aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2012-09-20 17:09:30 -0400
committerJens Axboe <axboe@kernel.dk>2012-09-21 09:33:12 -0400
commit60ea8226cbd5c8301f9a39edc574ddabcb8150e0 (patch)
treedb426f88c06a88e9a6e75eb6b3ef9c8b5ff0da85
parent749fefe6778e98dfefe3b8bb72a93875196ec554 (diff)
block: fix request_queue->flags initialization
A queue newly allocated with blk_alloc_queue_node() has only QUEUE_FLAG_BYPASS set. For request-based drivers, blk_init_allocated_queue() is called and q->queue_flags is overwritten with QUEUE_FLAG_DEFAULT which doesn't include BYPASS even though the initial bypass is still in effect. In blk_init_allocated_queue(), or QUEUE_FLAG_DEFAULT to q->queue_flags instead of overwriting. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: stable@vger.kernel.org Acked-by: Vivek Goyal <vgoyal@redhat.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r--block/blk-core.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/block/blk-core.c b/block/blk-core.c
index 80e29c90723c..a17869f337f7 100644
--- a/block/blk-core.c
+++ b/block/blk-core.c
@@ -696,7 +696,7 @@ blk_init_allocated_queue(struct request_queue *q, request_fn_proc *rfn,
696 q->request_fn = rfn; 696 q->request_fn = rfn;
697 q->prep_rq_fn = NULL; 697 q->prep_rq_fn = NULL;
698 q->unprep_rq_fn = NULL; 698 q->unprep_rq_fn = NULL;
699 q->queue_flags = QUEUE_FLAG_DEFAULT; 699 q->queue_flags |= QUEUE_FLAG_DEFAULT;
700 700
701 /* Override internal queue lock with supplied lock pointer */ 701 /* Override internal queue lock with supplied lock pointer */
702 if (lock) 702 if (lock)