ublk_drv: set DMA alignment mask to 3
authorJens Axboe <axboe@kernel.dk>
Sat, 11 May 2024 14:37:52 +0000 (08:37 -0600)
committerJens Axboe <axboe@kernel.dk>
Mon, 13 May 2024 23:51:06 +0000 (17:51 -0600)
By default, this will be 511, as that's the block layer default. But
drivers these days can support memory alignments that aren't tied to
the sector sizes, instead just being limited by what the DMA engine
supports. An example is NVMe, where it's generally set to a 32-bit or
64-bit boundary. As ublk itself doesn't really care, just set it low
enough that we don't run into issues with NVMe where the required
O_DIRECT memory alignment is now more restrictive on ublk than it is
on the underlying device.

This was triggered by spurious -EINVAL returns on O_DIRECT IO on a
setup with ublk managing NVMe devices, which previously worked just
fine on the NVMe device itself. With the alignment relaxed, the test
works fine.

Reviewed-by: Ming Lei <ming.lei@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/ublk_drv.c

index 176657dce3e3850c34d01936c9cd19a68d48f7a1..4e159948c912c20403667cdc8cb767f39d3170b5 100644 (file)
@@ -2178,6 +2178,7 @@ static int ublk_ctrl_start_dev(struct ublk_device *ub, struct io_uring_cmd *cmd)
                .virt_boundary_mask     = p->virt_boundary_mask,
                .max_segments           = USHRT_MAX,
                .max_segment_size       = UINT_MAX,
+               .dma_alignment          = 3,
        };
        struct gendisk *disk;
        int ret = -EINVAL;