diff options
author | Yang Yang <yang.yang@vivo.com> | 2021-02-05 10:13:10 +0100 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2021-02-22 20:37:57 +0100 |
commit | ffa772cfe9356ce94d3061335c2681f60e7c1c5b (patch) | |
tree | eb1b8f17f4e31786960caf70b621150761f799fd /net/sched/act_vlan.c | |
parent | loop: fix I/O error on fsync() in detached loop devices (diff) | |
download | linux-ffa772cfe9356ce94d3061335c2681f60e7c1c5b.tar.xz linux-ffa772cfe9356ce94d3061335c2681f60e7c1c5b.zip |
kyber: introduce kyber_depth_updated()
Hang occurs when user changes the scheduler queue depth, by writing to
the 'nr_requests' sysfs file of that device.
The details of the environment that we found the problem are as follows:
an eMMC block device
total driver tags: 16
default queue_depth: 32
kqd->async_depth initialized in kyber_init_sched() with queue_depth=32
Then we change queue_depth to 256, by writing to the 'nr_requests' sysfs
file. But kqd->async_depth don't be updated after queue_depth changes.
Now the value of async depth is too small for queue_depth=256, this may
cause hang.
This patch introduces kyber_depth_updated(), so that kyber can update
async depth when queue depth changes.
Signed-off-by: Yang Yang <yang.yang@vivo.com>
Reviewed-by: Omar Sandoval <osandov@fb.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'net/sched/act_vlan.c')
0 files changed, 0 insertions, 0 deletions