summaryrefslogtreecommitdiff
path: root/kern/sleepq.c
diff options
context:
space:
mode:
authorRichard Braun <rbraun@sceen.net>2018-01-06 23:28:08 +0100
committerRichard Braun <rbraun@sceen.net>2018-01-06 23:28:08 +0100
commita97a2bc6f1c24851ef19600a7bd15b211137abfe (patch)
treeda6532992f523df92a642031eda4cc8750398a2b /kern/sleepq.c
parenta56a2183e428ef806225482eff5b44da9b79e306 (diff)
kern/sleepq: fix signal behaviour
In order to correctly implement the behaviour of condition_signal, which must wake up at least one waiting thread if there's any, sleepq_signal wakes up the oldest waiter and shifts it. The FIFO behaviour is removed from the specification, as the only user which relied on it was a previous condition variable implementation.
Diffstat (limited to 'kern/sleepq.c')
-rw-r--r--kern/sleepq.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/kern/sleepq.c b/kern/sleepq.c
index bd0e363..0d04c6e 100644
--- a/kern/sleepq.c
+++ b/kern/sleepq.c
@@ -492,11 +492,13 @@ sleepq_signal(struct sleepq *sleepq)
{
struct sleepq_waiter *waiter;
- if (list_empty(&sleepq->waiters)) {
+ waiter = sleepq->oldest_waiter;
+
+ if (!waiter) {
return;
}
- waiter = list_last_entry(&sleepq->waiters, struct sleepq_waiter, node);
+ sleepq_shift_oldest_waiter(sleepq);
sleepq_waiter_set_pending_wakeup(waiter);
sleepq_waiter_wakeup(waiter);
}