]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commit
[PATCH] OOM can panic due to processes stuck in __alloc_pages()
authorKirill Korotaev <dev@openvz.org>
Thu, 7 Dec 2006 04:32:27 +0000 (20:32 -0800)
committerLinus Torvalds <torvalds@woody.osdl.org>
Thu, 7 Dec 2006 16:39:22 +0000 (08:39 -0800)
commitb43a57bb4dae72e8f7232e7c821a8799eda30022
tree4293286b44c8b11bac6a03c4ddfe75aea40aa089
parenta3eea484f7a1aadb70ed6665338026a09ad6ce85
[PATCH] OOM can panic due to processes stuck in __alloc_pages()

OOM can panic due to the processes stuck in __alloc_pages() doing infinite
rebalance loop while no memory can be reclaimed.  OOM killer tries to kill
some processes, but unfortunetaly, rebalance label was moved by someone
below the TIF_MEMDIE check, so buddy allocator doesn't see that process is
OOM-killed and it can simply fail the allocation :/

Observed in reality on RHEL4(2.6.9)+OpenVZ kernel when a user doing some
memory allocation tricks triggered OOM panic.

Signed-off-by: Denis Lunev <den@sw.ru>
Signed-off-by: Kirill Korotaev <dev@openvz.org>
Cc: Nick Piggin <nickpiggin@yahoo.com.au>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
mm/page_alloc.c