From: Mikulas Patocka <mpatocka@xxxxxxxxxx> commit 9c0ba14828d64744ccd195c610594ba254a1a9ab upstream. There was a bug report [1] where the user got a warning alignment inconsistency. The user has optimal I/O 16776704 (0xFFFE00) and physical block size 4096. Note that the optimal I/O size may be set by the DMA engines or SCSI controllers and they have no knowledge about the disks attached to them, so the situation with optimal I/O not aligned to physical block size may happen. This commit makes blk_validate_limits round down optimal I/O size to the physical block size of the block device. Closes: https://lore.kernel.org/dm-devel/1426ad71-79b4-4062-b2bf-84278be66a5d@xxxxxxxxxx/T/ [1] Signed-off-by: Mikulas Patocka <mpatocka@xxxxxxxxxx> Fixes: a23634644afc ("block: take io_opt and io_min into account for max_sectors") Cc: stable@xxxxxxxxxxxxxxx # v6.11+ Reviewed-by: Christoph Hellwig <hch@xxxxxx> Link: https://lore.kernel.org/r/3dc0014b-9690-dc38-81c9-4a316a2d4fb2@xxxxxxxxxx Signed-off-by: Jens Axboe <axboe@xxxxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- block/blk-settings.c | 7 +++++++ 1 file changed, 7 insertions(+) --- a/block/blk-settings.c +++ b/block/blk-settings.c @@ -250,6 +250,13 @@ static int blk_validate_limits(struct qu lim->io_min = lim->physical_block_size; /* + * The optimal I/O size may not be aligned to physical block size + * (because it may be limited by dma engines which have no clue about + * block size of the disks attached to them), so we round it down here. + */ + lim->io_opt = round_down(lim->io_opt, lim->physical_block_size); + + /* * max_hw_sectors has a somewhat weird default for historical reason, * but driver really should set their own instead of relying on this * value. Patches currently in stable-queue which might be from mpatocka@xxxxxxxxxx are queue-6.11/blk-settings-round-down-io_opt-to-physical_block_size.patch queue-6.11/dm-bufio-fix-warnings-about-duplicate-slab-caches.patch queue-6.11/dm-cache-fix-warnings-about-duplicate-slab-caches.patch