Skip to content

Commit 3c17a34

Browse files
hailan94axboe
authored andcommitted
blk-rq-qos: fix possible debugfs_mutex deadlock
Currently rq-qos debugfs entries are created from rq_qos_add(), while rq_qos_add() can be called while queue is still frozen. This can deadlock because creating new entries can trigger fs reclaim. Fix this problem by delaying creating rq-qos debugfs entries after queue is unfrozen. - For wbt, 1) it can be initialized by default, fix it by calling new helper after wbt_init() from wbt_init_enable_default(); 2) it can be initialized by sysfs, fix it by calling new helper after queue is unfrozen from wbt_set_lat(). - For iocost and iolatency, they can only be initialized by blkcg configuration, however, they don't have debugfs entries for now, hence they are not handled yet. Signed-off-by: Yu Kuai <yukuai@fnnas.com> Reviewed-by: Nilay Shroff <nilay@linux.ibm.com> Reviewed-by: Ming Lei <ming.lei@redhat.com> Reviewed-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Jens Axboe <axboe@kernel.dk>
1 parent 3f0bea9 commit 3c17a34

2 files changed

Lines changed: 12 additions & 8 deletions

File tree

block/blk-rq-qos.c

Lines changed: 0 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -347,13 +347,6 @@ int rq_qos_add(struct rq_qos *rqos, struct gendisk *disk, enum rq_qos_id id,
347347
blk_queue_flag_set(QUEUE_FLAG_QOS_ENABLED, q);
348348

349349
blk_mq_unfreeze_queue(q, memflags);
350-
351-
if (rqos->ops->debugfs_attrs) {
352-
mutex_lock(&q->debugfs_mutex);
353-
blk_mq_debugfs_register_rqos(rqos);
354-
mutex_unlock(&q->debugfs_mutex);
355-
}
356-
357350
return 0;
358351
ebusy:
359352
blk_mq_unfreeze_queue(q, memflags);

block/blk-wbt.c

Lines changed: 12 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -774,6 +774,7 @@ EXPORT_SYMBOL_GPL(wbt_enable_default);
774774

775775
void wbt_init_enable_default(struct gendisk *disk)
776776
{
777+
struct request_queue *q = disk->queue;
777778
struct rq_wb *rwb;
778779

779780
if (!__wbt_enable_default(disk))
@@ -783,8 +784,14 @@ void wbt_init_enable_default(struct gendisk *disk)
783784
if (WARN_ON_ONCE(!rwb))
784785
return;
785786

786-
if (WARN_ON_ONCE(wbt_init(disk, rwb)))
787+
if (WARN_ON_ONCE(wbt_init(disk, rwb))) {
787788
wbt_free(rwb);
789+
return;
790+
}
791+
792+
mutex_lock(&q->debugfs_mutex);
793+
blk_mq_debugfs_register_rq_qos(q);
794+
mutex_unlock(&q->debugfs_mutex);
788795
}
789796

790797
static u64 wbt_default_latency_nsec(struct request_queue *q)
@@ -1008,5 +1015,9 @@ int wbt_set_lat(struct gendisk *disk, s64 val)
10081015
blk_mq_unquiesce_queue(q);
10091016
out:
10101017
blk_mq_unfreeze_queue(q, memflags);
1018+
mutex_lock(&q->debugfs_mutex);
1019+
blk_mq_debugfs_register_rq_qos(q);
1020+
mutex_unlock(&q->debugfs_mutex);
1021+
10111022
return ret;
10121023
}

0 commit comments

Comments
 (0)