Auto merge of #35378 - Amanieu:rwlock_eagain, r=alexcrichton
Handle RwLock reader count overflow `pthread_rwlock_rdlock` may return `EAGAIN` if the maximum reader count overflows. We shouldn't return a successful lock in that case.
This commit is contained in:
commit
877dfeb572
@ -50,7 +50,9 @@ impl RWLock {
|
|||||||
// the implementation allows recursive locking. The POSIX standard
|
// the implementation allows recursive locking. The POSIX standard
|
||||||
// doesn't require recursivly locking a rwlock to deadlock, but we can't
|
// doesn't require recursivly locking a rwlock to deadlock, but we can't
|
||||||
// allow that because it could lead to aliasing issues.
|
// allow that because it could lead to aliasing issues.
|
||||||
if r == libc::EDEADLK || *self.write_locked.get() {
|
if r == libc::EAGAIN {
|
||||||
|
panic!("rwlock maximum reader count exceeded");
|
||||||
|
} else if r == libc::EDEADLK || *self.write_locked.get() {
|
||||||
if r == 0 {
|
if r == 0 {
|
||||||
self.raw_unlock();
|
self.raw_unlock();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user