From: Christoph Hellwig Date: Fri, 16 Jun 2017 16:15:23 +0000 (+0200) Subject: blk-mq: streamline blk_mq_get_request X-Git-Tag: v4.13-rc1~70^2~60 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=037cebb85b94027a52be69d72068e6f6d0dca3a3;p=platform%2Fkernel%2Flinux-exynos.git blk-mq: streamline blk_mq_get_request Signed-off-by: Christoph Hellwig Signed-off-by: Jens Axboe --- diff --git a/block/blk-mq.c b/block/blk-mq.c index 0b17351..e056725 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c @@ -302,24 +302,24 @@ static struct request *blk_mq_get_request(struct request_queue *q, rq = e->type->ops.mq.get_request(q, op, data); if (rq) rq->rq_flags |= RQF_QUEUED; - } else - rq = __blk_mq_alloc_request(data, op); - } else { - rq = __blk_mq_alloc_request(data, op); + goto allocated; + } } - if (rq) { - if (!op_is_flush(op)) { - rq->elv.icq = NULL; - if (e && e->type->icq_cache) - blk_mq_sched_assign_ioc(q, rq, bio); - } - data->hctx->queued++; - return rq; + rq = __blk_mq_alloc_request(data, op); +allocated: + if (!rq) { + blk_queue_exit(q); + return NULL; } - blk_queue_exit(q); - return NULL; + if (!op_is_flush(op)) { + rq->elv.icq = NULL; + if (e && e->type->icq_cache) + blk_mq_sched_assign_ioc(q, rq, bio); + } + data->hctx->queued++; + return rq; } struct request *blk_mq_alloc_request(struct request_queue *q, int rw,