Page MenuHomeFreeBSD

Use atomics for object reference count so that we can use the shared lock to protect it.
ClosedPublic

Authored by jeff on Sep 10 2019, 8:34 PM.
Tags
None
Referenced Files
F107680544: D21598.id63765.diff
Fri, Jan 17, 1:10 PM
Unknown Object (File)
Sat, Jan 11, 2:33 PM
Unknown Object (File)
Thu, Jan 9, 8:44 PM
Unknown Object (File)
Sun, Jan 5, 8:26 AM
Unknown Object (File)
Mon, Dec 30, 5:41 AM
Unknown Object (File)
Sat, Dec 21, 3:09 PM
Unknown Object (File)
Nov 30 2024, 6:15 PM
Unknown Object (File)
Nov 24 2024, 3:00 AM
Subscribers

Details

Summary

This allows for shared locks in some cases where we are manipulating the object reference count.

It would be possible for non-vnode objects to actually atomically drop the reference count with no lock held as long as it is above 2. Callers that expect stable reference counts with the write lock held only require it stay stable below 2. The relationship between the object and vnode reference counts make this much more complex for vnodes. I would like to refactor this so we only bump the vnode ref for the first object ref but it requires other changes to vfs.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

jeff added reviewers: alc, kib, markj, dougm.
This revision is now accepted and ready to land.Sep 22 2019, 1:42 PM
sys/vm/vm_object.c
525 ↗(On Diff #61916)

BTW, why do you need the object lock there at all ? The object->type can only migrate from OBJT_VNODE to OBJT_DEAD until we hold the reference.