|
@@ -4906,13 +4906,16 @@ int set_migratetype_isolate(struct page *page)
|
|
struct zone *zone;
|
|
struct zone *zone;
|
|
unsigned long flags;
|
|
unsigned long flags;
|
|
int ret = -EBUSY;
|
|
int ret = -EBUSY;
|
|
|
|
+ int zone_idx;
|
|
|
|
|
|
zone = page_zone(page);
|
|
zone = page_zone(page);
|
|
|
|
+ zone_idx = zone_idx(zone);
|
|
spin_lock_irqsave(&zone->lock, flags);
|
|
spin_lock_irqsave(&zone->lock, flags);
|
|
/*
|
|
/*
|
|
* In future, more migrate types will be able to be isolation target.
|
|
* In future, more migrate types will be able to be isolation target.
|
|
*/
|
|
*/
|
|
- if (get_pageblock_migratetype(page) != MIGRATE_MOVABLE)
|
|
|
|
|
|
+ if (get_pageblock_migratetype(page) != MIGRATE_MOVABLE &&
|
|
|
|
+ zone_idx != ZONE_MOVABLE)
|
|
goto out;
|
|
goto out;
|
|
set_pageblock_migratetype(page, MIGRATE_ISOLATE);
|
|
set_pageblock_migratetype(page, MIGRATE_ISOLATE);
|
|
move_freepages_block(zone, page, MIGRATE_ISOLATE);
|
|
move_freepages_block(zone, page, MIGRATE_ISOLATE);
|