When SMR was introduced, zone_put_bucket() was changed to always place
full buckets at the end of the queue.  However, it is generally
preferable to use recently used buckets since items are more likely to
be resident in data caches.  For buckets that have no constraint on
reuse, use a last-in-first-out ordering.  Gleb reported that this
measurably reduces time spent in UMA when allocating from vm_page cache
zones.
Details
Details
- Reviewers
- rlibby - jeff - glebius 
- Commits
- rS366378: uma: Use LIFO for non-SMR bucket caches
Diff Detail
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
- Lint Not Applicable 
- Unit
- Tests Not Applicable 
Event Timeline
| sys/vm/uma_core.c | ||
|---|---|---|
| 741–744 ↗ | (On Diff #77021) | Maybe I'm confused, but isn't this test backward? Shouldn't it be, if smr then tail else head? Maybe also better written as ub_seq == SMR_SEQ_INVALID? | 
| sys/vm/uma_core.c | ||
|---|---|---|
| 741–744 ↗ | (On Diff #77021) | Sorry, I missed uploading the fix. You're right, this is supposed to be ub_seq == SMR_SEQ_INVALID. |