Peter Zijlstra
37aadc687a
sched: Unbreak wakeups
...
Remove broken task->state references and let wake_up_process() DTRT.
The anti-pattern in these patches breaks the ordering of ->state vs
COND as described in the comment near set_current_state() and can lead
to missed wakeups:
(OoO load, observes RUNNING)<-.
for (;;) { |
t->state = UNINTERRUPTIBLE; |
smp_mb(); ,-----> | (observes !COND)
| /
if (COND) ---------' | COND = 1;
break; `- if (t->state != RUNNING)
wake_up_process(t); // not done
schedule(); // forever waiting
}
t->state = TASK_RUNNING;
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Davidlohr Bueso <dbueso@suse.de>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Acked-by: Will Deacon <will@kernel.org>
Link: https://lore.kernel.org/r/20210611082838.160855222@infradead.org
2021-06-18 11:43:06 +02:00
..
2021-06-02 21:59:22 +02:00
2021-06-10 09:58:50 -04:00
2021-05-07 00:26:34 -07:00
2021-04-27 18:09:44 -07:00
2021-05-04 10:58:49 -07:00
2021-05-31 10:14:49 +02:00
2021-05-31 10:14:51 +02:00
2021-05-07 00:26:32 -07:00
2021-05-05 12:39:29 -07:00
2021-05-18 10:58:02 -07:00
2021-04-27 18:14:38 -07:00
2021-05-18 12:53:51 +02:00
2021-04-08 19:37:21 +02:00
2021-03-30 15:34:17 +02:00
2021-03-24 17:20:18 -07:00
2021-06-18 11:31:25 +02:00
2021-05-31 10:14:49 +02:00
2021-06-08 16:44:00 -04:00
2021-05-02 00:43:35 +09:00
2020-12-15 22:46:15 -08:00
2021-05-07 00:26:33 -07:00
2021-02-23 10:25:27 -05:00
2020-12-03 14:58:35 +01:00
2020-12-03 14:58:35 +01:00
2021-03-22 15:23:32 -04:00
2021-03-24 12:11:48 -04:00
2021-03-22 15:23:32 -04:00
2021-04-27 13:50:58 -07:00
2020-07-30 11:15:58 -07:00
2021-01-24 14:27:16 +01:00
2021-04-08 16:04:20 -07:00
2020-08-23 17:36:59 -05:00
2020-06-11 15:14:36 +02:00
2020-09-01 09:58:03 +02:00
2021-04-21 13:55:43 +02:00
2020-12-15 22:46:18 -08:00
2021-05-06 19:24:11 -07:00
2021-05-12 11:43:25 +02:00
2021-05-06 19:24:13 -07:00
2020-12-15 22:46:19 -08:00
2021-05-26 08:58:53 +02:00
2021-03-27 14:09:10 -06:00
2021-05-06 20:19:04 +02:00
2021-04-25 05:26:10 +09:00
2021-02-26 09:41:03 -08:00
2020-11-02 12:14:19 -08:00
2021-06-10 10:00:08 +02:00
2021-03-19 13:16:44 +01:00
2021-04-08 16:04:21 -07:00
2020-12-15 19:36:48 -08:00
2021-06-01 16:00:10 +02:00
2020-11-02 18:00:20 -08:00
2021-05-07 00:26:32 -07:00
2021-05-07 00:26:32 -07:00
2021-02-22 12:33:26 +00:00
2020-10-05 13:37:03 +02:00
2021-05-07 00:26:33 -07:00
2021-02-19 14:57:12 -05:00
2021-05-18 12:53:53 +02:00
2021-05-02 00:43:35 +09:00
2021-01-19 10:24:45 +01:00
2021-01-19 10:24:45 +01:00
2021-05-17 09:48:24 +02:00
2020-09-01 09:58:03 +02:00
2020-12-14 16:40:27 -08:00
2020-09-04 17:51:55 +10:00
2020-11-14 11:26:04 -08:00
2020-12-17 13:01:31 -08:00
2020-12-14 16:40:27 -08:00
2020-12-15 19:36:48 -08:00
2021-04-10 13:35:54 +02:00
2021-05-12 10:45:22 -07:00
2020-10-16 11:11:19 -07:00
2021-03-18 16:58:02 +01:00
2020-07-27 14:31:12 -04:00
2020-12-15 22:46:18 -08:00
2020-11-25 18:52:35 +01:00
2021-05-14 19:41:32 -07:00
2021-04-14 18:04:09 +02:00
2021-01-04 13:53:41 -08:00
2020-12-01 10:30:28 +00:00
2021-05-29 11:13:27 -07:00
2021-05-21 06:12:52 -10:00
2021-05-06 15:33:49 +02:00
2021-05-12 13:01:45 +02:00
2021-06-18 11:43:06 +02:00
2020-09-19 13:13:39 -07:00
2020-09-18 14:24:16 +01:00
2021-04-09 13:22:12 +02:00
2021-03-23 16:01:58 +01:00
2021-05-01 18:50:44 -07:00
2021-05-12 11:43:31 +02:00
2021-06-03 19:00:49 +02:00
2021-04-30 11:20:42 -07:00
2020-11-16 08:08:54 -08:00
2021-03-08 14:22:28 -08:00
2021-02-09 12:27:29 -05:00
2021-03-16 16:49:31 +01:00
2021-05-07 00:26:34 -07:00
2021-05-09 13:07:03 -07:00
2021-05-07 00:26:34 -07:00
2020-08-19 14:14:12 +02:00
2021-03-19 22:23:19 +01:00
2020-08-19 14:13:20 +02:00
2021-01-26 11:16:34 +00:00
2021-05-22 15:09:07 -10:00
2021-05-20 12:58:30 -04:00