On 8/23/17 05:43, Bart Van Assche wrote: > On Sat, 2017-08-05 at 14:56 +0800, Ming Lei wrote: >> +static inline bool blk_mq_has_dispatch_rqs(struct blk_mq_hw_ctx *hctx) >> +{ >> + return !list_empty_careful(&hctx->dispatch); >> +} >> + >> +static inline void blk_mq_add_rq_to_dispatch(struct blk_mq_hw_ctx *hctx, >> + struct request *rq) >> +{ >> + spin_lock(&hctx->lock); >> + list_add(&rq->queuelist, &hctx->dispatch); >> + blk_mq_hctx_set_dispatch_busy(hctx); >> + spin_unlock(&hctx->lock); >> +} >> + >> +static inline void blk_mq_add_list_to_dispatch(struct blk_mq_hw_ctx *hctx, >> + struct list_head *list) >> +{ >> + spin_lock(&hctx->lock); >> + list_splice_init(list, &hctx->dispatch); >> + blk_mq_hctx_set_dispatch_busy(hctx); >> + spin_unlock(&hctx->lock); >> +} >> + >> +static inline void blk_mq_add_list_to_dispatch_tail(struct blk_mq_hw_ctx *hctx, >> + struct list_head *list) >> +{ >> + spin_lock(&hctx->lock); >> + list_splice_tail_init(list, &hctx->dispatch); >> + blk_mq_hctx_set_dispatch_busy(hctx); >> + spin_unlock(&hctx->lock); >> +} >> + >> +static inline void blk_mq_take_list_from_dispatch(struct blk_mq_hw_ctx *hctx, >> + struct list_head *list) >> +{ >> + spin_lock(&hctx->lock); >> + list_splice_init(&hctx->dispatch, list); >> + spin_unlock(&hctx->lock); >> +} > > Same comment for this patch: these helper functions are so short that I'm not > sure it is useful to introduce these helper functions. > > Bart. Personally, I like those very much as they give a place to hook up different dispatch_list handling without having to change blk-mq.c and blk-mq-sched.c all over the place. I am thinking of SMR (zoned block device) support here since we need to to sort insert write requests in blk_mq_add_rq_to_dispatch() and blk_mq_add_list_to_dispatch_tail(). For this last one, the name would become a little awkward though. This sort insert would be to avoid breaking a sequential write request sequence sent by the disk user. This is needed since this reordering breakage cannot be solved only from the SCSI layer. blk_mq_add_list_to_dispatch() and blk_mq_add_list_to_dispatch_tail() could be combined together into blk_mq_add_list_to_dispatch() with the addition of a "where" argument (BLK_MQ_INSERT_HEAD or BLK_MQ_INSERT_TAIL), or like some other functions in blk-mq, the addition of a simple "bool at_head" argument. Best regards. -- Damien Le Moal, Western Digital Research