mm/page_alloc.c: remove hand-coded get_order()

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Andrew Morton <akpm@...>, kernel list <linux-kernel@...>
Date: Tuesday, April 15, 2008 - 5:23 am

__get_free_pages() is strange interface:

It has underscores, yet get_free_pages() does not exists.

It returns long when most people need pointer.

(And it takes order, when many people want to pass size).

What about creating void *get_free_pages(flags, order) version, then
slowly converting users to it?
									Pavel

---

Remove hand-coded get_order() from page_alloc.c.

Signed-off-by: Pavel Machek <pavel@suse.cz>

diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index 402a504..c48aa45 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -4339,9 +4339,7 @@ void *__init alloc_large_system_hash(con
 		else if (hashdist)
 			table = __vmalloc(size, GFP_ATOMIC, PAGE_KERNEL);
 		else {
-			unsigned long order;
-			for (order = 0; ((1UL << order) << PAGE_SHIFT) < size; order++)
-				;
+			unsigned long order = get_order(size);
 			table = (void*) __get_free_pages(GFP_ATOMIC, order);
 			/*
 			 * If bucketsize is not a power-of-two, we may free


-- 
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
mm/page_alloc.c: remove hand-coded get_order(), Pavel Machek, (Tue Apr 15, 5:23 am)
Re: mm/page_alloc.c: remove hand-coded get_order(), Andi Kleen, (Tue Apr 15, 6:39 am)
Re: mm/page_alloc.c: remove hand-coded get_order(), Christoph Lameter, (Wed Apr 16, 3:18 pm)
Re: mm/page_alloc.c: remove hand-coded get_order(), Andrew Morton, (Tue Apr 15, 5:35 am)
Re: mm/page_alloc.c: remove hand-coded get_order(), Andrew Morton, (Tue Apr 15, 5:38 am)