summaryrefslogtreecommitdiff
path: root/net
diff options
context:
space:
mode:
authorJan Kara <jack@suse.cz>2021-11-25 14:36:37 +0100
committerJens Axboe <axboe@kernel.dk>2021-11-29 06:38:51 -0700
commit76f1df88bbc2f984eb0418cc90de0a8384e63604 (patch)
treee9bc3f981542f9e5efed2748d6d9562d421b9829 /net
parent44dfa279f117646163db0c8760addb45dd6a0e8c (diff)
downloadlwn-76f1df88bbc2f984eb0418cc90de0a8384e63604.tar.gz
lwn-76f1df88bbc2f984eb0418cc90de0a8384e63604.zip
bfq: Limit number of requests consumed by each cgroup
When cgroup IO scheduling is used with BFQ it does not really provide service differentiation if the cgroup drives a big IO depth. That for example happens with writeback which asynchronously submits lots of IO but it can happen with AIO as well. The problem is that if we have two cgroups that submit IO with different weights, the cgroup with higher weight properly gets more IO time and is able to dispatch more IO. However this causes lower weight cgroup to accumulate more requests inside BFQ and eventually lower weight cgroup consumes most of IO scheduler tags. At that point higher weight cgroup stops getting better service as it is mostly blocked waiting for a scheduler tag while its queues inside BFQ are empty and thus lower weight cgroup gets served. Check how many requests submitting cgroup has allocated in bfq_limit_depth() and if it consumes more requests than what would correspond to its weight limit available depth to 1 so that the cgroup cannot consume many more requests. With this limitation the higher weight cgroup gets proper service even with writeback. Reviewed-by: Michal Koutný <mkoutny@suse.com> Acked-by: Paolo Valente <paolo.valente@linaro.org> Signed-off-by: Jan Kara <jack@suse.cz> Link: https://lore.kernel.org/r/20211125133645.27483-4-jack@suse.cz Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions