compact_should_abort() returns true instead of false and vice versa due to changes between v1 and v2 of the patch. This makes both async and sync compaction abort with high probability, and has been reported to cause e.g. soft lockups on some ARM boards, or drivers calling dma_alloc_coherent() fail to probe with CMA enabled on different boards. This patch fixes the return value to match comments and callers expecations. Reported-and-tested-by: Kevin Hilman <khilman@xxxxxxxxxx> Reported-and-tested-by: Shawn Guo <shawn.guo@xxxxxxxxxx> Tested-by: Stephen Warren <swarren@xxxxxxxxxx> Signed-off-by: Vlastimil Babka <vbabka@xxxxxxx> --- mm/compaction.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/mm/compaction.c b/mm/compaction.c index a525cd4..5175019 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -237,13 +237,13 @@ static inline bool compact_should_abort(struct compact_control *cc) if (need_resched()) { if (cc->mode == MIGRATE_ASYNC) { cc->contended = true; - return false; + return true; } cond_resched(); } - return true; + return false; } /* Returns true if the page is within a block suitable for migration to */ -- 1.8.4.5 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>