diff options
| author | Jens Axboe <axboe@kernel.dk> | 2021-09-27 10:04:10 -0600 | 
|---|---|---|
| committer | Jens Axboe <axboe@kernel.dk> | 2021-09-27 11:03:43 -0600 | 
| commit | 78f8876c2d9f6fdeb9ff62ed1911505156cd7b3d (patch) | |
| tree | 48df289241a4c4c339cb74be7cd6cfa75679d650 /lib/mpi/mpi-bit.c | |
| parent | 7df778be2f61e1a23002d1f2f5d6aaf702771eb8 (diff) | |
io-wq: exclusively gate signal based exit on get_signal() return
io-wq threads block all signals, except SIGKILL and SIGSTOP. We should not
need any extra checking of signal_pending or fatal_signal_pending, rely
exclusively on whether or not get_signal() tells us to exit.
The original debugging of this issue led to the false positive that we
were exiting on non-fatal signals, but that is not the case. The issue
was around races with nr_workers accounting.
Fixes: 87c169665578 ("io-wq: ensure we exit if thread group is exiting")
Fixes: 15e20db2e0ce ("io-wq: only exit on fatal signals")
Reported-by: Eric W. Biederman <ebiederm@xmission.com>
Reported-by: Linus Torvalds <torvalds@linux-foundation.org>
Acked-by: "Eric W. Biederman" <ebiederm@xmission.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'lib/mpi/mpi-bit.c')
0 files changed, 0 insertions, 0 deletions
