summaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorMing Lei <tom.leiming@gmail.com>2014-06-04 18:23:55 +0200
committerJens Axboe <axboe@fb.com>2014-06-04 18:40:16 +0200
commit14b83e172f0bc83b8dcf78ee8b1844beeffb418d (patch)
tree3695014cf1ecadfaba613ed6d5e6be39b6788d68 /block
parentblk-mq: let blk_mq_tag_to_rq() take blk_mq_tags as the main parameter (diff)
downloadlinux-14b83e172f0bc83b8dcf78ee8b1844beeffb418d.tar.xz
linux-14b83e172f0bc83b8dcf78ee8b1844beeffb418d.zip
block: mq flush: clear flush_rq's tag in flush_end_io()
blk_mq_tag_to_rq() needs to be able to tell if it should return the original request, or the flush request if we are doing a flush sequence. Clear the flush tag when IO completes for a flush, since that is what we are comparing against. Signed-off-by: Ming Lei <tom.leiming@gmail.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block')
-rw-r--r--block/blk-flush.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/block/blk-flush.c b/block/blk-flush.c
index ff87c664b7df..8ffee4b5f93d 100644
--- a/block/blk-flush.c
+++ b/block/blk-flush.c
@@ -225,7 +225,7 @@ static void flush_end_io(struct request *flush_rq, int error)
if (q->mq_ops) {
spin_lock_irqsave(&q->mq_flush_lock, flags);
- q->flush_rq->cmd_flags = 0;
+ q->flush_rq->tag = -1;
}
running = &q->flush_queue[q->flush_running_idx];