io_uring/rsrc: get rid of io_mapped_ubuf->folio_mask
authorJens Axboe <axboe@kernel.dk>
Sun, 15 Sep 2024 14:51:20 +0000 (08:51 -0600)
committerJens Axboe <axboe@kernel.dk>
Sun, 15 Sep 2024 15:15:19 +0000 (09:15 -0600)
We don't really need to cache this, let's reclaim 8 bytes from struct
io_mapped_ubuf and just calculate it when we need it. The only hot path
here is io_import_fixed().

Signed-off-by: Jens Axboe <axboe@kernel.dk>
io_uring/rsrc.c
io_uring/rsrc.h

index 9264e555ae59ec2243dd2b6cc90aedd893de5de5..2477995e2d656d470a33756459da6d3f05b3a649 100644 (file)
@@ -988,13 +988,10 @@ static int io_sqe_buffer_register(struct io_ring_ctx *ctx, struct iovec *iov,
        imu->ubuf_end = imu->ubuf + iov->iov_len;
        imu->nr_bvecs = nr_pages;
        imu->folio_shift = PAGE_SHIFT;
-       imu->folio_mask = PAGE_MASK;
-       if (coalesced) {
+       if (coalesced)
                imu->folio_shift = data.folio_shift;
-               imu->folio_mask = ~((1UL << data.folio_shift) - 1);
-       }
        refcount_set(&imu->refs, 1);
-       off = (unsigned long) iov->iov_base & ~imu->folio_mask;
+       off = (unsigned long) iov->iov_base & ((1UL << imu->folio_shift) - 1);
        *pimu = imu;
        ret = 0;
 
@@ -1132,7 +1129,7 @@ int io_import_fixed(int ddir, struct iov_iter *iter,
                        iter->bvec = bvec + seg_skip;
                        iter->nr_segs -= seg_skip;
                        iter->count -= bvec->bv_len + offset;
-                       iter->iov_offset = offset & ~imu->folio_mask;
+                       iter->iov_offset = offset & ((1UL << imu->folio_shift) - 1);
                }
        }
 
index eb4803e473b01302413df546e60f62849eca2c41..e290d2be328545ab9c86abe2e30468082fb59a47 100644 (file)
@@ -46,7 +46,6 @@ struct io_mapped_ubuf {
        unsigned int    nr_bvecs;
        unsigned int    folio_shift;
        unsigned long   acct_pages;
-       unsigned long   folio_mask;
        refcount_t      refs;
        struct bio_vec  bvec[] __counted_by(nr_bvecs);
 };