diff options
author | Jens Axboe <axboe@kernel.dk> | 2020-09-24 14:55:54 -0600 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2020-09-25 07:41:46 -0600 |
commit | f3cd4850504ff612d0ea77a0aaf29b66c98fcefe (patch) | |
tree | f455b8000f9f4ee17948ac8ab67185a5842f87a9 /fs/io_uring.c | |
parent | 4eb8dded6b82e184c09bb963bea0335fa3f30b55 (diff) | |
download | lwn-f3cd4850504ff612d0ea77a0aaf29b66c98fcefe.tar.gz lwn-f3cd4850504ff612d0ea77a0aaf29b66c98fcefe.zip |
io_uring: ensure open/openat2 name is cleaned on cancelation
If we cancel these requests, we'll leak the memory associated with the
filename. Add them to the table of ops that need cleaning, if
REQ_F_NEED_CLEANUP is set.
Cc: stable@vger.kernel.org
Fixes: e62753e4e292 ("io_uring: call statx directly")
Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'fs/io_uring.c')
-rw-r--r-- | fs/io_uring.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/fs/io_uring.c b/fs/io_uring.c index e6004b92e553..0ab16df31288 100644 --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -5671,6 +5671,11 @@ static void __io_clean_op(struct io_kiocb *req) io_put_file(req, req->splice.file_in, (req->splice.flags & SPLICE_F_FD_IN_FIXED)); break; + case IORING_OP_OPENAT: + case IORING_OP_OPENAT2: + if (req->open.filename) + putname(req->open.filename); + break; } req->flags &= ~REQ_F_NEED_CLEANUP; } |