diff options
author | Omar Sandoval <osandov@fb.com> | 2018-09-27 15:55:51 -0700 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2018-09-27 17:34:52 -0600 |
commit | ed88660a5372faa67c168c3db5201e33e488c9fd (patch) | |
tree | 8019473ab93c4b987cf07da9cad88d7cf60a69ed /block/blk-mq.c | |
parent | 986d413b7c156e69198dfc80fb74aa18d0ddef44 (diff) | |
download | lwn-ed88660a5372faa67c168c3db5201e33e488c9fd.tar.gz lwn-ed88660a5372faa67c168c3db5201e33e488c9fd.zip |
block: move call of scheduler's ->completed_request() hook
Commit 4bc6339a583c ("block: move blk_stat_add() to
__blk_mq_end_request()") consolidated some calls using ktime_get() so
we'd only need to call it once. Kyber's ->completed_request() hook also
calls ktime_get(), so let's move it to the same place, too.
Signed-off-by: Omar Sandoval <osandov@fb.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/blk-mq.c')
-rw-r--r-- | block/blk-mq.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/block/blk-mq.c b/block/blk-mq.c index d384ab700afd..1e72d53e8f2d 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c @@ -528,6 +528,9 @@ inline void __blk_mq_end_request(struct request *rq, blk_status_t error) blk_stat_add(rq, now); } + if (rq->internal_tag != -1) + blk_mq_sched_completed_request(rq, now); + blk_account_io_done(rq, now); if (rq->end_io) { @@ -564,8 +567,6 @@ static void __blk_mq_complete_request(struct request *rq) if (!blk_mq_mark_complete(rq)) return; - if (rq->internal_tag != -1) - blk_mq_sched_completed_request(rq); if (!test_bit(QUEUE_FLAG_SAME_COMP, &rq->q->queue_flags)) { rq->q->softirq_done_fn(rq); |