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
Unknown Object (File)
Wed, Jan 22, 6:56 AM
Unknown Object (File)
Tue, Jan 7, 9:24 AM
Unknown Object (File)
Dec 9 2024, 1:35 PM
Unknown Object (File)
Dec 4 2024, 1:22 PM
Unknown Object (File)
Oct 30 2024, 12:26 PM
Unknown Object (File)
Oct 11 2024, 1:24 AM
Unknown Object (File)
Sep 27 2024, 11:08 PM
Unknown Object (File)
Sep 27 2024, 11:07 PM
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
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

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