<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
From: Pavel Machek &lt;pavel@ucw.cz&gt;

This should make refrigerator sleep properly, not busywait after the first
schedule() returns.

Signed-off-by: Pavel Machek &lt;pavel@suse.cz&gt;
Signed-off-by: Andrew Morton &lt;akpm@osdl.org&gt;
---

 kernel/power/process.c |    5 +++--
 1 files changed, 3 insertions(+), 2 deletions(-)

diff -puN kernel/power/process.c~remove-busywait-in-refrigerator kernel/power/process.c
--- devel/kernel/power/process.c~remove-busywait-in-refrigerator	2005-07-28 16:17:17.000000000 -0700
+++ devel-akpm/kernel/power/process.c	2005-07-28 16:17:17.000000000 -0700
@@ -38,7 +38,6 @@ void refrigerator(void)
 	   processes around? */
 	long save;
 	save = current-&gt;state;
-	current-&gt;state = TASK_UNINTERRUPTIBLE;
 	pr_debug("%s entered refrigerator\n", current-&gt;comm);
 	printk("=");
 
@@ -47,8 +46,10 @@ void refrigerator(void)
 	recalc_sigpending(); /* We sent fake signal, clean it up */
 	spin_unlock_irq(&amp;current-&gt;sighand-&gt;siglock);
 
-	while (frozen(current))
+	while (frozen(current)) {
+		current-&gt;state = TASK_UNINTERRUPTIBLE;
 		schedule();
+	}
 	pr_debug("%s left refrigerator\n", current-&gt;comm);
 	current-&gt;state = save;
 }
_
</pre></body></html>