summaryrefslogtreecommitdiffstats
path: root/block/blk-cgroup.c
diff options
context:
space:
mode:
authorChunguang Xu <brookxu@tencent.com>2021-01-25 06:05:28 +0100
committerJens Axboe <axboe@kernel.dk>2021-01-26 21:14:30 +0100
commit49d1822bc05e702be1665ffc2092ec5711e77491 (patch)
tree7eac30c97fadabfa253974bdba1609706a19f36d /block/blk-cgroup.c
parentblock: unexport truncate_bdev_range (diff)
downloadlinux-49d1822bc05e702be1665ffc2092ec5711e77491.tar.xz
linux-49d1822bc05e702be1665ffc2092ec5711e77491.zip
blkcg: delete redundant get/put operations for queue
When calling blkcg_schedule_throttle(), for the same queue, redundant get/put operations can be removed. Signed-off-by: Chunguang Xu <brookxu@tencent.com> Acked-by: Tejun Heo <tj@kernel.org> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/blk-cgroup.c')
-rw-r--r--block/blk-cgroup.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c
index 3465d6ee708e..02ce2058c14b 100644
--- a/block/blk-cgroup.c
+++ b/block/blk-cgroup.c
@@ -1757,12 +1757,15 @@ void blkcg_schedule_throttle(struct request_queue *q, bool use_memdelay)
if (unlikely(current->flags & PF_KTHREAD))
return;
- if (!blk_get_queue(q))
- return;
+ if (current->throttle_queue != q) {
+ if (!blk_get_queue(q))
+ return;
+
+ if (current->throttle_queue)
+ blk_put_queue(current->throttle_queue);
+ current->throttle_queue = q;
+ }
- if (current->throttle_queue)
- blk_put_queue(current->throttle_queue);
- current->throttle_queue = q;
if (use_memdelay)
current->use_memdelay = use_memdelay;
set_notify_resume(current);