Page MenuHomeFreeBSD

vn_open_vnode(): handle error when fp == NULL
ClosedPublic

Authored by kib on Apr 19 2021, 10:32 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Mar 21, 10:08 AM
Unknown Object (File)
Feb 24 2025, 3:14 PM
Unknown Object (File)
Jan 27 2025, 5:37 AM
Unknown Object (File)
Jan 26 2025, 1:50 AM
Unknown Object (File)
Jan 26 2025, 12:34 AM
Unknown Object (File)
Jan 17 2025, 8:20 PM
Unknown Object (File)
Nov 14 2024, 12:32 PM
Unknown Object (File)
Oct 5 2024, 8:46 AM
Subscribers

Details

Summary

If VOP_ADD_WRITECOUNT() or adv locking failed, so VOP_CLOSE() needs to be called, we cannot use fp fo_close() when there is no fp. This occurs when e.g. kernel code directly calls vn_open() instead of the open(2) syscall.

In this case, VOP_CLOSE() can be called directly, after possible lock upgrade.

Reported by: nvass@gmx.com
PR: 255119

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kib requested review of this revision.Apr 19 2021, 10:32 AM
kib created this revision.

This fixes the issue for me. I have started a full test on mercat1.

In D29830#669416, @pho wrote:

This fixes the issue for me. I have started a full test on mercat1.

I completed a full stress2 test without seeing any issues.

This revision was not accepted when it landed; it landed in state Needs Review.Apr 21 2021, 3:08 PM
This revision was automatically updated to reflect the committed changes.