Page MenuHomeFreeBSD

(lookup 2) vfs: add the infrastructure for lockless lookup
ClosedPublic

Authored by mjg on Jul 6 2020, 7:29 PM.
Tags
None
Referenced Files
F108392504: D25577.diff
Fri, Jan 24, 10:21 AM
Unknown Object (File)
Sat, Jan 18, 5:47 PM
Unknown Object (File)
Sat, Jan 4, 2:42 AM
Unknown Object (File)
Nov 29 2024, 9:42 AM
Unknown Object (File)
Nov 21 2024, 12:03 AM
Unknown Object (File)
Nov 6 2024, 8:40 PM
Unknown Object (File)
Nov 4 2024, 1:13 PM
Unknown Object (File)
Oct 22 2024, 6:01 PM
Subscribers

Details

Summary

Assorted changes split out from the complete diff. Some have value on their own, but for the most part are only there for the new lookup.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 32269

Event Timeline

mjg requested review of this revision.Jul 6 2020, 7:29 PM
sys/kern/kern_descrip.c
3350–3354

I am still surprised with such loops. Don't you need yield sometimes ?

sys/kern/vfs_subr.c
3088

Why not extract this block from there and vget_finish() into a common function ?

sys/kern/kern_descrip.c
3350–3354

If worrying about excessive looping, I think the right solution is to do the above once and in case of failure take the lock.

sys/kern/vfs_subr.c
3088

ok, will update later

sys/kern/kern_descrip.c
3350–3354

My concern that if we are on UP and mutator is preempted by this loop at the unlucky moment, system can be livelocked.

  • rebase

does not address vref_smr yet

sys/kern/vfs_subr.c
3088

So I don't know how to name this. In the patchset I introduce vget_finish_ref later to facilitate WANTPARENT/!LOCKLEAF lookups, but I'm not going to call something like that from vref.

sys/kern/vfs_subr.c
3088

I would call it vref_hold() or vget_ref_hold(). This name describes the action of the code.

  • add vfs_smr_entered_load
  • vget_finish_ref
sys/kern/vfs_subr.c
3088

I reworked the only consumer of vref_smr to use vget direclty instead, thus getting rid of the problem for the time being.

This revision is now accepted and ready to land.Jul 13 2020, 6:24 PM
This revision was automatically updated to reflect the committed changes.