- Add vop_strategy_pre to validate VOP_STRATEGY locking.

- Disable original vop_strategy lock specification.
 - Switch to the new vop_strategy_pre for lock validation.

VOP_STRATEGY requires only that the buf is locked UNLESS the block numbers need
to be translated.  There may be other reasons, but as long as the underlying
layer uses a VOP to perform the operations they will be caught later.
This commit is contained in:
Jeff Roberson 2002-07-06 05:21:12 +00:00
parent 13e407efee
commit 302c7aaab9
2 changed files with 17 additions and 0 deletions

View File

@ -253,6 +253,22 @@ vop_rename_pre(void *ap)
ASSERT_VOP_LOCKED(a->a_tdvp, "vop_rename: tdvp not locked.\n");
}
void
vop_strategy_pre(void *ap)
{
struct vop_strategy_args *a = ap;
int status;
status = lockstatus(&a->a_bp->b_lock, curthread);
if (status != LK_SHARED && status != LK_EXCLUSIVE) {
if (vfs_badlock_print)
printf("VOP_STRATEGY: bp is not locked but should be.\n");
if (vfs_badlock_panic)
Debugger("Lock violation.\n");
}
}
#endif /* DEBUG_VFS_LOCKS */
void

View File

@ -524,6 +524,7 @@ do { \
} while (0)
void vop_rename_pre(void *a);
void vop_strategy_pre(void *a);
#else