diff options
author | David Rientjes <rientjes@google.com> | 2011-03-23 19:42:44 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-23 22:46:33 -0400 |
commit | f9434ad1552427fab49336e1a6e3ef121895b9d1 (patch) | |
tree | 5284bccbf71e601d056d138e894c27726047dc82 /mm/oom_kill.c | |
parent | 5a6475a4e162200f43855e2d42bbf55bcca1a9f2 (diff) |
memcg: give current access to memory reserves if it's trying to die
When a memcg is oom and current has already received a SIGKILL, then give
it access to memory reserves with a higher scheduling priority so that it
may quickly exit and free its memory.
This is identical to the global oom killer and is done even before
checking for panic_on_oom: a pending SIGKILL here while panic_on_oom is
selected is guaranteed to have come from userspace; the thread only needs
access to memory reserves to exit and thus we don't unnecessarily panic
the machine until the kernel has no last resort to free memory.
Signed-off-by: David Rientjes <rientjes@google.com>
Cc: Balbir Singh <balbir@linux.vnet.ibm.com>
Cc: Daisuke Nishimura <nishimura@mxp.nes.nec.co.jp>
Acked-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/oom_kill.c')
-rw-r--r-- | 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 3100bc57036b..62a5cec08a17 100644 --- a/mm/oom_kill.c +++ b/mm/oom_kill.c | |||
@@ -549,6 +549,17 @@ void mem_cgroup_out_of_memory(struct mem_cgroup *mem, gfp_t gfp_mask) | |||
549 | unsigned int points = 0; | 549 | unsigned int points = 0; |
550 | struct task_struct *p; | 550 | struct task_struct *p; |
551 | 551 | ||
552 | /* | ||
553 | * If current has a pending SIGKILL, then automatically select it. The | ||
554 | * goal is to allow it to allocate so that it may quickly exit and free | ||
555 | * its memory. | ||
556 | */ | ||
557 | if (fatal_signal_pending(current)) { | ||
558 | set_thread_flag(TIF_MEMDIE); | ||
559 | boost_dying_task_prio(current, NULL); | ||
560 | return; | ||
561 | } | ||
562 | |||
552 | check_panic_on_oom(CONSTRAINT_MEMCG, gfp_mask, 0, NULL); | 563 | check_panic_on_oom(CONSTRAINT_MEMCG, gfp_mask, 0, NULL); |
553 | limit = mem_cgroup_get_limit(mem) >> PAGE_SHIFT; | 564 | limit = mem_cgroup_get_limit(mem) >> PAGE_SHIFT; |
554 | read_lock(&tasklist_lock); | 565 | read_lock(&tasklist_lock); |