assert_vop_locked: make the assertion race-free and more efficient
this is really a minor improvement for the sake of correctness MFC after: 6 days
This commit is contained in:
parent
38c3b37a84
commit
9c2d52ecde
@ -3979,10 +3979,13 @@ assert_vi_unlocked(struct vnode *vp, const char *str)
|
||||
void
|
||||
assert_vop_locked(struct vnode *vp, const char *str)
|
||||
{
|
||||
int locked;
|
||||
|
||||
if (!IGNORE_LOCK(vp) &&
|
||||
(VOP_ISLOCKED(vp) == 0 || VOP_ISLOCKED(vp) == LK_EXCLOTHER))
|
||||
vfs_badlock("is not locked but should be", str, vp);
|
||||
if (!IGNORE_LOCK(vp)) {
|
||||
locked = VOP_ISLOCKED(vp);
|
||||
if (locked == 0 || locked == LK_EXCLOTHER)
|
||||
vfs_badlock("is not locked but should be", str, vp);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
Loading…
x
Reference in New Issue
Block a user