fix refrigerator() vs thaw_process() race
refrigerator() can miss a wakeup, "wait event" loop needs a proper memory ordering. Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru> Acked-by: "Rafael J. Wysocki" <rjw@sisk.pl> Cc: Pavel Machek <pavel@ucw.cz> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
e87be11434
commit
433ecb4ab3
|
@ -47,8 +47,10 @@ void refrigerator(void)
|
||||||
recalc_sigpending(); /* We sent fake signal, clean it up */
|
recalc_sigpending(); /* We sent fake signal, clean it up */
|
||||||
spin_unlock_irq(¤t->sighand->siglock);
|
spin_unlock_irq(¤t->sighand->siglock);
|
||||||
|
|
||||||
while (frozen(current)) {
|
for (;;) {
|
||||||
current->state = TASK_UNINTERRUPTIBLE;
|
set_current_state(TASK_UNINTERRUPTIBLE);
|
||||||
|
if (!frozen(current))
|
||||||
|
break;
|
||||||
schedule();
|
schedule();
|
||||||
}
|
}
|
||||||
pr_debug("%s left refrigerator\n", current->comm);
|
pr_debug("%s left refrigerator\n", current->comm);
|
||||||
|
|
Loading…
Reference in New Issue