From: Mateusz Nosek Date: Tue, 13 Oct 2020 23:56:58 +0000 (-0700) Subject: mm/compaction.c: micro-optimization remove unnecessary branch X-Git-Tag: v5.10-rc1~156^2~25 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=62b35fe0eba21b09b015cdb43cddf51073e4b18c;p=thirdparty%2Fkernel%2Flinux.git mm/compaction.c: micro-optimization remove unnecessary branch The same code can work both for 'zone->compact_considered > defer_limit' and 'zone->compact_considered >= defer_limit'. In the latter there is one branch less which is more effective considering performance. Signed-off-by: Mateusz Nosek Signed-off-by: Andrew Morton Reviewed-by: Andrew Morton Cc: Joonsoo Kim Cc: Vlastimil Babka Cc: Mel Gorman Cc: David Rientjes Link: https://lkml.kernel.org/r/20200913190448.28649-1-mateusznosek0@gmail.com Signed-off-by: Linus Torvalds --- diff --git a/mm/compaction.c b/mm/compaction.c index 176dcded298ee..6c63844fc0614 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -180,11 +180,10 @@ bool compaction_deferred(struct zone *zone, int order) return false; /* Avoid possible overflow */ - if (++zone->compact_considered > defer_limit) + if (++zone->compact_considered >= defer_limit) { zone->compact_considered = defer_limit; - - if (zone->compact_considered >= defer_limit) return false; + } trace_mm_compaction_deferred(zone, order);