Page MenuHomeFreeBSD

TSLOG: Optionally instrument pmap_zero_page
ClosedPublic

Authored by cperciva on May 30 2023, 3:13 AM.
Tags
None
Referenced Files
F108458420: D40326.diff
Sat, Jan 25, 1:00 AM
F108432118: D40326.id.diff
Fri, Jan 24, 5:38 PM
F108404872: D40326.id122826.diff
Fri, Jan 24, 12:50 PM
Unknown Object (File)
Mon, Jan 13, 10:38 PM
Unknown Object (File)
Dec 21 2024, 6:22 PM
Unknown Object (File)
Dec 7 2024, 7:09 PM
Unknown Object (File)
Dec 6 2024, 5:18 PM
Unknown Object (File)
Nov 15 2024, 5:47 AM
Subscribers

Details

Summary

Booting an amd64 kernel on Firecracker with 1 CPU and 128 MB of RAM,
pmap_zero_page is responsible for 4.6 ms of the 25.0 ms of boot time.
This is not in fact time spent zeroing pages though; almost all of
that time is spent in a first-touch penalty, presumably due to the
host Linux kernel faulting in backing pages one by one.

There's probably a way to improve that by teaching Firecracker to
fault in all the VM's pages from the start rather than having them
faulted in one at a time, but that's outside of FreeBSD's control.

This commit adds a TSLOG_PAGEZERO option which enables TSLOG on the
amd64 pmap_zero_page function; it's a separate option (turned off
by default even if TSLOG is enabled) since zeroing pages happens
enough that it can easily fill the TSLOG buffer and prevent other
timing information from being recorded.

Diff Detail

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