diff options
author | John Hubbard <jhubbard@nvidia.com> | 2019-08-04 19:32:06 -0700 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2019-08-27 10:41:41 -0600 |
commit | 27c4d3a3252fa661b049b8f57a548bba331133e0 (patch) | |
tree | f7d832d53e9f346038bd9c398f564040c72a824e | |
parent | a55aa89aab90fae7c815b0551b07be37db359d76 (diff) | |
download | lwn-27c4d3a3252fa661b049b8f57a548bba331133e0.tar.gz lwn-27c4d3a3252fa661b049b8f57a548bba331133e0.zip |
fs/io_uring.c: convert put_page() to put_user_page*()
For pages that were retained via get_user_pages*(), release those pages
via the new put_user_page*() routines, instead of via put_page() or
release_pages().
This is part a tree-wide conversion, as described in commit fc1d8e7cca2d
("mm: introduce put_user_page*(), placeholder versions").
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Cc: Jens Axboe <axboe@kernel.dk>
Cc: linux-fsdevel@vger.kernel.org
Cc: linux-block@vger.kernel.org
Signed-off-by: John Hubbard <jhubbard@nvidia.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r-- | fs/io_uring.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/fs/io_uring.c b/fs/io_uring.c index cfb48bd088e1..08d614c6b60e 100644 --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -2845,7 +2845,7 @@ static int io_sqe_buffer_unregister(struct io_ring_ctx *ctx) struct io_mapped_ubuf *imu = &ctx->user_bufs[i]; for (j = 0; j < imu->nr_bvecs; j++) - put_page(imu->bvec[j].bv_page); + put_user_page(imu->bvec[j].bv_page); if (ctx->account_mem) io_unaccount_mem(ctx->user, imu->nr_bvecs); @@ -2989,10 +2989,8 @@ static int io_sqe_buffer_register(struct io_ring_ctx *ctx, void __user *arg, * if we did partial map, or found file backed vmas, * release any pages we did get */ - if (pret > 0) { - for (j = 0; j < pret; j++) - put_page(pages[j]); - } + if (pret > 0) + put_user_pages(pages, pret); if (ctx->account_mem) io_unaccount_mem(ctx->user, nr_pages); kvfree(imu->bvec); |