cvs commit: src/sys/vfs/deadfs dead_vnops.c
Matthew Dillon
dillon at crater.dragonflybsd.org
Wed May 24 18:22:11 PDT 2006
dillon 2006/05/24 18:20:07 PDT
DragonFly src repository
Modified files:
sys/vfs/deadfs dead_vnops.c
Log:
When a vnode is vgone()'d its v_ops is replaced with dead_vnode_ops.
dead_vnode_ops replaces VOP_LOCK with a dummy routine that just returns
TRUE.
This blows up anyone actually trying to access the vnode by improperly
returning a successful lock which then panics the machine when the caller
tries to unlock it. This also screws up VOP_LOCK vs vx_lock() interactions
and can theoretically create other problems.
Normally vgone()'d vnodes have no references and this isn't a problem.
The two notable exceptions are (1) when revoke() is called on a device
(i.e. tty), and (2) when a procfs or linprocfs vnode is destroyed due
to a process exit while another process is accessing it.
Remove dead_lock(). Dead vnodes revert to defaultops which implement
the expected lockmgr lock.
Revision Changes Path
1.17 +0 -13 src/sys/vfs/deadfs/dead_vnops.c
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/deadfs/dead_vnops.c.diff?r1=1.16&r2=1.17&f=u
More information about the Commits
mailing list