diff options
author | Josef Bacik <jbacik@fb.com> | 2017-02-10 13:03:33 -0500 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2017-02-10 13:15:01 -0500 |
commit | f6f94300cda0f85180a0dd8838d1cc855661e239 (patch) | |
tree | 31d095416a52582e9cd9c6f6e4d906f429d65069 | |
parent | f1ba82616c3368e1ae9e64ef29cf3edc1be0860d (diff) |
block: set make_request_fn manually in blk_mq_update_nr_hw_queues
Calling blk_queue_make_request resets a bunch of settings on the
request_queue, but all we really want is to update the make_request_fn,
so do this directly so we don't lose things like the logical and
physical block sizes.
Signed-off-by: Josef Bacik <jbacik@fb.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
-rw-r--r-- | block/blk-mq.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/block/blk-mq.c b/block/blk-mq.c index 7412191aee57..ade89197a4f1 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c | |||
@@ -2629,10 +2629,14 @@ void blk_mq_update_nr_hw_queues(struct blk_mq_tag_set *set, int nr_hw_queues) | |||
2629 | list_for_each_entry(q, &set->tag_list, tag_set_list) { | 2629 | list_for_each_entry(q, &set->tag_list, tag_set_list) { |
2630 | blk_mq_realloc_hw_ctxs(set, q); | 2630 | blk_mq_realloc_hw_ctxs(set, q); |
2631 | 2631 | ||
2632 | /* | ||
2633 | * Manually set the make_request_fn as blk_queue_make_request | ||
2634 | * resets a lot of the queue settings. | ||
2635 | */ | ||
2632 | if (q->nr_hw_queues > 1) | 2636 | if (q->nr_hw_queues > 1) |
2633 | blk_queue_make_request(q, blk_mq_make_request); | 2637 | q->make_request_fn = blk_mq_make_request; |
2634 | else | 2638 | else |
2635 | blk_queue_make_request(q, blk_sq_make_request); | 2639 | q->make_request_fn = blk_sq_make_request; |
2636 | 2640 | ||
2637 | blk_mq_queue_reinit(q, cpu_online_mask); | 2641 | blk_mq_queue_reinit(q, cpu_online_mask); |
2638 | } | 2642 | } |