Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
mm: compaction: abort compaction loop if lock is contended or run too…
… long isolate_migratepages_range() might isolate no pages if for example when zone->lru_lock is contended and running asynchronous compaction. In this case, we should abort compaction, otherwise, compact_zone will run a useless loop and make zone->lru_lock is even contended. An additional check is added to ensure that cc.migratepages and cc.freepages get properly drained whan compaction is aborted. [[email protected]: Putback pages isolated for migration if aborting] [[email protected]: compact_zone_order requires non-NULL arg contended] [[email protected]: make compact_zone_order() require non-NULL arg `contended'] [[email protected]: Putback pages isolated for migration if aborting] Signed-off-by: Andrea Arcangeli <[email protected]> Signed-off-by: Shaohua Li <[email protected]> Signed-off-by: Mel Gorman <[email protected]> Acked-by: Minchan Kim <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
- Loading branch information