Page MenuHomeFreeBSD

Fix zone and keg alignment as well as boot pages calculations on numa.
ClosedPublic

Authored by jeff on Jan 5 2020, 11:53 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, May 23, 10:50 AM
Unknown Object (File)
Apr 17 2025, 6:56 PM
Unknown Object (File)
Apr 14 2025, 12:49 PM
Unknown Object (File)
Mar 31 2025, 9:09 AM
Unknown Object (File)
Mar 10 2025, 7:17 PM
Unknown Object (File)
Feb 9 2025, 8:16 PM
Unknown Object (File)
Feb 4 2025, 3:43 PM
Unknown Object (File)
Feb 1 2025, 8:55 PM
Subscribers

Details

Summary

While making NUMA amd64 w/o MD_SMALL_ALLOC boot I noticed a number of numa bugs but also weaker than required alignment. In practice the alignment of zones was actually dictated by the alignment of the per-cpu cache structure. This just clarifies existing behavior while simplifying code.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

jeff added reviewers: rlibby, markj.
jeff set the repository for this revision to rS FreeBSD src repository - subversion.
sys/amd64/include/vmparam.h
79 ↗(On Diff #66394)

obviously not committing this.

This revision is now accepted and ready to land.Jan 6 2020, 12:10 AM
markj added inline comments.
sys/vm/uma_int.h
169 ↗(On Diff #66394)

Typo: terminology.

I think we used to define CACHE_LINE_SIZE to 128 on amd64 for this reason. I'm not sure when that changed.