Commit deba0487 authored by Vlastimil Babka's avatar Vlastimil Babka Committed by Linus Torvalds

mm, page_alloc: use unlikely() in task_capc()

Hugh noted that task_capc() could use unlikely(), as most of the time
there is no capture in progress and we are in page freeing hot path.
Indeed adding unlikely() produces assembly that better matches the
assumption and moves all the tests away from the hot path.

I have also noticed that we don't need to test for cc->direct_compaction
as the only place we set current->task_capture is compact_zone_order()
which also always sets cc->direct_compaction true.
Suggested-by: default avatarHugh Dickins <hughd@google.com>
Signed-off-by: default avatarVlastimil Babka <vbabka@suse.cz>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Acked-by: default avatarHugh Dickins <hughd@googlecom>
Acked-by: default avatarMel Gorman <mgorman@techsingularity.net>
Cc: Alex Shi <alex.shi@linux.alibaba.com>
Cc: Li Wang <liwang@redhat.com>
Link: http://lkml.kernel.org/r/4a24f7af-3aa5-6e80-4ae6-8f253b562039@suse.czSigned-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 51dcc81c
...@@ -813,11 +813,10 @@ static inline struct capture_control *task_capc(struct zone *zone) ...@@ -813,11 +813,10 @@ static inline struct capture_control *task_capc(struct zone *zone)
{ {
struct capture_control *capc = current->capture_control; struct capture_control *capc = current->capture_control;
return capc && return unlikely(capc) &&
!(current->flags & PF_KTHREAD) && !(current->flags & PF_KTHREAD) &&
!capc->page && !capc->page &&
capc->cc->zone == zone && capc->cc->zone == zone ? capc : NULL;
capc->cc->direct_compaction ? capc : NULL;
} }
static inline bool static inline bool
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment