Commit 58b613dc authored by Matthew Wilcox's avatar Matthew Wilcox Committed by Linus Torvalds

[PATCH] Make slab use alloc_pages directly

__get_free_pages() calls alloc_pages, finds the page_address() and throws
away the struct page *.  Slab then calls virt_to_page to get it back again.
 Much more efficient for slab to call alloc_pages itself, as well as making
the NUMA and non-NUMA cases more similarr to each other.
Signed-off-by: default avatarMatthew Wilcox <matthew@wil.cx>
Signed-off-by: default avatarManfred Spraul <manfred@colorfullife.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 382a7dec
...@@ -894,16 +894,13 @@ static void *kmem_getpages(kmem_cache_t *cachep, int flags, int nodeid) ...@@ -894,16 +894,13 @@ static void *kmem_getpages(kmem_cache_t *cachep, int flags, int nodeid)
flags |= cachep->gfpflags; flags |= cachep->gfpflags;
if (likely(nodeid == -1)) { if (likely(nodeid == -1)) {
addr = (void*)__get_free_pages(flags, cachep->gfporder); page = alloc_pages(flags, cachep->gfporder);
if (!addr)
return NULL;
page = virt_to_page(addr);
} else { } else {
page = alloc_pages_node(nodeid, flags, cachep->gfporder); page = alloc_pages_node(nodeid, flags, cachep->gfporder);
}
if (!page) if (!page)
return NULL; return NULL;
addr = page_address(page); addr = page_address(page);
}
i = (1 << cachep->gfporder); i = (1 << cachep->gfporder);
if (cachep->flags & SLAB_RECLAIM_ACCOUNT) if (cachep->flags & SLAB_RECLAIM_ACCOUNT)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment