OSDN Git Service

blk-mq: optimise rq sort function
authorPavel Begunkov <asml.silence@gmail.com>
Thu, 28 Nov 2019 21:11:53 +0000 (00:11 +0300)
committerJens Axboe <axboe@kernel.dk>
Thu, 19 Dec 2019 13:08:50 +0000 (06:08 -0700)
Check "!=" in multi-layer comparisons. The same memory usage, fewer
instructions, and 2 from 4 jumps are replaced with SETcc.

Note, that list_sort() doesn't differ 0 and <0.

Reviewed-by: Nikolay Borisov <nborisov@suse.com>
Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/blk-mq.c

index 323c9cb..f32a3cf 100644 (file)
@@ -1668,14 +1668,10 @@ static int plug_rq_cmp(void *priv, struct list_head *a, struct list_head *b)
        struct request *rqa = container_of(a, struct request, queuelist);
        struct request *rqb = container_of(b, struct request, queuelist);
 
-       if (rqa->mq_ctx < rqb->mq_ctx)
-               return -1;
-       else if (rqa->mq_ctx > rqb->mq_ctx)
-               return 1;
-       else if (rqa->mq_hctx < rqb->mq_hctx)
-               return -1;
-       else if (rqa->mq_hctx > rqb->mq_hctx)
-               return 1;
+       if (rqa->mq_ctx != rqb->mq_ctx)
+               return rqa->mq_ctx > rqb->mq_ctx;
+       if (rqa->mq_hctx != rqb->mq_hctx)
+               return rqa->mq_hctx > rqb->mq_hctx;
 
        return blk_rq_pos(rqa) > blk_rq_pos(rqb);
 }