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, Jan 23, 2:41 AM
Unknown Object (File)
Mon, Jan 19, 5:29 PM
Unknown Object (File)
Sun, Jan 11, 10:18 PM
Unknown Object (File)
Mon, Jan 5, 8:32 PM
Unknown Object (File)
Dec 16 2025, 6:42 PM
Unknown Object (File)
Dec 3 2025, 7:47 PM
Unknown Object (File)
Nov 27 2025, 6:59 PM
Unknown Object (File)
Nov 25 2025, 4:58 AM
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.