Page MenuHomeFreeBSD

arm64 pmap: implement per-superpage locks
ClosedPublic

Authored by andrew on Aug 23 2022, 12:24 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 23, 7:40 AM
Unknown Object (File)
Tue, Jan 14, 2:28 AM
Unknown Object (File)
Fri, Jan 10, 8:21 PM
Unknown Object (File)
Thu, Jan 9, 4:19 AM
Unknown Object (File)
Sun, Dec 29, 3:11 AM
Unknown Object (File)
Dec 13 2024, 7:41 AM
Unknown Object (File)
Nov 19 2024, 11:43 PM
Unknown Object (File)
Nov 19 2024, 11:43 PM
Subscribers

Details

Summary

As with amd64 pmap introduce per-superpage locks backed by pages
allocated by their respective domains.

This significiantly reduces lock contantion from pmap when running
poudriere on a 160 core Ampere Altra server

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 47262
Build 44149: arc lint + arc unit

Event Timeline

Why do we continue to implement the old locking scheme if NUMA isn't configured? It seems more complicated than necessary, and it's not only NUMA systems that suffer from pv list lock contention. Graviton EC2 instances always have a single memory domain, and one might disable NUMA in the kernel config.

sys/arm64/arm64/pmap.c
195
1386–1387
1411

Pass VM_ALLOC_ZERO to vm_page_alloc_noobj_domain() instead of calling pmap_zero_page().

1564

Extra newline.

andrew marked 4 inline comments as done.

Fixes from feedback by @markj

This revision was not accepted when it landed; it landed in state Needs Review.Nov 17 2022, 5:13 PM
This revision was automatically updated to reflect the committed changes.