Page MenuHomeFreeBSD

arm64: Handle changing self-referential DMAP pages
ClosedPublic

Authored by andrew on Mar 19 2026, 4:04 PM.
Tags
None
Referenced Files
F158008644: D55943.id175105.diff
Wed, May 27, 10:56 AM
Unknown Object (File)
Mon, May 18, 2:26 PM
Unknown Object (File)
Mon, May 18, 2:22 PM
Unknown Object (File)
Mon, May 18, 8:32 AM
Unknown Object (File)
Mon, May 18, 8:25 AM
Unknown Object (File)
Mon, May 18, 8:03 AM
Unknown Object (File)
Mon, May 18, 8:00 AM
Unknown Object (File)
Mon, May 18, 7:54 AM
Subscribers

Details

Summary

Support changing the property of a DMAP page that holds it's own page
table entry.

Because we need to perform a break-before-make sequence to change the
properties of pages a page that also holds it's own page table entry
will fault in the make part of the sequence.

Handle this by mapping the page with a temporary mapping as we already
do when demoting a superpage.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 72053
Build 68936: arc lint + arc unit

Event Timeline

sys/arm64/arm64/pmap.c
8413

IMO it makes more sense to reserve a page frame and use it there instead of allocating and then freeing KVA, similar to the CMAPs on amd64. You would avoid the weird EINVAL from below.

sys/arm64/arm64/pmap.c
8413

I agree. It would be better to avoid error cases when updating the kernel pmap.

sys/arm64/arm64/pmap.c
8413

We already return a failure if demote fails above.

sys/arm64/arm64/pmap.c
8413

We can remove the first error path in pmap_demote_l2() by implementing kib's suggestion. The second one won't happen for kernel maps. The third one is quite unlikely to happen for kernel maps given that we use VM_ALLOC_INTERRUPT to allocate the new L3 page. I still think it's better to avoid the failure mode here.

This revision is now accepted and ready to land.Apr 10 2026, 2:33 PM