Page MenuHomeFreeBSD

Allow safe unlocked busy sleeps.
ClosedPublic

Authored by jeff on Feb 10 2020, 8:11 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 12, 7:12 AM
Unknown Object (File)
Mon, Jan 6, 6:28 AM
Unknown Object (File)
Mon, Jan 6, 5:51 AM
Unknown Object (File)
Sat, Jan 4, 2:51 AM
Unknown Object (File)
Nov 16 2024, 10:25 PM
Unknown Object (File)
Oct 3 2024, 2:19 PM
Unknown Object (File)
Sep 30 2024, 4:48 AM
Unknown Object (File)
Sep 23 2024, 7:41 PM
Subscribers

Details

Summary

The title is perhaps a misnomer. It does add an unlocked sleep that revalidates the page's object and pindex under the sleepq lock. This actually eliminates the need for object as an interlock in sleeps although this code is maintained because it does reduce the number of times object is dropped and picked back up.

The real thrust however is to refactor the sleep routines so I can ultimately eliminate some variants. We have too many and frankly the nonshared argument is very confusing. I am moving towards just passing allocflags. The only difference between vm_page_busy_sleep() and vm_page_sleep_if_busy() is that one returns with the object lock and one returns without. This could easily be solved with a VM_ALLOC_DROP or simply a busy_sleep() and busy_sleep_drop() that take an allocflags parameter to determine the lock type.

This helps me move towards simplifying the external API while still allowing for unlocked sleeps and potentially a third busy type (shared (io), exclusive, map) without adding a bunch of new interfaces.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 29279
Build 27192: arc lint + arc unit