OSDN Git Service

blk-mq: use if-else instead of goto in blk_mq_alloc_cached_request()
authorJinlong Chen <nickyc975@zju.edu.cn>
Wed, 2 Nov 2022 02:52:30 +0000 (10:52 +0800)
committerJens Axboe <axboe@kernel.dk>
Wed, 2 Nov 2022 14:36:50 +0000 (08:36 -0600)
if-else is more readable than goto here.

Signed-off-by: Jinlong Chen <nickyc975@zju.edu.cn>
Link: https://lore.kernel.org/r/d3306fa4e92dc9cc614edc8f1802686096bafef2.1667356813.git.nickyc975@zju.edu.cn
Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/blk-mq.c

index d4824b5..fc9c400 100644 (file)
@@ -575,25 +575,26 @@ static struct request *blk_mq_alloc_cached_request(struct request_queue *q,
 
        if (!plug)
                return NULL;
+
        if (rq_list_empty(plug->cached_rq)) {
                if (plug->nr_ios == 1)
                        return NULL;
                rq = blk_mq_rq_cache_fill(q, plug, opf, flags);
-               if (rq)
-                       goto got_it;
-               return NULL;
-       }
-       rq = rq_list_peek(&plug->cached_rq);
-       if (!rq || rq->q != q)
-               return NULL;
+               if (!rq)
+                       return NULL;
+       } else {
+               rq = rq_list_peek(&plug->cached_rq);
+               if (!rq || rq->q != q)
+                       return NULL;
 
-       if (blk_mq_get_hctx_type(opf) != rq->mq_hctx->type)
-               return NULL;
-       if (op_is_flush(rq->cmd_flags) != op_is_flush(opf))
-               return NULL;
+               if (blk_mq_get_hctx_type(opf) != rq->mq_hctx->type)
+                       return NULL;
+               if (op_is_flush(rq->cmd_flags) != op_is_flush(opf))
+                       return NULL;
+
+               plug->cached_rq = rq_list_next(rq);
+       }
 
-       plug->cached_rq = rq_list_next(rq);
-got_it:
        rq->cmd_flags = opf;
        INIT_LIST_HEAD(&rq->queuelist);
        return rq;