Page MenuHomeFreeBSD

nfsclient: access v_mount only after the vnode is locked
ClosedPublic

Authored by kib on Sep 26 2022, 6:13 PM.
Tags
None
Referenced Files
F133384374: D36722.id111114.diff
Sat, Oct 25, 9:16 AM
F133349784: D36722.diff
Sat, Oct 25, 2:58 AM
F133340908: D36722.id111114.diff
Sat, Oct 25, 1:25 AM
Unknown Object (File)
Fri, Oct 10, 4:51 PM
Unknown Object (File)
Fri, Oct 10, 4:51 PM
Unknown Object (File)
Fri, Oct 10, 4:51 PM
Unknown Object (File)
Fri, Oct 10, 4:40 AM
Unknown Object (File)
Thu, Oct 9, 11:21 PM
Subscribers

Details

Summary

and we checked that it is not reclaimed.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

kib requested review of this revision.Sep 26 2022, 6:13 PM
This revision is now accepted and ready to land.Sep 27 2022, 12:52 AM

I do have a question?

How did v_data get referenced in the unpatched code?
Do you mean the NFS specific structure on the mount point?

I do have a question?

How did v_data get referenced in the unpatched code?
Do you mean the NFS specific structure on the mount point?

Sorry, it is v_mount not v_data. I fixed the commit message, thanks.

kib retitled this revision from nfsclient: access v_data only after the vnode is locked to nfsclient: access v_mount only after the vnode is locked.Sep 27 2022, 11:42 AM
sys/fs/nfsclient/nfs_clvnops.c
3934

If invp == outvp then the loop above will never terminate, and there is a double-unlock below. Probably it's better to handle that as a separate case at the beginning of the function, since we do not require the mountpoint mutex to check invp == outvp.

Avoid invp == outvp case for locking vnodes.
Reorg and clean code, avoid using ap->a_XXX for locals.

This revision now requires review to proceed.Sep 27 2022, 1:39 PM

Looks ok to me. It seems rather wasteful that we have to uselessly acquire three mutexes each time VOP_COPY_FILE_RANGE is called on a NFSv3 mount. Was it ever considered to have separate vnode ops tables for different NFS major versions? I assume that the version is constant for the lifetime of the mount.

This revision is now accepted and ready to land.Sep 27 2022, 1:51 PM

Looks fine to me. Good catch w.r.t. invp == outvp.

During development, NFSv4 compounds were based on NFSv3
RPCs, so they share a lot of code. It would not have made sense
to have a separate VOP table,

Now that NFSv4.2 has an assortment of operations unlike NFSv3,
it might make sense, for your example and others.