aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMel Gorman <mel@csn.ul.ie>2007-10-16 04:26:10 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-10-16 12:43:01 -0400
commit48f13bf3e742fca8aab87f6c39451d03bf5952d4 (patch)
tree668160019ab157500a90655cf44f798ed3c77893
parentea3061d227816d00717446ac12b853d7ae04b4fe (diff)
Breakout page_order() to internal.h to avoid special knowledge of the buddy allocator
The statistics patch later needs to know what order a free page is on the free lists. Rather than having special knowledge of page_private() when PageBuddy() is set, this patch places out page_order() in internal.h and adds a VM_BUG_ON to catch using it on non-PageBuddy pages. Signed-off-by: Mel Gorman <mel@csn.ul.ie> Signed-off-by: Christoph Lameter <clameter@sgi.com> Acked-by: Andy Whitcroft <apw@shadowen.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--mm/internal.h10
-rw-r--r--mm/page_alloc.c10
2 files changed, 10 insertions, 10 deletions
diff --git a/mm/internal.h b/mm/internal.h
index a3110c02aea7..953f941ea867 100644
--- a/mm/internal.h
+++ b/mm/internal.h
@@ -37,4 +37,14 @@ static inline void __put_page(struct page *page)
37extern void fastcall __init __free_pages_bootmem(struct page *page, 37extern void fastcall __init __free_pages_bootmem(struct page *page,
38 unsigned int order); 38 unsigned int order);
39 39
40/*
41 * function for dealing with page's order in buddy system.
42 * zone->lock is already acquired when we use these.
43 * So, we don't need atomic page->flags operations here.
44 */
45static inline unsigned long page_order(struct page *page)
46{
47 VM_BUG_ON(!PageBuddy(page));
48 return page_private(page);
49}
40#endif 50#endif
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index a8a53f879dfe..71ced519c31c 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -313,16 +313,6 @@ static inline void prep_zero_page(struct page *page, int order, gfp_t gfp_flags)
313 clear_highpage(page + i); 313 clear_highpage(page + i);
314} 314}
315 315
316/*
317 * function for dealing with page's order in buddy system.
318 * zone->lock is already acquired when we use these.
319 * So, we don't need atomic page->flags operations here.
320 */
321static inline unsigned long page_order(struct page *page)
322{
323 return page_private(page);
324}
325
326static inline void set_page_order(struct page *page, int order) 316static inline void set_page_order(struct page *page, int order)
327{ 317{
328 set_page_private(page, order); 318 set_page_private(page, order);