Page MenuHomeFreeBSD

Fix double unlock if the source file disappears
ClosedPublic

Authored by trasz on Nov 23 2020, 1:58 PM.
Tags
None
Referenced Files
F147912080: D27339.diff
Sat, Mar 14, 3:01 PM
Unknown Object (File)
Feb 7 2026, 12:09 AM
Unknown Object (File)
Jan 20 2026, 8:26 PM
Unknown Object (File)
Jan 20 2026, 8:20 AM
Unknown Object (File)
Jan 17 2026, 6:37 PM
Unknown Object (File)
Dec 20 2025, 2:30 AM
Unknown Object (File)
Dec 19 2025, 3:44 AM
Unknown Object (File)
Dec 12 2025, 3:15 AM
Subscribers

Details

Summary

Fix double unlock if the source file disappears; we would
unlock it here, only to unlock it again below, just before "bad".

Diff Detail

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

Event Timeline

trasz requested review of this revision.Nov 23 2020, 1:58 PM
sys/fs/msdosfs/msdosfs_vnops.c
1144

So why this vrele() uses a_vfp pointer instead of fvp ? Is it possible that they are different (doubt it). If so wouldn't it be more natural to stop these intermediate vrele/unlocks, replacing them by final vput(fvp) ?

sys/fs/msdosfs/msdosfs_vnops.c
1144

It is possible they are different - this code happens after a call to relookup(), which can change fvp. In fact, it has to be different, given the conditional ("xp != ip").

This revision is now accepted and ready to land.Dec 3 2020, 1:14 PM