Page MenuHomeFreeBSD

uma: Avoid depleting keg reserves when filling a bucket
ClosedPublic

Authored by markj on Oct 13 2020, 8:56 PM.
Tags
None
Referenced Files
F106857899: D26771.diff
Mon, Jan 6, 12:38 PM
Unknown Object (File)
Nov 23 2024, 8:39 PM
Unknown Object (File)
Nov 22 2024, 8:56 PM
Unknown Object (File)
Nov 21 2024, 4:08 PM
Unknown Object (File)
Nov 21 2024, 1:40 PM
Unknown Object (File)
Nov 20 2024, 3:27 PM
Unknown Object (File)
Nov 11 2024, 1:52 PM
Unknown Object (File)
Nov 11 2024, 4:59 AM
Subscribers

Details

Summary

zone_import() fetches a free or partially free slab from the keg and
then uses its items to populate an array, typically filling a bucket.
If a single allocation causes the keg to drop below its minimum reserve,
the inner loop ends. However, if the bucket is still not full and
M_USE_RESERVE is specified, the outer loop will continue to fetch items
from the keg.

If M_USE_RESERVE is specified and the number of free items is below the
reserved limit, we should return only a single item. Otherwise, if the
bucket size is larger than the reserve, all of the reserved items may
end up in a single per-CPU bucket, invisible to other CPUs.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 34162
Build 31318: arc lint + arc unit

Event Timeline

markj requested review of this revision.Oct 13 2020, 8:56 PM
markj created this revision.
sys/vm/uma_core.c
3762–3766

Should this be conditional on actually being at or below the reserve limit?

markj marked an inline comment as done.

Modify zone_import() to return as soon as the free count dips below the
reserve. This is still not perfect, since for round-robin zones we could
potentially continue allocating from other domains.

This revision is now accepted and ready to land.Oct 14 2020, 5:53 PM