diff options
author | Hugh Dickins <hugh.dickins@tiscali.co.uk> | 2009-06-16 18:31:50 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-06-16 22:47:31 -0400 |
commit | 6c0db4664b49417d80988953e69c323721353227 (patch) | |
tree | 83ec1fcf3607b06c8c3cc2d39b5d10a61289cdd6 | |
parent | 58568d2a8215cb6f55caf2332017d7bdff954e1c (diff) |
mm: alloc_large_system_hash check order
On an x86_64 with 4GB ram, tcp_init()'s call to alloc_large_system_hash(),
to allocate tcp_hashinfo.ehash, is now triggering an mmotm WARN_ON_ONCE on
order >= MAX_ORDER - it's hoping for order 11. alloc_large_system_hash()
had better make its own check on the order.
Signed-off-by: Hugh Dickins <hugh.dickins@tiscali.co.uk>
Cc: David Miller <davem@davemloft.net>
Cc: Mel Gorman <mel@csn.ul.ie>
Cc: Eric Dumazet <dada1@cosmosbay.com>
Cc: Christoph Lameter <cl@linux.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | mm/page_alloc.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 7cc3179e3591..cbed869fd831 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
@@ -4511,7 +4511,10 @@ void *__init alloc_large_system_hash(const char *tablename, | |||
4511 | table = __vmalloc(size, GFP_ATOMIC, PAGE_KERNEL); | 4511 | table = __vmalloc(size, GFP_ATOMIC, PAGE_KERNEL); |
4512 | else { | 4512 | else { |
4513 | unsigned long order = get_order(size); | 4513 | unsigned long order = get_order(size); |
4514 | table = (void*) __get_free_pages(GFP_ATOMIC, order); | 4514 | |
4515 | if (order < MAX_ORDER) | ||
4516 | table = (void *)__get_free_pages(GFP_ATOMIC, | ||
4517 | order); | ||
4515 | /* | 4518 | /* |
4516 | * If bucketsize is not a power-of-two, we may free | 4519 | * If bucketsize is not a power-of-two, we may free |
4517 | * some pages at the end of hash table. | 4520 | * some pages at the end of hash table. |