mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-07 14:32:23 +00:00
block: invoke blk_mq_exit_sched no matter whether have .exit_sched
We will register debugfs for scheduler no matter whether it have defined callback funciton .exit_sched. So, blk_mq_exit_sched() is always needed to unregister debugfs. Also, q->elevator should be set as NULL after exiting scheduler. For now, since all register scheduler have defined .exit_sched, it will not cause any actual problem. But It will be more reasonable to do this change. Signed-off-by: Yufen Yu <yuyufen@huawei.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
7ea6bf2e6c
commit
dd1c372d65
@ -740,7 +740,6 @@ static void blk_exit_queue(struct request_queue *q)
|
|||||||
if (q->elevator) {
|
if (q->elevator) {
|
||||||
ioc_clear_queue(q);
|
ioc_clear_queue(q);
|
||||||
__elevator_exit(q, q->elevator);
|
__elevator_exit(q, q->elevator);
|
||||||
q->elevator = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -191,8 +191,7 @@ static void elevator_release(struct kobject *kobj)
|
|||||||
void __elevator_exit(struct request_queue *q, struct elevator_queue *e)
|
void __elevator_exit(struct request_queue *q, struct elevator_queue *e)
|
||||||
{
|
{
|
||||||
mutex_lock(&e->sysfs_lock);
|
mutex_lock(&e->sysfs_lock);
|
||||||
if (e->type->ops.exit_sched)
|
blk_mq_exit_sched(q, e);
|
||||||
blk_mq_exit_sched(q, e);
|
|
||||||
mutex_unlock(&e->sysfs_lock);
|
mutex_unlock(&e->sysfs_lock);
|
||||||
|
|
||||||
kobject_put(&e->kobj);
|
kobject_put(&e->kobj);
|
||||||
|
Loading…
Reference in New Issue
Block a user