Prev: [PATCH 6/9] oom: use same_thread_group instead comparing ->mm
Next: [GIT PULL] OMAP DSS fixes for 2.6.35-rc4
From: KOSAKI Motohiro on 16 Jun 2010 07:40 When oom_kill_allocating_task is enabled, an argument of oom_kill_process is not selected by select_bad_process(), but just out_of_memory() caller task. It mean the task can be unkillable. check it first. Signed-off-by: KOSAKI Motohiro <kosaki.motohiro(a)jp.fujitsu.com> --- mm/oom_kill.c | 11 +++++++++++ 1 files changed, 11 insertions(+), 0 deletions(-) diff --git a/mm/oom_kill.c b/mm/oom_kill.c index 6ca6cb8..3e48023 100644 --- a/mm/oom_kill.c +++ b/mm/oom_kill.c @@ -436,6 +436,17 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, unsigned long victim_points = 0; struct timespec uptime; + /* + * When oom_kill_allocating_task is enabled, p can be + * unkillable. check it first. + */ + if (is_global_init(p) || (p->flags & PF_KTHREAD)) + return 1; + if (mem && !task_in_mem_cgroup(p, mem)) + return 1; + if (!has_intersects_mems_allowed(p, nodemask)) + return 1; + if (printk_ratelimit()) dump_header(p, gfp_mask, order, mem); -- 1.6.5.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |