From: Christoph Hellwig <hch@infradead.org>
To: Jens Axboe <axboe@fb.com>
Cc: axboe@kernel.dk, linux-block@vger.kernel.org, paolo.valente@linaro.org
Subject: Re: [PATCH 3/7] block: use appropriate queue running functions
Date: Mon, 5 Dec 2016 05:07:52 -0800 [thread overview]
Message-ID: <20161205130752.GC7100@infradead.org> (raw)
In-Reply-To: <1480734921-23701-4-git-send-email-axboe@fb.com>
On Fri, Dec 02, 2016 at 08:15:17PM -0700, Jens Axboe wrote:
> Use MQ variants for MQ, legacy ones for legacy.
>
> Signed-off-by: Jens Axboe <axboe@fb.com>
> ---
> block/blk-core.c | 5 ++++-
> block/blk-exec.c | 10 ++++++++--
> block/blk-flush.c | 14 ++++++++++----
> block/elevator.c | 5 ++++-
> 4 files changed, 26 insertions(+), 8 deletions(-)
>
> diff --git a/block/blk-core.c b/block/blk-core.c
> index 0e23589ab3bf..3591f5419509 100644
> --- a/block/blk-core.c
> +++ b/block/blk-core.c
> @@ -340,7 +340,10 @@ void __blk_run_queue(struct request_queue *q)
> if (unlikely(blk_queue_stopped(q)))
> return;
>
> - __blk_run_queue_uncond(q);
> + if (WARN_ON_ONCE(q->mq_ops))
> + blk_mq_run_hw_queues(q, true);
> + else
This looks odd with the WARN_ON..
> +++ b/block/blk-exec.c
> @@ -80,8 +80,14 @@ void blk_execute_rq_nowait(struct request_queue *q, struct gendisk *bd_disk,
> }
>
> __elv_add_request(q, rq, where);
> - __blk_run_queue(q);
> - spin_unlock_irq(q->queue_lock);
> +
> + if (q->mq_ops) {
> + spin_unlock_irq(q->queue_lock);
> + blk_mq_run_hw_queues(q, false);
> + } else {
> + __blk_run_queue(q);
> + spin_unlock_irq(q->queue_lock);
> + }
We already branch out to the blk-mq path earlier in the function.
next prev parent reply other threads:[~2016-12-05 13:07 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-03 3:15 [PATCHSET/RFC] Make legacy IO schedulers work with blk-mq Jens Axboe
2016-12-03 3:15 ` [PATCH 1/7] block: use legacy path for flush requests for MQ with a scheduler Jens Axboe
2016-12-05 13:05 ` Christoph Hellwig
2016-12-05 15:07 ` Jens Axboe
2016-12-05 15:49 ` Johannes Thumshirn
2016-12-05 15:49 ` Jens Axboe
2016-12-05 22:40 ` Mike Snitzer
2016-12-05 22:50 ` Jens Axboe
2016-12-06 19:50 ` Mike Snitzer
2016-12-05 17:00 ` Ming Lei
2016-12-05 17:09 ` Jens Axboe
2016-12-05 19:22 ` Ming Lei
2016-12-05 19:35 ` Jens Axboe
2016-12-03 3:15 ` [PATCH 2/7] cfq-iosched: use appropriate run queue function Jens Axboe
2016-12-05 8:48 ` Johannes Thumshirn
2016-12-05 15:12 ` Jens Axboe
2016-12-05 15:18 ` Johannes Thumshirn
2016-12-05 13:06 ` Christoph Hellwig
2016-12-05 15:08 ` Jens Axboe
2016-12-03 3:15 ` [PATCH 3/7] block: use appropriate queue running functions Jens Axboe
2016-12-05 9:01 ` Johannes Thumshirn
2016-12-05 13:07 ` Christoph Hellwig [this message]
2016-12-05 15:10 ` Jens Axboe
2016-12-05 17:39 ` Jens Axboe
2016-12-03 3:15 ` [PATCH 4/7] blk-mq: blk_account_io_start() takes a bool Jens Axboe
2016-12-05 9:01 ` Johannes Thumshirn
2016-12-05 13:08 ` Christoph Hellwig
2016-12-03 3:15 ` [PATCH 5/7] blk-mq: test patch to get legacy IO schedulers working Jens Axboe
2016-12-03 3:15 ` [PATCH 6/7] block: drop irq+lock when flushing queue plugs Jens Axboe
2016-12-03 3:15 ` [PATCH 7/7] null_blk: add parameters to ask for mq-sched and write cache Jens Axboe
2016-12-03 4:02 ` [PATCHSET/RFC] Make legacy IO schedulers work with blk-mq Jens Axboe
2016-12-03 4:04 ` Jens Axboe
-- strict thread matches above, loose matches on Subject: below --
2016-12-05 18:26 [PATCHSET/RFC v2] " Jens Axboe
2016-12-05 18:27 ` [PATCH 3/7] block: use appropriate queue running functions Jens Axboe
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20161205130752.GC7100@infradead.org \
--to=hch@infradead.org \
--cc=axboe@fb.com \
--cc=axboe@kernel.dk \
--cc=linux-block@vger.kernel.org \
--cc=paolo.valente@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.