Move the NORELEASE check to after the recurse count decrement and bailout, this
is not counted as actually releasing the lock.
This commit is contained in:
parent
15bfb6156f
commit
4eafa084fe
@ -1511,12 +1511,6 @@ witness_unlock(struct lock_object *lock, int flags, const char *file, int line)
|
||||
instance->li_line);
|
||||
panic("share->uexcl");
|
||||
}
|
||||
if ((instance->li_flags & LI_NORELEASE) != 0 && witness_watch > 0) {
|
||||
printf("forbidden unlock of (%s) %s @ %s:%d\n", class->lc_name,
|
||||
lock->lo_name, file, line);
|
||||
panic("lock marked norelease");
|
||||
}
|
||||
|
||||
/* If we are recursed, unrecurse. */
|
||||
if ((instance->li_flags & LI_RECURSEMASK) > 0) {
|
||||
CTR4(KTR_WITNESS, "%s: pid %d unrecursed on %s r=%d", __func__,
|
||||
@ -1525,6 +1519,12 @@ witness_unlock(struct lock_object *lock, int flags, const char *file, int line)
|
||||
instance->li_flags--;
|
||||
return;
|
||||
}
|
||||
/* The lock is now being dropped, check for NORELEASE flag */
|
||||
if ((instance->li_flags & LI_NORELEASE) != 0 && witness_watch > 0) {
|
||||
printf("forbidden unlock of (%s) %s @ %s:%d\n", class->lc_name,
|
||||
lock->lo_name, file, line);
|
||||
panic("lock marked norelease");
|
||||
}
|
||||
|
||||
/* Otherwise, remove this item from the list. */
|
||||
s = intr_disable();
|
||||
|
Loading…
Reference in New Issue
Block a user