summaryrefslogtreecommitdiff
path: root/arch/sh/kernel/process_64.c
diff options
context:
space:
mode:
authorTetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>2013-11-12 15:06:45 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2013-11-13 12:08:59 +0900
commit786235eeba0e1e85e5cbbb9f97d1087ad03dfa21 (patch)
treee529b2b8f6a64889ec8c385cdca64f5c1d8e1c19 /arch/sh/kernel/process_64.c
parent10d0c9705e80bbd3d587c5fad24599aabaca6688 (diff)
downloadlwn-786235eeba0e1e85e5cbbb9f97d1087ad03dfa21.tar.gz
lwn-786235eeba0e1e85e5cbbb9f97d1087ad03dfa21.zip
kthread: make kthread_create() killable
Any user process callers of wait_for_completion() except global init process might be chosen by the OOM killer while waiting for completion() call by some other process which does memory allocation. See CVE-2012-4398 "kernel: request_module() OOM local DoS" can happen. When such users are chosen by the OOM killer when they are waiting for completion() in TASK_UNINTERRUPTIBLE, the system will be kept stressed due to memory starvation because the OOM killer cannot kill such users. kthread_create() is one of such users and this patch fixes the problem for kthreadd by making kthread_create() killable - the same approach used for fixing CVE-2012-4398. Signed-off-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> Cc: Oleg Nesterov <oleg@redhat.com> Acked-by: David Rientjes <rientjes@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/sh/kernel/process_64.c')
0 files changed, 0 insertions, 0 deletions