diff options
author | Tejun Heo <tj@kernel.org> | 2012-09-20 17:09:30 -0400 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2012-09-21 09:33:12 -0400 |
commit | 60ea8226cbd5c8301f9a39edc574ddabcb8150e0 (patch) | |
tree | db426f88c06a88e9a6e75eb6b3ef9c8b5ff0da85 /block | |
parent | 749fefe6778e98dfefe3b8bb72a93875196ec554 (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>
Diffstat (limited to 'block')
-rw-r--r-- | block/blk-core.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/block/blk-core.c b/block/blk-core.c index 80e29c90723..a17869f337f 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) |