Page MenuHomeFreeBSD

uma: Fix handling of reserves in zone_import()
ClosedPublic

Authored by markj on Oct 15 2021, 10:00 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 25, 8:05 PM
Unknown Object (File)
Fri, Jan 24, 5:42 PM
Unknown Object (File)
Fri, Jan 24, 4:35 PM
Unknown Object (File)
Thu, Jan 9, 5:19 AM
Unknown Object (File)
Mon, Jan 6, 2:06 AM
Unknown Object (File)
Nov 23 2024, 2:34 AM
Unknown Object (File)
Nov 21 2024, 2:30 PM
Unknown Object (File)
Nov 18 2024, 4:32 AM
Subscribers

Details

Summary

Kegs with no items reserved have uk_reserve = 0. So the check
keg->uk_reserve >= dom->ud_free_items will be true once all slabs are
depleted. Then, rather than go and allocate a fresh slab, we return.

The intent was to do this only when the keg actually has a reserve, so
modify the check to verify this first. Another approach would be to
make uk_reserve signed and set it to -1 until uma_zone_reserve() is
called, but requires a few casts elsewhere.

The bug would cause us to go to the keg more often than necessary when
filling buckets. In a steady state I wouldn't expect it to make much of
a difference, but maybe I'm missing something. I noticed the problem by
code inspection.

Fixes: 1b2dcc8c54a8 ("uma: Avoid depleting keg reserves when filling a bucket")

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable