aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorMel Gorman <mel@csn.ul.ie>2009-06-16 18:32:04 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2009-06-16 22:47:33 -0400
commit728ec980fb9fa2d65d9e05444079a53615985e7b (patch)
treed98dca98cd46fc28a871135cc9bd95168e4667b3 /mm
parenta56f57ff94c25d5d80def06f3ed8fe7f99147762 (diff)
page allocator: inline __rmqueue_smallest()
Inline __rmqueue_smallest by altering flow very slightly so that there is only one call site. Because there is only one call-site, this function can then be inlined without causing text bloat. On an x86-based config, this patch reduces text by 16 bytes. Signed-off-by: Mel Gorman <mel@csn.ul.ie> Reviewed-by: Christoph Lameter <cl@linux-foundation.org> Reviewed-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Cc: Pekka Enberg <penberg@cs.helsinki.fi> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Nick Piggin <nickpiggin@yahoo.com.au> Cc: Dave Hansen <dave@linux.vnet.ibm.com> Cc: Lee Schermerhorn <Lee.Schermerhorn@hp.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/page_alloc.c20
1 files changed, 16 insertions, 4 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index 94f33e2b7f0b..04713f649fd4 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -661,7 +661,8 @@ static int prep_new_page(struct page *page, int order, gfp_t gfp_flags)
661 * Go through the free lists for the given migratetype and remove 661 * Go through the free lists for the given migratetype and remove
662 * the smallest available page from the freelists 662 * the smallest available page from the freelists
663 */ 663 */
664static struct page *__rmqueue_smallest(struct zone *zone, unsigned int order, 664static inline
665struct page *__rmqueue_smallest(struct zone *zone, unsigned int order,
665 int migratetype) 666 int migratetype)
666{ 667{
667 unsigned int current_order; 668 unsigned int current_order;
@@ -831,8 +832,7 @@ static struct page *__rmqueue_fallback(struct zone *zone, int order,
831 } 832 }
832 } 833 }
833 834
834 /* Use MIGRATE_RESERVE rather than fail an allocation */ 835 return NULL;
835 return __rmqueue_smallest(zone, order, MIGRATE_RESERVE);
836} 836}
837 837
838/* 838/*
@@ -844,11 +844,23 @@ static struct page *__rmqueue(struct zone *zone, unsigned int order,
844{ 844{
845 struct page *page; 845 struct page *page;
846 846
847retry_reserve:
847 page = __rmqueue_smallest(zone, order, migratetype); 848 page = __rmqueue_smallest(zone, order, migratetype);
848 849
849 if (unlikely(!page)) 850 if (unlikely(!page) && migratetype != MIGRATE_RESERVE) {
850 page = __rmqueue_fallback(zone, order, migratetype); 851 page = __rmqueue_fallback(zone, order, migratetype);
851 852
853 /*
854 * Use MIGRATE_RESERVE rather than fail an allocation. goto
855 * is used because __rmqueue_smallest is an inline function
856 * and we want just one call site
857 */
858 if (!page) {
859 migratetype = MIGRATE_RESERVE;
860 goto retry_reserve;
861 }
862 }
863
852 return page; 864 return page;
853} 865}
854 866