Skip to content

Commit e02657e

Browse files
Ming Leiaxboe
authored andcommitted
blk-mq: handle already freed tags gracefully in blk_mq_free_rqs
To simplify further changes allow for double calling blk_mq_free_rqs on a queue. Signed-off-by: Ming Lei <ming.lei@redhat.com> [hch: split out from a larger patch] Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Bart Van Assche <bvanassche@acm.org> Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com> Link: https://lore.kernel.org/r/20220308055200.735835-3-hch@lst.de Signed-off-by: Jens Axboe <axboe@kernel.dk>
1 parent 41fa722 commit e02657e

File tree

1 file changed

+3
-0
lines changed

1 file changed

+3
-0
lines changed

block/blk-mq.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3071,6 +3071,9 @@ void blk_mq_free_rqs(struct blk_mq_tag_set *set, struct blk_mq_tags *tags,
30713071
struct blk_mq_tags *drv_tags;
30723072
struct page *page;
30733073

3074+
if (list_empty(&tags->page_list))
3075+
return;
3076+
30743077
if (blk_mq_is_shared_tags(set->flags))
30753078
drv_tags = set->shared_tags;
30763079
else

0 commit comments

Comments
 (0)