Blame view
mm/oom_kill.c
17.8 KB
1da177e4c Linux-2.6.12-rc2 |
1 2 3 4 5 6 7 8 |
/* * linux/mm/oom_kill.c * * Copyright (C) 1998,2000 Rik van Riel * Thanks go out to Claus Fischer for some serious inspiration and * for goading me into coding this file... * * The routines in this file are used to kill a process when |
a49335cce [PATCH] cpusets: ... |
9 10 |
* we're seriously out of memory. This gets called from __alloc_pages() * in mm/page_alloc.c when we really run out of memory. |
1da177e4c Linux-2.6.12-rc2 |
11 12 13 14 15 16 |
* * Since we won't call these routines often (on a well-configured * machine) this file will double as a 'coding guide' and a signpost * for newbie kernel hackers. It features several pointers to major * kernel subsystems and hints as to where to find out what things do. */ |
8ac773b4f [PATCH] OOM kille... |
17 |
#include <linux/oom.h> |
1da177e4c Linux-2.6.12-rc2 |
18 |
#include <linux/mm.h> |
4e950f6f0 Remove fs.h from ... |
19 |
#include <linux/err.h> |
1da177e4c Linux-2.6.12-rc2 |
20 21 22 23 |
#include <linux/sched.h> #include <linux/swap.h> #include <linux/timex.h> #include <linux/jiffies.h> |
ef08e3b49 [PATCH] cpusets: ... |
24 |
#include <linux/cpuset.h> |
8bc719d3c [PATCH] out of me... |
25 26 |
#include <linux/module.h> #include <linux/notifier.h> |
c7ba5c9e8 Memory controller... |
27 |
#include <linux/memcontrol.h> |
5cd9c58fb security: Fix set... |
28 |
#include <linux/security.h> |
1da177e4c Linux-2.6.12-rc2 |
29 |
|
fadd8fbd1 [PATCH] support f... |
30 |
int sysctl_panic_on_oom; |
fe071d7e8 oom: add oom_kill... |
31 |
int sysctl_oom_kill_allocating_task; |
fef1bdd68 oom: add sysctl t... |
32 |
int sysctl_oom_dump_tasks; |
c7d4caeb1 oom: fix zone_sca... |
33 |
static DEFINE_SPINLOCK(zone_scan_lock); |
1da177e4c Linux-2.6.12-rc2 |
34 |
/* #define DEBUG */ |
495789a51 oom: make oom_sco... |
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 |
/* * Is all threads of the target process nodes overlap ours? */ static int has_intersects_mems_allowed(struct task_struct *tsk) { struct task_struct *t; t = tsk; do { if (cpuset_mems_allowed_intersects(current, t)) return 1; t = next_thread(t); } while (t != tsk); return 0; } |
1da177e4c Linux-2.6.12-rc2 |
51 |
/** |
6937a25cf [PATCH] mm: fix t... |
52 |
* badness - calculate a numeric value for how bad this task has been |
1da177e4c Linux-2.6.12-rc2 |
53 |
* @p: task struct of which task we should calculate |
a49335cce [PATCH] cpusets: ... |
54 |
* @uptime: current uptime in seconds |
1da177e4c Linux-2.6.12-rc2 |
55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
* * The formula used is relatively simple and documented inline in the * function. The main rationale is that we want to select a good task * to kill when we run out of memory. * * Good in this context means that: * 1) we lose the minimum amount of work done * 2) we recover a large amount of memory * 3) we don't kill anything innocent of eating tons of memory * 4) we want to kill the minimum amount of processes (one) * 5) we try to kill the process the user expects us to kill, this * algorithm has been meticulously tuned to meet the principle * of least surprise ... (be careful when you change it) */ |
97d87c971 oom_kill: remove ... |
69 |
unsigned long badness(struct task_struct *p, unsigned long uptime) |
1da177e4c Linux-2.6.12-rc2 |
70 |
{ |
a12888f77 oom_kill: don't c... |
71 |
unsigned long points, cpu_time, run_time; |
97c2c9b84 [PATCH] oom-kill:... |
72 73 |
struct mm_struct *mm; struct task_struct *child; |
28b83c519 oom: move oom_adj... |
74 |
int oom_adj = p->signal->oom_adj; |
495789a51 oom: make oom_sco... |
75 76 77 |
struct task_cputime task_time; unsigned long utime; unsigned long stime; |
28b83c519 oom: move oom_adj... |
78 79 80 |
if (oom_adj == OOM_DISABLE) return 0; |
1da177e4c Linux-2.6.12-rc2 |
81 |
|
97c2c9b84 [PATCH] oom-kill:... |
82 83 84 85 |
task_lock(p); mm = p->mm; if (!mm) { task_unlock(p); |
1da177e4c Linux-2.6.12-rc2 |
86 |
return 0; |
97c2c9b84 [PATCH] oom-kill:... |
87 |
} |
1da177e4c Linux-2.6.12-rc2 |
88 89 90 91 |
/* * The memory size of the process is the basis for the badness. */ |
97c2c9b84 [PATCH] oom-kill:... |
92 93 94 95 96 97 |
points = mm->total_vm; /* * After this unlock we can no longer dereference local variable `mm' */ task_unlock(p); |
1da177e4c Linux-2.6.12-rc2 |
98 99 |
/* |
7ba348594 [PATCH] fix OOM k... |
100 101 |
* swapoff can easily use up all memory, so kill those first. */ |
35451beec ksm: unmerge is a... |
102 |
if (p->flags & PF_OOM_ORIGIN) |
7ba348594 [PATCH] fix OOM k... |
103 104 105 |
return ULONG_MAX; /* |
1da177e4c Linux-2.6.12-rc2 |
106 |
* Processes which fork a lot of child processes are likely |
9827b781f [PATCH] OOM kill:... |
107 |
* a good choice. We add half the vmsize of the children if they |
1da177e4c Linux-2.6.12-rc2 |
108 |
* have an own mm. This prevents forking servers to flood the |
9827b781f [PATCH] OOM kill:... |
109 110 111 |
* machine with an endless amount of children. In case a single * child is eating the vast majority of memory, adding only half * to the parents will make the child our kill candidate of choice. |
1da177e4c Linux-2.6.12-rc2 |
112 |
*/ |
97c2c9b84 [PATCH] oom-kill:... |
113 114 115 116 117 |
list_for_each_entry(child, &p->children, sibling) { task_lock(child); if (child->mm != mm && child->mm) points += child->mm->total_vm/2 + 1; task_unlock(child); |
1da177e4c Linux-2.6.12-rc2 |
118 119 120 121 122 123 124 |
} /* * CPU time is in tens of seconds and run time is in thousands * of seconds. There is no particular reason for this other than * that it turned out to work very well in practice. */ |
495789a51 oom: make oom_sco... |
125 126 127 128 |
thread_group_cputime(p, &task_time); utime = cputime_to_jiffies(task_time.utime); stime = cputime_to_jiffies(task_time.stime); cpu_time = (utime + stime) >> (SHIFT_HZ + 3); |
1da177e4c Linux-2.6.12-rc2 |
129 130 131 132 133 |
if (uptime >= p->start_time.tv_sec) run_time = (uptime - p->start_time.tv_sec) >> 10; else run_time = 0; |
a12888f77 oom_kill: don't c... |
134 135 136 137 |
if (cpu_time) points /= int_sqrt(cpu_time); if (run_time) points /= int_sqrt(int_sqrt(run_time)); |
1da177e4c Linux-2.6.12-rc2 |
138 139 140 141 142 143 144 145 146 147 148 149 |
/* * Niced processes are most likely less important, so double * their badness points. */ if (task_nice(p) > 0) points *= 2; /* * Superuser processes are usually more important, so we make it * less likely that we kill those. */ |
a2f2945a9 The oomkiller cal... |
150 151 |
if (has_capability_noaudit(p, CAP_SYS_ADMIN) || has_capability_noaudit(p, CAP_SYS_RESOURCE)) |
1da177e4c Linux-2.6.12-rc2 |
152 153 154 155 156 157 158 159 |
points /= 4; /* * We don't want to kill a process with direct hardware access. * Not only could that mess up the hardware, but usually users * tend to only have this flag set on applications they think * of as important. */ |
a2f2945a9 The oomkiller cal... |
160 |
if (has_capability_noaudit(p, CAP_SYS_RAWIO)) |
1da177e4c Linux-2.6.12-rc2 |
161 162 163 |
points /= 4; /* |
7887a3da7 [PATCH] oom: cpus... |
164 165 166 167 |
* If p's nodes don't overlap ours, it may still help to kill p * because p may have allocated or otherwise mapped memory on * this node before. However it will be less likely. */ |
495789a51 oom: make oom_sco... |
168 |
if (!has_intersects_mems_allowed(p)) |
7887a3da7 [PATCH] oom: cpus... |
169 170 171 |
points /= 8; /* |
28b83c519 oom: move oom_adj... |
172 |
* Adjust the score by oom_adj. |
1da177e4c Linux-2.6.12-rc2 |
173 |
*/ |
28b83c519 oom: move oom_adj... |
174 175 |
if (oom_adj) { if (oom_adj > 0) { |
9a82782f8 allow oom_adj of ... |
176 177 |
if (!points) points = 1; |
28b83c519 oom: move oom_adj... |
178 |
points <<= oom_adj; |
9a82782f8 allow oom_adj of ... |
179 |
} else |
28b83c519 oom: move oom_adj... |
180 |
points >>= -(oom_adj); |
1da177e4c Linux-2.6.12-rc2 |
181 182 183 |
} #ifdef DEBUG |
a5e58a614 oom: print points... |
184 185 |
printk(KERN_DEBUG "OOMkill: task %d (%s) got %lu points ", |
1da177e4c Linux-2.6.12-rc2 |
186 187 188 189 190 191 |
p->pid, p->comm, points); #endif return points; } /* |
9b0f8b040 [PATCH] Terminate... |
192 193 |
* Determine the type of allocation constraint. */ |
9b0f8b040 [PATCH] Terminate... |
194 |
#ifdef CONFIG_NUMA |
4365a5676 oom-kill: fix NUM... |
195 196 197 |
static enum oom_constraint constrained_alloc(struct zonelist *zonelist, gfp_t gfp_mask, nodemask_t *nodemask) { |
54a6eb5c4 mm: use two zonel... |
198 |
struct zone *zone; |
dd1a239f6 mm: have zonelist... |
199 |
struct zoneref *z; |
54a6eb5c4 mm: use two zonel... |
200 |
enum zone_type high_zoneidx = gfp_zone(gfp_mask); |
9b0f8b040 [PATCH] Terminate... |
201 |
|
4365a5676 oom-kill: fix NUM... |
202 203 204 205 206 207 208 |
/* * Reach here only when __GFP_NOFAIL is used. So, we should avoid * to kill current.We have to random task kill in this case. * Hopefully, CONSTRAINT_THISNODE...but no way to handle it, now. */ if (gfp_mask & __GFP_THISNODE) return CONSTRAINT_NONE; |
9b0f8b040 [PATCH] Terminate... |
209 |
|
4365a5676 oom-kill: fix NUM... |
210 211 212 213 214 215 216 |
/* * The nodemask here is a nodemask passed to alloc_pages(). Now, * cpuset doesn't use this nodemask for its hardwall/softwall/hierarchy * feature. mempolicy is an only user of nodemask here. * check mempolicy's nodemask contains all N_HIGH_MEMORY */ if (nodemask && !nodes_subset(node_states[N_HIGH_MEMORY], *nodemask)) |
9b0f8b040 [PATCH] Terminate... |
217 |
return CONSTRAINT_MEMORY_POLICY; |
4365a5676 oom-kill: fix NUM... |
218 219 220 221 222 223 |
/* Check this allocation failure is caused by cpuset's wall function */ for_each_zone_zonelist_nodemask(zone, z, zonelist, high_zoneidx, nodemask) if (!cpuset_zone_allowed_softwall(zone, gfp_mask)) return CONSTRAINT_CPUSET; |
9b0f8b040 [PATCH] Terminate... |
224 225 226 |
return CONSTRAINT_NONE; } |
4365a5676 oom-kill: fix NUM... |
227 228 229 230 231 232 233 |
#else static enum oom_constraint constrained_alloc(struct zonelist *zonelist, gfp_t gfp_mask, nodemask_t *nodemask) { return CONSTRAINT_NONE; } #endif |
9b0f8b040 [PATCH] Terminate... |
234 235 |
/* |
1da177e4c Linux-2.6.12-rc2 |
236 237 238 239 240 |
* Simple selection loop. We chose the process with the highest * number of 'points'. We expect the caller will lock the tasklist. * * (not docbooked, we don't want this one cluttering up the manual) */ |
c7ba5c9e8 Memory controller... |
241 242 |
static struct task_struct *select_bad_process(unsigned long *ppoints, struct mem_cgroup *mem) |
1da177e4c Linux-2.6.12-rc2 |
243 |
{ |
495789a51 oom: make oom_sco... |
244 |
struct task_struct *p; |
1da177e4c Linux-2.6.12-rc2 |
245 246 |
struct task_struct *chosen = NULL; struct timespec uptime; |
9827b781f [PATCH] OOM kill:... |
247 |
*ppoints = 0; |
1da177e4c Linux-2.6.12-rc2 |
248 249 |
do_posix_clock_monotonic_gettime(&uptime); |
495789a51 oom: make oom_sco... |
250 |
for_each_process(p) { |
a49335cce [PATCH] cpusets: ... |
251 |
unsigned long points; |
a49335cce [PATCH] cpusets: ... |
252 |
|
28324d1df [PATCH] select_ba... |
253 254 255 256 |
/* * skip kernel threads and tasks which have already released * their mm. */ |
5081dde33 [PATCH] oom: kthr... |
257 258 |
if (!p->mm) continue; |
28324d1df [PATCH] select_ba... |
259 |
/* skip the init task */ |
b460cbc58 pid namespaces: d... |
260 |
if (is_global_init(p)) |
a49335cce [PATCH] cpusets: ... |
261 |
continue; |
4c4a22148 memcontrol: move ... |
262 263 |
if (mem && !task_in_mem_cgroup(p, mem)) continue; |
ef08e3b49 [PATCH] cpusets: ... |
264 |
|
a49335cce [PATCH] cpusets: ... |
265 |
/* |
b78483a4b [PATCH] oom: don'... |
266 267 268 269 270 271 272 273 274 275 276 277 |
* This task already has access to memory reserves and is * being killed. Don't allow any other task access to the * memory reserve. * * Note: this may have a chance of deadlock if it gets * blocked waiting for another task which itself is waiting * for memory. Is there a better alternative? */ if (test_tsk_thread_flag(p, TIF_MEMDIE)) return ERR_PTR(-1UL); /* |
6937a25cf [PATCH] mm: fix t... |
278 |
* This is in the process of releasing memory so wait for it |
a49335cce [PATCH] cpusets: ... |
279 |
* to finish before killing some other task by mistake. |
50ec3bbff [PATCH] oom: hand... |
280 281 282 283 284 |
* * However, if p is the current task, we allow the 'kill' to * go ahead if it is exiting: this will simply set TIF_MEMDIE, * which will allow it to gain access to memory reserves in * the process of exiting and releasing its resources. |
b78483a4b [PATCH] oom: don'... |
285 |
* Otherwise we could get an easy OOM deadlock. |
a49335cce [PATCH] cpusets: ... |
286 |
*/ |
b78483a4b [PATCH] oom: don'... |
287 288 289 |
if (p->flags & PF_EXITING) { if (p != current) return ERR_PTR(-1UL); |
972c4ea59 [PATCH] select_ba... |
290 291 |
chosen = p; *ppoints = ULONG_MAX; |
50ec3bbff [PATCH] oom: hand... |
292 |
} |
972c4ea59 [PATCH] select_ba... |
293 |
|
28b83c519 oom: move oom_adj... |
294 |
if (p->signal->oom_adj == OOM_DISABLE) |
0753ba01e mm: revert "oom: ... |
295 |
continue; |
97d87c971 oom_kill: remove ... |
296 |
points = badness(p, uptime.tv_sec); |
0753ba01e mm: revert "oom: ... |
297 |
if (points > *ppoints || !chosen) { |
a49335cce [PATCH] cpusets: ... |
298 |
chosen = p; |
9827b781f [PATCH] OOM kill:... |
299 |
*ppoints = points; |
1da177e4c Linux-2.6.12-rc2 |
300 |
} |
495789a51 oom: make oom_sco... |
301 |
} |
972c4ea59 [PATCH] select_ba... |
302 |
|
1da177e4c Linux-2.6.12-rc2 |
303 304 305 306 |
return chosen; } /** |
1b578df02 mm/oom_kill: fix ... |
307 308 309 |
* dump_tasks - dump current memory state of all system tasks * @mem: target memory controller * |
fef1bdd68 oom: add sysctl t... |
310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 |
* Dumps the current memory state of all system tasks, excluding kernel threads. * State information includes task's pid, uid, tgid, vm size, rss, cpu, oom_adj * score, and name. * * If the actual is non-NULL, only tasks that are a member of the mem_cgroup are * shown. * * Call with tasklist_lock read-locked. */ static void dump_tasks(const struct mem_cgroup *mem) { struct task_struct *g, *p; printk(KERN_INFO "[ pid ] uid tgid total_vm rss cpu oom_adj " "name "); do_each_thread(g, p) { |
6d2661ede oom: fix possible... |
327 |
struct mm_struct *mm; |
fef1bdd68 oom: add sysctl t... |
328 329 |
if (mem && !task_in_mem_cgroup(p, mem)) continue; |
b4416d2be oom: do not dump ... |
330 331 |
if (!thread_group_leader(p)) continue; |
fef1bdd68 oom: add sysctl t... |
332 333 |
task_lock(p); |
6d2661ede oom: fix possible... |
334 335 336 337 338 339 340 341 342 343 |
mm = p->mm; if (!mm) { /* * total_vm and rss sizes do not exist for tasks with no * mm so there's no need to report them; they can't be * oom killed anyway. */ task_unlock(p); continue; } |
fef1bdd68 oom: add sysctl t... |
344 345 |
printk(KERN_INFO "[%5d] %5d %5d %8lu %8lu %3d %3d %s ", |
6d2661ede oom: fix possible... |
346 |
p->pid, __task_cred(p)->uid, p->tgid, mm->total_vm, |
28b83c519 oom: move oom_adj... |
347 |
get_mm_rss(mm), (int)task_cpu(p), p->signal->oom_adj, |
0753ba01e mm: revert "oom: ... |
348 |
p->comm); |
fef1bdd68 oom: add sysctl t... |
349 350 351 |
task_unlock(p); } while_each_thread(g, p); } |
d31f56dbf memcg: avoid oom-... |
352 353 |
static void dump_header(struct task_struct *p, gfp_t gfp_mask, int order, struct mem_cgroup *mem) |
1b604d75b oom: dump stack a... |
354 355 356 357 358 359 360 361 362 |
{ pr_warning("%s invoked oom-killer: gfp_mask=0x%x, order=%d, " "oom_adj=%d ", current->comm, gfp_mask, order, current->signal->oom_adj); task_lock(current); cpuset_print_task_mems_allowed(current); task_unlock(current); dump_stack(); |
d31f56dbf memcg: avoid oom-... |
363 |
mem_cgroup_print_oom_info(mem, p); |
1b604d75b oom: dump stack a... |
364 365 366 367 |
show_mem(); if (sysctl_oom_dump_tasks) dump_tasks(mem); } |
3b4798cbc oom-kill: show vi... |
368 |
#define K(x) ((x) << (PAGE_SHIFT-10)) |
1b578df02 mm/oom_kill: fix ... |
369 |
/* |
5a291b98b [PATCH] oom-kill:... |
370 371 372 |
* Send SIGKILL to the selected process irrespective of CAP_SYS_RAW_IO * flag though it's unlikely that we select a process with CAP_SYS_RAW_IO * set. |
1da177e4c Linux-2.6.12-rc2 |
373 |
*/ |
f3af38d30 [PATCH] oom: clea... |
374 |
static void __oom_kill_task(struct task_struct *p, int verbose) |
1da177e4c Linux-2.6.12-rc2 |
375 |
{ |
b460cbc58 pid namespaces: d... |
376 |
if (is_global_init(p)) { |
1da177e4c Linux-2.6.12-rc2 |
377 378 379 380 381 |
WARN_ON(1); printk(KERN_WARNING "tried to kill init! "); return; } |
3b4798cbc oom-kill: show vi... |
382 |
task_lock(p); |
0753ba01e mm: revert "oom: ... |
383 384 |
if (!p->mm) { WARN_ON(1); |
3b4798cbc oom-kill: show vi... |
385 386 387 388 |
printk(KERN_WARNING "tried to kill an mm-less task %d (%s)! ", task_pid_nr(p), p->comm); task_unlock(p); |
1da177e4c Linux-2.6.12-rc2 |
389 |
return; |
0753ba01e mm: revert "oom: ... |
390 |
} |
50ec3bbff [PATCH] oom: hand... |
391 |
|
f3af38d30 [PATCH] oom: clea... |
392 |
if (verbose) |
3b4798cbc oom-kill: show vi... |
393 394 395 396 397 |
printk(KERN_ERR "Killed process %d (%s) " "vsz:%lukB, anon-rss:%lukB, file-rss:%lukB ", task_pid_nr(p), p->comm, K(p->mm->total_vm), |
d559db086 mm: clean up mm_c... |
398 399 |
K(get_mm_counter(p->mm, MM_ANONPAGES)), K(get_mm_counter(p->mm, MM_FILEPAGES))); |
3b4798cbc oom-kill: show vi... |
400 |
task_unlock(p); |
1da177e4c Linux-2.6.12-rc2 |
401 402 403 404 405 406 |
/* * We give our sacrificial lamb high priority and access to * all the memory it needs. That way it should be able to * exit() and clear out its resources quickly... */ |
fa717060f sched: sched_rt_e... |
407 |
p->rt.time_slice = HZ; |
1da177e4c Linux-2.6.12-rc2 |
408 409 410 411 |
set_tsk_thread_flag(p, TIF_MEMDIE); force_sig(SIGKILL, p); } |
f3af38d30 [PATCH] oom: clea... |
412 |
static int oom_kill_task(struct task_struct *p) |
1da177e4c Linux-2.6.12-rc2 |
413 |
{ |
0753ba01e mm: revert "oom: ... |
414 415 416 417 418 419 420 421 |
/* WARNING: mm may not be dereferenced since we did not obtain its * value from get_task_mm(p). This is OK since all we need to do is * compare mm to q->mm below. * * Furthermore, even if mm contains a non-NULL value, p->mm may * change to NULL at any time since we do not hold task_lock(p). * However, this is of no concern to us. */ |
8c5cd6f3a oom: oom_kill doe... |
422 |
if (!p->mm || p->signal->oom_adj == OOM_DISABLE) |
013159227 [PATCH] mm: fix m... |
423 |
return 1; |
0753ba01e mm: revert "oom: ... |
424 |
|
f3af38d30 [PATCH] oom: clea... |
425 |
__oom_kill_task(p, 1); |
c33e0fca3 [PATCH] oom: don'... |
426 |
|
013159227 [PATCH] mm: fix m... |
427 |
return 0; |
1da177e4c Linux-2.6.12-rc2 |
428 |
} |
7213f5066 oom: suppress ext... |
429 |
static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, |
fef1bdd68 oom: add sysctl t... |
430 431 |
unsigned long points, struct mem_cgroup *mem, const char *message) |
1da177e4c Linux-2.6.12-rc2 |
432 |
{ |
1da177e4c Linux-2.6.12-rc2 |
433 |
struct task_struct *c; |
1da177e4c Linux-2.6.12-rc2 |
434 |
|
1b604d75b oom: dump stack a... |
435 |
if (printk_ratelimit()) |
d31f56dbf memcg: avoid oom-... |
436 |
dump_header(p, gfp_mask, order, mem); |
7213f5066 oom: suppress ext... |
437 |
|
50ec3bbff [PATCH] oom: hand... |
438 439 440 441 |
/* * If the task is already exiting, don't alarm the sysadmin or kill * its children or threads, just set TIF_MEMDIE so it can die quickly */ |
0753ba01e mm: revert "oom: ... |
442 |
if (p->flags & PF_EXITING) { |
f3af38d30 [PATCH] oom: clea... |
443 |
__oom_kill_task(p, 0); |
50ec3bbff [PATCH] oom: hand... |
444 445 |
return 0; } |
f3af38d30 [PATCH] oom: clea... |
446 447 |
printk(KERN_ERR "%s: kill process %d (%s) score %li or a child ", |
ba25f9dcc Use helpers to ob... |
448 |
message, task_pid_nr(p), p->comm, points); |
f3af38d30 [PATCH] oom: clea... |
449 |
|
1da177e4c Linux-2.6.12-rc2 |
450 |
/* Try to kill a child first */ |
7b1915a98 mm/oom_kill.c: Us... |
451 |
list_for_each_entry(c, &p->children, sibling) { |
1da177e4c Linux-2.6.12-rc2 |
452 453 |
if (c->mm == p->mm) continue; |
5a2d41961 memcg: fix oom ki... |
454 455 |
if (mem && !task_in_mem_cgroup(c, mem)) continue; |
f3af38d30 [PATCH] oom: clea... |
456 |
if (!oom_kill_task(c)) |
013159227 [PATCH] mm: fix m... |
457 |
return 0; |
1da177e4c Linux-2.6.12-rc2 |
458 |
} |
f3af38d30 [PATCH] oom: clea... |
459 |
return oom_kill_task(p); |
1da177e4c Linux-2.6.12-rc2 |
460 |
} |
00f0b8259 Memory controller... |
461 |
#ifdef CONFIG_CGROUP_MEM_RES_CTLR |
c7ba5c9e8 Memory controller... |
462 463 464 465 |
void mem_cgroup_out_of_memory(struct mem_cgroup *mem, gfp_t gfp_mask) { unsigned long points = 0; struct task_struct *p; |
e115f2d89 memcg: fix oops i... |
466 |
read_lock(&tasklist_lock); |
c7ba5c9e8 Memory controller... |
467 468 469 470 471 472 473 |
retry: p = select_bad_process(&points, mem); if (PTR_ERR(p) == -1UL) goto out; if (!p) p = current; |
fef1bdd68 oom: add sysctl t... |
474 |
if (oom_kill_process(p, gfp_mask, 0, points, mem, |
c7ba5c9e8 Memory controller... |
475 476 477 |
"Memory cgroup out of memory")) goto retry; out: |
e115f2d89 memcg: fix oops i... |
478 |
read_unlock(&tasklist_lock); |
c7ba5c9e8 Memory controller... |
479 480 |
} #endif |
8bc719d3c [PATCH] out of me... |
481 482 483 484 485 486 487 488 489 490 491 492 493 |
static BLOCKING_NOTIFIER_HEAD(oom_notify_list); int register_oom_notifier(struct notifier_block *nb) { return blocking_notifier_chain_register(&oom_notify_list, nb); } EXPORT_SYMBOL_GPL(register_oom_notifier); int unregister_oom_notifier(struct notifier_block *nb) { return blocking_notifier_chain_unregister(&oom_notify_list, nb); } EXPORT_SYMBOL_GPL(unregister_oom_notifier); |
098d7f128 oom: add per-zone... |
494 495 496 497 498 |
/* * Try to acquire the OOM killer lock for the zones in zonelist. Returns zero * if a parallel OOM killing is already taking place that includes a zone in * the zonelist. Otherwise, locks all zones in the zonelist and returns 1. */ |
dd1a239f6 mm: have zonelist... |
499 |
int try_set_zone_oom(struct zonelist *zonelist, gfp_t gfp_mask) |
098d7f128 oom: add per-zone... |
500 |
{ |
dd1a239f6 mm: have zonelist... |
501 502 |
struct zoneref *z; struct zone *zone; |
098d7f128 oom: add per-zone... |
503 |
int ret = 1; |
c7d4caeb1 oom: fix zone_sca... |
504 |
spin_lock(&zone_scan_lock); |
dd1a239f6 mm: have zonelist... |
505 506 |
for_each_zone_zonelist(zone, z, zonelist, gfp_zone(gfp_mask)) { if (zone_is_oom_locked(zone)) { |
098d7f128 oom: add per-zone... |
507 508 509 |
ret = 0; goto out; } |
dd1a239f6 mm: have zonelist... |
510 511 512 513 |
} for_each_zone_zonelist(zone, z, zonelist, gfp_zone(gfp_mask)) { /* |
c7d4caeb1 oom: fix zone_sca... |
514 |
* Lock each zone in the zonelist under zone_scan_lock so a |
dd1a239f6 mm: have zonelist... |
515 516 517 518 519 |
* parallel invocation of try_set_zone_oom() doesn't succeed * when it shouldn't. */ zone_set_flag(zone, ZONE_OOM_LOCKED); } |
098d7f128 oom: add per-zone... |
520 |
|
098d7f128 oom: add per-zone... |
521 |
out: |
c7d4caeb1 oom: fix zone_sca... |
522 |
spin_unlock(&zone_scan_lock); |
098d7f128 oom: add per-zone... |
523 524 525 526 527 528 529 530 |
return ret; } /* * Clears the ZONE_OOM_LOCKED flag for all zones in the zonelist so that failed * allocation attempts with zonelists containing them may now recall the OOM * killer, if necessary. */ |
dd1a239f6 mm: have zonelist... |
531 |
void clear_zonelist_oom(struct zonelist *zonelist, gfp_t gfp_mask) |
098d7f128 oom: add per-zone... |
532 |
{ |
dd1a239f6 mm: have zonelist... |
533 534 |
struct zoneref *z; struct zone *zone; |
098d7f128 oom: add per-zone... |
535 |
|
c7d4caeb1 oom: fix zone_sca... |
536 |
spin_lock(&zone_scan_lock); |
dd1a239f6 mm: have zonelist... |
537 538 539 |
for_each_zone_zonelist(zone, z, zonelist, gfp_zone(gfp_mask)) { zone_clear_flag(zone, ZONE_OOM_LOCKED); } |
c7d4caeb1 oom: fix zone_sca... |
540 |
spin_unlock(&zone_scan_lock); |
098d7f128 oom: add per-zone... |
541 |
} |
1c0fe6e3b mm: invoke oom-ki... |
542 543 544 545 546 |
/* * Must be called with tasklist_lock held for read. */ static void __out_of_memory(gfp_t gfp_mask, int order) { |
184101bf1 oom: prevent live... |
547 548 |
struct task_struct *p; unsigned long points; |
1c0fe6e3b mm: invoke oom-ki... |
549 |
|
184101bf1 oom: prevent live... |
550 551 552 |
if (sysctl_oom_kill_allocating_task) if (!oom_kill_process(current, gfp_mask, order, 0, NULL, "Out of memory (oom_kill_allocating_task)")) |
1c0fe6e3b mm: invoke oom-ki... |
553 |
return; |
184101bf1 oom: prevent live... |
554 555 556 557 558 559 |
retry: /* * Rambo mode: Shoot down a process and hope it solves whatever * issues we may have. */ p = select_bad_process(&points, NULL); |
1c0fe6e3b mm: invoke oom-ki... |
560 |
|
184101bf1 oom: prevent live... |
561 562 |
if (PTR_ERR(p) == -1UL) return; |
1c0fe6e3b mm: invoke oom-ki... |
563 |
|
184101bf1 oom: prevent live... |
564 565 566 |
/* Found nothing?!?! Either we hang forever, or we panic. */ if (!p) { read_unlock(&tasklist_lock); |
d31f56dbf memcg: avoid oom-... |
567 |
dump_header(NULL, gfp_mask, order, NULL); |
184101bf1 oom: prevent live... |
568 569 |
panic("Out of memory and no killable processes... "); |
1c0fe6e3b mm: invoke oom-ki... |
570 |
} |
184101bf1 oom: prevent live... |
571 572 573 574 |
if (oom_kill_process(p, gfp_mask, order, points, NULL, "Out of memory")) goto retry; |
1c0fe6e3b mm: invoke oom-ki... |
575 576 577 578 579 580 581 582 583 584 585 586 587 588 |
} /* * pagefault handler calls into here because it is out of memory but * doesn't know exactly how or why. */ void pagefault_out_of_memory(void) { unsigned long freed = 0; blocking_notifier_call_chain(&oom_notify_list, 0, &freed); if (freed > 0) /* Got some memory back in the last second. */ return; |
a636b327f memcg: avoid unne... |
589 590 591 592 593 594 |
/* * If this is from memcg, oom-killer is already invoked. * and not worth to go system-wide-oom. */ if (mem_cgroup_oom_called(current)) goto rest_and_return; |
1c0fe6e3b mm: invoke oom-ki... |
595 596 597 598 599 600 601 602 603 604 605 606 |
if (sysctl_panic_on_oom) panic("out of memory from page fault. panic_on_oom is selected. "); read_lock(&tasklist_lock); __out_of_memory(0, 0); /* unknown gfp_mask and order */ read_unlock(&tasklist_lock); /* * Give "p" a good chance of killing itself before we * retry to allocate memory. */ |
a636b327f memcg: avoid unne... |
607 |
rest_and_return: |
1c0fe6e3b mm: invoke oom-ki... |
608 609 610 |
if (!test_thread_flag(TIF_MEMDIE)) schedule_timeout_uninterruptible(1); } |
1da177e4c Linux-2.6.12-rc2 |
611 |
/** |
6937a25cf [PATCH] mm: fix t... |
612 |
* out_of_memory - kill the "best" process when we run out of memory |
1b578df02 mm/oom_kill: fix ... |
613 614 615 |
* @zonelist: zonelist pointer * @gfp_mask: memory allocation flags * @order: amount of memory being requested as a power of 2 |
1da177e4c Linux-2.6.12-rc2 |
616 617 618 619 620 621 |
* * If we run out of memory, we have the choice between either * killing a random task (bad), letting the system crash (worse) * OR try to be smart about which process to kill. Note that we * don't have to be perfect here, we just have to be good. */ |
4365a5676 oom-kill: fix NUM... |
622 623 |
void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask, int order, nodemask_t *nodemask) |
1da177e4c Linux-2.6.12-rc2 |
624 |
{ |
8bc719d3c [PATCH] out of me... |
625 |
unsigned long freed = 0; |
70e24bdf6 oom: move constra... |
626 |
enum oom_constraint constraint; |
8bc719d3c [PATCH] out of me... |
627 628 629 630 631 |
blocking_notifier_call_chain(&oom_notify_list, 0, &freed); if (freed > 0) /* Got some memory back in the last second. */ return; |
1da177e4c Linux-2.6.12-rc2 |
632 |
|
1b604d75b oom: dump stack a... |
633 |
if (sysctl_panic_on_oom == 2) { |
d31f56dbf memcg: avoid oom-... |
634 |
dump_header(NULL, gfp_mask, order, NULL); |
2b744c01a mm: fix handling ... |
635 636 |
panic("out of memory. Compulsory panic_on_oom is selected. "); |
1b604d75b oom: dump stack a... |
637 |
} |
2b744c01a mm: fix handling ... |
638 |
|
9b0f8b040 [PATCH] Terminate... |
639 640 641 642 |
/* * Check if there were limitations on the allocation (only relevant for * NUMA) that may require different handling. */ |
4365a5676 oom-kill: fix NUM... |
643 |
constraint = constrained_alloc(zonelist, gfp_mask, nodemask); |
2b45ab339 oom: fix constrai... |
644 645 646 |
read_lock(&tasklist_lock); switch (constraint) { |
9b0f8b040 [PATCH] Terminate... |
647 |
case CONSTRAINT_MEMORY_POLICY: |
1c0fe6e3b mm: invoke oom-ki... |
648 |
oom_kill_process(current, gfp_mask, order, 0, NULL, |
9b0f8b040 [PATCH] Terminate... |
649 650 |
"No available memory (MPOL_BIND)"); break; |
9b0f8b040 [PATCH] Terminate... |
651 |
case CONSTRAINT_NONE: |
1b604d75b oom: dump stack a... |
652 |
if (sysctl_panic_on_oom) { |
d31f56dbf memcg: avoid oom-... |
653 |
dump_header(NULL, gfp_mask, order, NULL); |
fadd8fbd1 [PATCH] support f... |
654 655 |
panic("out of memory. panic_on_oom is selected "); |
1b604d75b oom: dump stack a... |
656 |
} |
fe071d7e8 oom: add oom_kill... |
657 658 |
/* Fall-through */ case CONSTRAINT_CPUSET: |
1c0fe6e3b mm: invoke oom-ki... |
659 |
__out_of_memory(gfp_mask, order); |
9b0f8b040 [PATCH] Terminate... |
660 661 |
break; } |
1da177e4c Linux-2.6.12-rc2 |
662 |
|
140ffcec4 [PATCH] out_of_me... |
663 |
read_unlock(&tasklist_lock); |
1da177e4c Linux-2.6.12-rc2 |
664 665 666 |
/* * Give "p" a good chance of killing itself before we |
2f659f462 [PATCH] Optimise ... |
667 |
* retry to allocate memory unless "p" is current |
1da177e4c Linux-2.6.12-rc2 |
668 |
*/ |
2f659f462 [PATCH] Optimise ... |
669 |
if (!test_thread_flag(TIF_MEMDIE)) |
140ffcec4 [PATCH] out_of_me... |
670 |
schedule_timeout_uninterruptible(1); |
1da177e4c Linux-2.6.12-rc2 |
671 |
} |