Page MenuHomeFreeBSD

arm64: Make shareability attributes dynamic
ClosedPublic

Authored by andrew on Aug 21 2024, 12:15 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Dec 21, 1:01 PM
Unknown Object (File)
Fri, Dec 20, 11:59 PM
Unknown Object (File)
Fri, Dec 20, 8:18 AM
Unknown Object (File)
Wed, Dec 18, 1:57 AM
Unknown Object (File)
Thu, Dec 5, 10:18 AM
Unknown Object (File)
Nov 9 2024, 7:08 PM
Unknown Object (File)
Nov 4 2024, 12:10 PM
Unknown Object (File)
Oct 21 2024, 4:47 AM
Subscribers

Details

Summary

When LPA2 is enabled the shareability attribute in the page table are
replaces with output address bits. To support a larger physical address
space make this attribute dynamic so we only set it when appropriate.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

sys/arm64/include/pte.h
114 ↗(On Diff #142300)

Why not include pmap_sh_attr here?

sys/arm64/include/pte.h
114 ↗(On Diff #142300)

We can't because it's used in locore.S

sys/arm64/arm64/pmap.c
358

Again, should it be __read_mostly?

sys/arm64/include/pte.h
114 ↗(On Diff #142300)

At this point, where ATTR_DEFAULT is simply ATTR_AF, I'm going to argue for its elimination. Instead, put ATTR_AF in its place. There are places where we construct the mapping with ATTR_DEFAULT, then later clear ATTR_AF. Instead, these could simply not set ATTR_AF in the first place, and only set it if the mapping is unmanaged.

  • Rebase on D46466
  • Add __read_mostly
  • Set VTCR_EL2.DS as stage 2 tables are also affected
andrew retitled this revision from arm64: Move ATTR_SH_IS out of ATTR_DEFAULT to arm64: Make shareability attributes dynamic.Aug 29 2024, 12:49 PM
andrew edited the summary of this revision. (Show Details)
This revision is now accepted and ready to land.Aug 30 2024, 9:26 PM
This revision was automatically updated to reflect the committed changes.