Set waiters flag before checking semaphore's counter,
otherwise we might lose a wakeup. Tested on postgresql database server.
This commit is contained in:
parent
6da4f04ede
commit
7d46cfed0a
@ -2853,6 +2853,8 @@ do_sem_wait(struct thread *td, struct _usem *sem, struct timespec *timeout)
|
||||
umtxq_insert(uq);
|
||||
umtxq_unlock(&uq->uq_key);
|
||||
|
||||
suword32(__DEVOLATILE(uint32_t *, &sem->_has_waiters), 1);
|
||||
|
||||
count = fuword32(__DEVOLATILE(uint32_t *, &sem->_count));
|
||||
if (count != 0) {
|
||||
umtxq_lock(&uq->uq_key);
|
||||
@ -2863,11 +2865,6 @@ do_sem_wait(struct thread *td, struct _usem *sem, struct timespec *timeout)
|
||||
return (0);
|
||||
}
|
||||
|
||||
/*
|
||||
* set waiters byte and sleep.
|
||||
*/
|
||||
suword32(__DEVOLATILE(uint32_t *, &sem->_has_waiters), 1);
|
||||
|
||||
umtxq_lock(&uq->uq_key);
|
||||
umtxq_unbusy(&uq->uq_key);
|
||||
umtxq_unlock(&uq->uq_key);
|
||||
|
Loading…
Reference in New Issue
Block a user