On Thu, May 04 2017, Ming Lei wrote: > diff --git a/block/blk-mq-sched.h b/block/blk-mq-sched.h > index edafb5383b7b..241d23c18181 100644 > --- a/block/blk-mq-sched.h > +++ b/block/blk-mq-sched.h > @@ -129,4 +136,19 @@ static inline bool blk_mq_sched_needs_restart(struct blk_mq_hw_ctx *hctx) > return test_bit(BLK_MQ_S_SCHED_RESTART, &hctx->state); > } > > +/* > + * If this queue has enough hardware tags and doesn't share tags with > + * other queues, just use hw tag directly for scheduling. > + */ > +static inline bool blk_mq_sched_may_use_hw_tag(struct request_queue *q) > +{ > + if (q->tag_set->flags & BLK_MQ_F_TAG_SHARED) > + return false; > + > + if (blk_mq_get_queue_depth(q) < q->nr_requests) > + return false; > + > + return true; > +} > + Let's put that in block/blk-mq-sched.c instead, especially since it grows more code in the next patch. -- Jens Axboe