io_uring: don't rely on weak ->files references
authorJens Axboe <axboe@kernel.dk>
Sun, 13 Sep 2020 19:09:39 +0000 (13:09 -0600)
committerJens Axboe <axboe@kernel.dk>
Mon, 12 Oct 2020 21:03:11 +0000 (15:03 -0600)
commit47f8ab595b4845cef33a51d9ea57c4f3262e6618
treeb6289ea55108e6a76dc1fb204e05786d2d6fc5c1
parent062be0e7ae80f9450d04fc4e4b8911dda02e2a75
io_uring: don't rely on weak ->files references

commit 0f2122045b946241a9e549c2a76cea54fa58a7ff upstream.

Grab actual references to the files_struct. To avoid circular references
issues due to this, we add a per-task note that keeps track of what
io_uring contexts a task has used. When the tasks execs or exits its
assigned files, we cancel requests based on this tracking.

With that, we can grab proper references to the files table, and no
longer need to rely on stashing away ring_fd and ring_file to check
if the ring_fd may have been closed.

Cc: stable@vger.kernel.org # v5.5+
Reviewed-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
fs/exec.c
fs/file.c
fs/io_uring.c
include/linux/io_uring.h [new file with mode: 0644]
include/linux/sched.h
init/init_task.c
kernel/fork.c