diff options
| author | Jens Axboe <axboe@kernel.dk> | 2019-08-22 07:19:11 +0300 | 
|---|---|---|
| committer | Jens Axboe <axboe@kernel.dk> | 2019-08-23 00:32:28 +0300 | 
| commit | 08f5439f1df25a6cf6cf4c72cf6c13025599ce67 (patch) | |
| tree | 13c09fd0f29e89e733080f92239c76f97e6a018d /scripts/gcc-plugins/structleak_plugin.c | |
| parent | 7035eef4496d95b69b0bc18e0bced09304e0afdf (diff) | |
| download | linux-08f5439f1df25a6cf6cf4c72cf6c13025599ce67.tar.xz | |
io_uring: add need_resched() check in inner poll loop
The outer poll loop checks for whether we need to reschedule, and
returns to userspace if we do. However, it's possible to get stuck
in the inner loop as well, if the CPU we are running on needs to
reschedule to finish the IO work.
Add the need_resched() check in the inner loop as well. This fixes
a potential hang if the kernel is configured with
CONFIG_PREEMPT_VOLUNTARY=y.
Reported-by: Sagi Grimberg <sagi@grimberg.me>
Reviewed-by: Sagi Grimberg <sagi@grimberg.me>
Tested-by: Sagi Grimberg <sagi@grimberg.me>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'scripts/gcc-plugins/structleak_plugin.c')
0 files changed, 0 insertions, 0 deletions
