aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/freezer.h2
-rw-r--r--kernel/cgroup_freezer.c4
-rw-r--r--kernel/freezer.c21
-rw-r--r--kernel/power/process.c8
4 files changed, 16 insertions, 19 deletions
diff --git a/include/linux/freezer.h b/include/linux/freezer.h
index a0f1b3a3604f..a28842e588f4 100644
--- a/include/linux/freezer.h
+++ b/include/linux/freezer.h
@@ -48,7 +48,7 @@ static inline bool try_to_freeze(void)
48 return __refrigerator(false); 48 return __refrigerator(false);
49} 49}
50 50
51extern bool freeze_task(struct task_struct *p, bool sig_only); 51extern bool freeze_task(struct task_struct *p);
52extern bool __set_freezable(bool with_signal); 52extern bool __set_freezable(bool with_signal);
53 53
54#ifdef CONFIG_CGROUP_FREEZER 54#ifdef CONFIG_CGROUP_FREEZER
diff --git a/kernel/cgroup_freezer.c b/kernel/cgroup_freezer.c
index 2327ad11725f..e411a60cc2c8 100644
--- a/kernel/cgroup_freezer.c
+++ b/kernel/cgroup_freezer.c
@@ -206,7 +206,7 @@ static void freezer_fork(struct cgroup_subsys *ss, struct task_struct *task)
206 206
207 /* Locking avoids race with FREEZING -> THAWED transitions. */ 207 /* Locking avoids race with FREEZING -> THAWED transitions. */
208 if (freezer->state == CGROUP_FREEZING) 208 if (freezer->state == CGROUP_FREEZING)
209 freeze_task(task, true); 209 freeze_task(task);
210 spin_unlock_irq(&freezer->lock); 210 spin_unlock_irq(&freezer->lock);
211} 211}
212 212
@@ -274,7 +274,7 @@ static int try_to_freeze_cgroup(struct cgroup *cgroup, struct freezer *freezer)
274 274
275 cgroup_iter_start(cgroup, &it); 275 cgroup_iter_start(cgroup, &it);
276 while ((task = cgroup_iter_next(cgroup, &it))) { 276 while ((task = cgroup_iter_next(cgroup, &it))) {
277 if (!freeze_task(task, true)) 277 if (!freeze_task(task))
278 continue; 278 continue;
279 if (frozen(task)) 279 if (frozen(task))
280 continue; 280 continue;
diff --git a/kernel/freezer.c b/kernel/freezer.c
index 389549f0a94e..2589a61de44c 100644
--- a/kernel/freezer.c
+++ b/kernel/freezer.c
@@ -100,20 +100,17 @@ static void fake_signal_wake_up(struct task_struct *p)
100} 100}
101 101
102/** 102/**
103 * freeze_task - send a freeze request to given task 103 * freeze_task - send a freeze request to given task
104 * @p: task to send the request to 104 * @p: task to send the request to
105 * @sig_only: if set, the request will only be sent if the task has the
106 * PF_FREEZER_NOSIG flag unset
107 * Return value: 'false', if @sig_only is set and the task has
108 * PF_FREEZER_NOSIG set or the task is frozen, 'true', otherwise
109 * 105 *
110 * The freeze request is sent by setting the tasks's TIF_FREEZE flag and 106 * If @p is freezing, the freeze request is sent by setting %TIF_FREEZE
111 * either sending a fake signal to it or waking it up, depending on whether 107 * flag and either sending a fake signal to it or waking it up, depending
112 * or not it has PF_FREEZER_NOSIG set. If @sig_only is set and the task 108 * on whether it has %PF_FREEZER_NOSIG set.
113 * has PF_FREEZER_NOSIG set (ie. it is a typical kernel thread), its 109 *
114 * TIF_FREEZE flag will not be set. 110 * RETURNS:
111 * %false, if @p is not freezing or already frozen; %true, otherwise
115 */ 112 */
116bool freeze_task(struct task_struct *p, bool sig_only) 113bool freeze_task(struct task_struct *p)
117{ 114{
118 unsigned long flags; 115 unsigned long flags;
119 116
diff --git a/kernel/power/process.c b/kernel/power/process.c
index 0beb51e1dec9..77274c9ba2f1 100644
--- a/kernel/power/process.c
+++ b/kernel/power/process.c
@@ -22,7 +22,7 @@
22 */ 22 */
23#define TIMEOUT (20 * HZ) 23#define TIMEOUT (20 * HZ)
24 24
25static int try_to_freeze_tasks(bool sig_only) 25static int try_to_freeze_tasks(bool user_only)
26{ 26{
27 struct task_struct *g, *p; 27 struct task_struct *g, *p;
28 unsigned long end_time; 28 unsigned long end_time;
@@ -37,14 +37,14 @@ static int try_to_freeze_tasks(bool sig_only)
37 37
38 end_time = jiffies + TIMEOUT; 38 end_time = jiffies + TIMEOUT;
39 39
40 if (!sig_only) 40 if (!user_only)
41 freeze_workqueues_begin(); 41 freeze_workqueues_begin();
42 42
43 while (true) { 43 while (true) {
44 todo = 0; 44 todo = 0;
45 read_lock(&tasklist_lock); 45 read_lock(&tasklist_lock);
46 do_each_thread(g, p) { 46 do_each_thread(g, p) {
47 if (p == current || !freeze_task(p, sig_only)) 47 if (p == current || !freeze_task(p))
48 continue; 48 continue;
49 49
50 /* 50 /*
@@ -65,7 +65,7 @@ static int try_to_freeze_tasks(bool sig_only)
65 } while_each_thread(g, p); 65 } while_each_thread(g, p);
66 read_unlock(&tasklist_lock); 66 read_unlock(&tasklist_lock);
67 67
68 if (!sig_only) { 68 if (!user_only) {
69 wq_busy = freeze_workqueues_busy(); 69 wq_busy = freeze_workqueues_busy();
70 todo += wq_busy; 70 todo += wq_busy;
71 } 71 }