aboutsummaryrefslogtreecommitdiffstats
path: root/mm/compaction.c
diff options
context:
space:
mode:
authorThierry Reding <thierry.reding@avionic-design.de>2012-12-12 16:51:17 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2012-12-12 20:38:32 -0500
commitc8bf2d8ba4fbc093de7c0d192fe5d2531f14b8b9 (patch)
tree0b26144dd758cc6cdceee1b1d2972bfab76b094c /mm/compaction.c
parent3ea41e6210fea3b234b6cb3e9443e75975850bbf (diff)
mm: compaction: Fix compiler warning
compact_capture_page() is only used if compaction is enabled so it should be moved into the corresponding #ifdef. Signed-off-by: Thierry Reding <thierry.reding@avionic-design.de> Acked-by: Mel Gorman <mgorman@suse.de> Cc: Rik van Riel <riel@redhat.com> Cc: Minchan Kim <minchan@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/compaction.c')
-rw-r--r--mm/compaction.c108
1 files changed, 54 insertions, 54 deletions
diff --git a/mm/compaction.c b/mm/compaction.c
index d24dd2d7bad4..129791218226 100644
--- a/mm/compaction.c
+++ b/mm/compaction.c
@@ -215,60 +215,6 @@ static bool suitable_migration_target(struct page *page)
215 return false; 215 return false;
216} 216}
217 217
218static void compact_capture_page(struct compact_control *cc)
219{
220 unsigned long flags;
221 int mtype, mtype_low, mtype_high;
222
223 if (!cc->page || *cc->page)
224 return;
225
226 /*
227 * For MIGRATE_MOVABLE allocations we capture a suitable page ASAP
228 * regardless of the migratetype of the freelist is is captured from.
229 * This is fine because the order for a high-order MIGRATE_MOVABLE
230 * allocation is typically at least a pageblock size and overall
231 * fragmentation is not impaired. Other allocation types must
232 * capture pages from their own migratelist because otherwise they
233 * could pollute other pageblocks like MIGRATE_MOVABLE with
234 * difficult to move pages and making fragmentation worse overall.
235 */
236 if (cc->migratetype == MIGRATE_MOVABLE) {
237 mtype_low = 0;
238 mtype_high = MIGRATE_PCPTYPES;
239 } else {
240 mtype_low = cc->migratetype;
241 mtype_high = cc->migratetype + 1;
242 }
243
244 /* Speculatively examine the free lists without zone lock */
245 for (mtype = mtype_low; mtype < mtype_high; mtype++) {
246 int order;
247 for (order = cc->order; order < MAX_ORDER; order++) {
248 struct page *page;
249 struct free_area *area;
250 area = &(cc->zone->free_area[order]);
251 if (list_empty(&area->free_list[mtype]))
252 continue;
253
254 /* Take the lock and attempt capture of the page */
255 if (!compact_trylock_irqsave(&cc->zone->lock, &flags, cc))
256 return;
257 if (!list_empty(&area->free_list[mtype])) {
258 page = list_entry(area->free_list[mtype].next,
259 struct page, lru);
260 if (capture_free_page(page, cc->order, mtype)) {
261 spin_unlock_irqrestore(&cc->zone->lock,
262 flags);
263 *cc->page = page;
264 return;
265 }
266 }
267 spin_unlock_irqrestore(&cc->zone->lock, flags);
268 }
269 }
270}
271
272/* 218/*
273 * Isolate free pages onto a private freelist. Caller must hold zone->lock. 219 * Isolate free pages onto a private freelist. Caller must hold zone->lock.
274 * If @strict is true, will abort returning 0 on any invalid PFNs or non-free 220 * If @strict is true, will abort returning 0 on any invalid PFNs or non-free
@@ -953,6 +899,60 @@ unsigned long compaction_suitable(struct zone *zone, int order)
953 return COMPACT_CONTINUE; 899 return COMPACT_CONTINUE;
954} 900}
955 901
902static void compact_capture_page(struct compact_control *cc)
903{
904 unsigned long flags;
905 int mtype, mtype_low, mtype_high;
906
907 if (!cc->page || *cc->page)
908 return;
909
910 /*
911 * For MIGRATE_MOVABLE allocations we capture a suitable page ASAP
912 * regardless of the migratetype of the freelist is is captured from.
913 * This is fine because the order for a high-order MIGRATE_MOVABLE
914 * allocation is typically at least a pageblock size and overall
915 * fragmentation is not impaired. Other allocation types must
916 * capture pages from their own migratelist because otherwise they
917 * could pollute other pageblocks like MIGRATE_MOVABLE with
918 * difficult to move pages and making fragmentation worse overall.
919 */
920 if (cc->migratetype == MIGRATE_MOVABLE) {
921 mtype_low = 0;
922 mtype_high = MIGRATE_PCPTYPES;
923 } else {
924 mtype_low = cc->migratetype;
925 mtype_high = cc->migratetype + 1;
926 }
927
928 /* Speculatively examine the free lists without zone lock */
929 for (mtype = mtype_low; mtype < mtype_high; mtype++) {
930 int order;
931 for (order = cc->order; order < MAX_ORDER; order++) {
932 struct page *page;
933 struct free_area *area;
934 area = &(cc->zone->free_area[order]);
935 if (list_empty(&area->free_list[mtype]))
936 continue;
937
938 /* Take the lock and attempt capture of the page */
939 if (!compact_trylock_irqsave(&cc->zone->lock, &flags, cc))
940 return;
941 if (!list_empty(&area->free_list[mtype])) {
942 page = list_entry(area->free_list[mtype].next,
943 struct page, lru);
944 if (capture_free_page(page, cc->order, mtype)) {
945 spin_unlock_irqrestore(&cc->zone->lock,
946 flags);
947 *cc->page = page;
948 return;
949 }
950 }
951 spin_unlock_irqrestore(&cc->zone->lock, flags);
952 }
953 }
954}
955
956static int compact_zone(struct zone *zone, struct compact_control *cc) 956static int compact_zone(struct zone *zone, struct compact_control *cc)
957{ 957{
958 int ret; 958 int ret;