aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/freezer.h48
-rw-r--r--include/linux/sched.h1
2 files changed, 47 insertions, 2 deletions
diff --git a/include/linux/freezer.h b/include/linux/freezer.h
index db5423eae24d..c9435252e8e4 100644
--- a/include/linux/freezer.h
+++ b/include/linux/freezer.h
@@ -81,7 +81,49 @@ static inline int try_to_freeze(void)
81 return 0; 81 return 0;
82} 82}
83 83
84extern void thaw_some_processes(int all); 84/*
85 * The PF_FREEZER_SKIP flag should be set by a vfork parent right before it
86 * calls wait_for_completion(&vfork) and reset right after it returns from this
87 * function. Next, the parent should call try_to_freeze() to freeze itself
88 * appropriately in case the child has exited before the freezing of tasks is
89 * complete. However, we don't want kernel threads to be frozen in unexpected
90 * places, so we allow them to block freeze_processes() instead or to set
91 * PF_NOFREEZE if needed and PF_FREEZER_SKIP is only set for userland vfork
92 * parents. Fortunately, in the ____call_usermodehelper() case the parent won't
93 * really block freeze_processes(), since ____call_usermodehelper() (the child)
94 * does a little before exec/exit and it can't be frozen before waking up the
95 * parent.
96 */
97
98/*
99 * If the current task is a user space one, tell the freezer not to count it as
100 * freezable.
101 */
102static inline void freezer_do_not_count(void)
103{
104 if (current->mm)
105 current->flags |= PF_FREEZER_SKIP;
106}
107
108/*
109 * If the current task is a user space one, tell the freezer to count it as
110 * freezable again and try to freeze it.
111 */
112static inline void freezer_count(void)
113{
114 if (current->mm) {
115 current->flags &= ~PF_FREEZER_SKIP;
116 try_to_freeze();
117 }
118}
119
120/*
121 * Check if the task should be counted as freezeable by the freezer
122 */
123static inline int freezer_should_skip(struct task_struct *p)
124{
125 return !!(p->flags & PF_FREEZER_SKIP);
126}
85 127
86#else 128#else
87static inline int frozen(struct task_struct *p) { return 0; } 129static inline int frozen(struct task_struct *p) { return 0; }
@@ -96,5 +138,7 @@ static inline void thaw_processes(void) {}
96 138
97static inline int try_to_freeze(void) { return 0; } 139static inline int try_to_freeze(void) { return 0; }
98 140
99 141static inline void freezer_do_not_count(void) {}
142static inline void freezer_count(void) {}
143static inline int freezer_should_skip(struct task_struct *p) { return 0; }
100#endif 144#endif
diff --git a/include/linux/sched.h b/include/linux/sched.h
index a81897e2a244..870b75e348ab 100644
--- a/include/linux/sched.h
+++ b/include/linux/sched.h
@@ -1182,6 +1182,7 @@ static inline void put_task_struct(struct task_struct *t)
1182#define PF_SPREAD_SLAB 0x02000000 /* Spread some slab caches over cpuset */ 1182#define PF_SPREAD_SLAB 0x02000000 /* Spread some slab caches over cpuset */
1183#define PF_MEMPOLICY 0x10000000 /* Non-default NUMA mempolicy */ 1183#define PF_MEMPOLICY 0x10000000 /* Non-default NUMA mempolicy */
1184#define PF_MUTEX_TESTER 0x20000000 /* Thread belongs to the rt mutex tester */ 1184#define PF_MUTEX_TESTER 0x20000000 /* Thread belongs to the rt mutex tester */
1185#define PF_FREEZER_SKIP 0x40000000 /* Freezer should not count it as freezeable */
1185 1186
1186/* 1187/*
1187 * Only the _current_ task can read/write to tsk->flags, but other 1188 * Only the _current_ task can read/write to tsk->flags, but other