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)
Thu, Mar 28, 9:30 PM
Unknown Object (File)
Dec 23 2023, 6:18 PM
Unknown Object (File)
Dec 23 2023, 6:18 PM
Unknown Object (File)
Dec 23 2023, 6:17 PM
Unknown Object (File)
Dec 22 2023, 11:02 PM
Unknown Object (File)
Dec 20 2023, 4:50 AM
Unknown Object (File)
Nov 24 2023, 8:30 AM
Unknown Object (File)
Nov 9 2023, 3:37 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.