aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorKOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>2010-08-09 20:19:33 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2010-08-09 23:45:00 -0400
commit7c59aec830c7ed6c745bd513982cee3563ed20c1 (patch)
treef06d2c626d0ab0ff2f9880d98a50e60be4af7816 /mm
parent1489fa14cb757b496c8fa2b63097dbcee6690695 (diff)
oom: don't try to kill oom_unkillable child
Presently, badness() doesn't care about either CPUSET nor mempolicy. Then if the victim child process have disjoint nodemask, OOM Killer might kill innocent process. This patch fixes it. [akpm@linux-foundation.org: coding-style fixes] Signed-off-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Reviewed-by: Minchan Kim <minchan.kim@gmail.com> Cc: Minchan Kim <minchan.kim@gmail.com> Cc: David Rientjes <rientjes@google.com> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Oleg Nesterov <oleg@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/oom_kill.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/mm/oom_kill.c b/mm/oom_kill.c
index 26ae6975fa32..6e9f16a910e0 100644
--- a/mm/oom_kill.c
+++ b/mm/oom_kill.c
@@ -429,7 +429,7 @@ static int oom_kill_task(struct task_struct *p)
429 429
430static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, 430static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order,
431 unsigned long points, struct mem_cgroup *mem, 431 unsigned long points, struct mem_cgroup *mem,
432 const char *message) 432 nodemask_t *nodemask, const char *message)
433{ 433{
434 struct task_struct *victim = p; 434 struct task_struct *victim = p;
435 struct task_struct *child; 435 struct task_struct *child;
@@ -469,6 +469,8 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order,
469 continue; 469 continue;
470 if (mem && !task_in_mem_cgroup(child, mem)) 470 if (mem && !task_in_mem_cgroup(child, mem))
471 continue; 471 continue;
472 if (!has_intersects_mems_allowed(child, nodemask))
473 continue;
472 474
473 /* badness() returns 0 if the thread is unkillable */ 475 /* badness() returns 0 if the thread is unkillable */
474 child_points = badness(child, uptime.tv_sec); 476 child_points = badness(child, uptime.tv_sec);
@@ -519,7 +521,7 @@ retry:
519 if (!p || PTR_ERR(p) == -1UL) 521 if (!p || PTR_ERR(p) == -1UL)
520 goto out; 522 goto out;
521 523
522 if (oom_kill_process(p, gfp_mask, 0, points, mem, 524 if (oom_kill_process(p, gfp_mask, 0, points, mem, NULL,
523 "Memory cgroup out of memory")) 525 "Memory cgroup out of memory"))
524 goto retry; 526 goto retry;
525out: 527out:
@@ -679,6 +681,7 @@ void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask,
679 * the tasklist scan. 681 * the tasklist scan.
680 */ 682 */
681 if (!oom_kill_process(current, gfp_mask, order, 0, NULL, 683 if (!oom_kill_process(current, gfp_mask, order, 0, NULL,
684 nodemask,
682 "Out of memory (oom_kill_allocating_task)")) 685 "Out of memory (oom_kill_allocating_task)"))
683 return; 686 return;
684 } 687 }
@@ -697,7 +700,7 @@ retry:
697 panic("Out of memory and no killable processes...\n"); 700 panic("Out of memory and no killable processes...\n");
698 } 701 }
699 702
700 if (oom_kill_process(p, gfp_mask, order, points, NULL, 703 if (oom_kill_process(p, gfp_mask, order, points, NULL, nodemask,
701 "Out of memory")) 704 "Out of memory"))
702 goto retry; 705 goto retry;
703 read_unlock(&tasklist_lock); 706 read_unlock(&tasklist_lock);