Page MenuHomeFreeBSD

call vm_lowmem hook in uma_reclaim_worker
ClosedPublic

Authored by avg on Feb 23 2017, 12:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 4:34 AM
Unknown Object (File)
Tue, Jan 7, 5:32 AM
Unknown Object (File)
Mon, Jan 6, 11:01 PM
Unknown Object (File)
Sat, Dec 14, 1:14 PM
Unknown Object (File)
Nov 4 2024, 7:47 PM
Unknown Object (File)
Nov 4 2024, 8:24 AM
Unknown Object (File)
Nov 4 2024, 6:46 AM
Unknown Object (File)
Nov 4 2024, 6:46 AM
Subscribers

Details

Summary

A comment near kmem_reclaim() implies that we already did that.
Calling the hook is useful, because some handlers, e.g. ARC,
might be able to release significant amounts of KVA.

Now that we have more than one place where vm_lowmem hook is called,
use this change as an opportunity to introduce flags that describe
a reason for calling the hook. No handler makes use of the flags yet.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 7714
Build 7861: arc lint + arc unit

Event Timeline

avg retitled this revision from to call vm_lowmem hook in uma_reclaim_worker.
avg updated this object.
avg edited the test plan for this revision. (Show Details)
avg added reviewers: kib, markj.
sys/vm/uma_core.c
3205

I suggest that some more care is needed there. In particular, I would only clear uma_reclaim_needed after re-acquiring uma_drain_lock.

sys/vm/vm_kern.c
557

if (i != 0)

sys/vm/vm_pageout.h
92

If these can be ORed together as suggested by the check in debug_vm_lowmem(), it'd be clearer to use hex constants.

sys/vm/uma_core.c
3205

I am not sure if that would actually make any difference, because that flag is already sloppy in a sense that it's set without holding the lock.

sys/vm/vm_kern.c
557

Okay.

sys/vm/vm_pageout.h
92

Sure. Will do.

markj edited edge metadata.
This revision is now accepted and ready to land.Feb 24 2017, 5:12 PM
kib edited edge metadata.
kib added inline comments.
sys/vm/vm_pageout.h
92

I would call it VM_LOW_KMEM or VM_FRAG_KMEM.

This revision was automatically updated to reflect the committed changes.