Files
linux/fs
Jens Axboe d4e7cd36a9 io_uring: sanitize double poll handling
There's a bit of confusion on the matching pairs of poll vs double poll,
depending on if the request is a pure poll (IORING_OP_POLL_ADD) or
poll driven retry.

Add io_poll_get_double() that returns the double poll waitqueue, if any,
and io_poll_get_single() that returns the original poll waitqueue. With
that, remove the argument to io_poll_remove_double().

Finally ensure that wait->private is cleared once the double poll handler
has run, so that remove knows it's already been seen.

Cc: stable@vger.kernel.org # v5.8
Reported-by: syzbot+7f617d4a9369028b8a2c@syzkaller.appspotmail.com
Fixes: 18bceab101 ("io_uring: allow POLL_ADD with double poll_wait() users")
Signed-off-by: Jens Axboe <axboe@kernel.dk>
2020-08-15 11:48:18 -07:00
..
2020-03-27 09:29:56 +00:00
2020-07-15 15:49:04 -07:00
2020-07-08 08:27:56 +02:00
2020-07-08 10:29:43 -07:00
2020-07-08 10:29:43 -07:00
2020-07-08 16:20:01 -06:00
2020-05-14 16:44:25 +02:00
2020-02-07 14:48:35 -05:00
2020-07-25 09:47:44 -06:00
2020-03-05 21:00:40 -05:00
2020-05-14 16:44:24 +02:00
2020-07-08 08:27:57 +02:00
2020-05-14 16:44:24 +02:00
2020-04-09 15:33:09 -04:00