loop: check in LO_FLAGS_DIRECT_IO in loop_default_blocksize
[ Upstream commit f6f9e32fe1e454ae8ac0190b2c2bd6074914beec ] We can't go below the minimum direct I/O size no matter if direct I/O is enabled by passing in an O_DIRECT file descriptor or due to the explicit flag. Now that LO_FLAGS_DIRECT_IO is set earlier after assigning a backing file, loop_default_blocksize can check it instead of the O_DIRECT flag to handle both conditions. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Damien Le Moal <dlemoal@kernel.org> Link: https://lore.kernel.org/r/20250131120120.1315125-4-hch@lst.de Signed-off-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
5b62f941ea
commit
20a53c3689
@@ -916,7 +916,7 @@ static unsigned int loop_default_blocksize(struct loop_device *lo,
|
|||||||
struct block_device *backing_bdev)
|
struct block_device *backing_bdev)
|
||||||
{
|
{
|
||||||
/* In case of direct I/O, match underlying block size */
|
/* In case of direct I/O, match underlying block size */
|
||||||
if ((lo->lo_backing_file->f_flags & O_DIRECT) && backing_bdev)
|
if ((lo->lo_flags & LO_FLAGS_DIRECT_IO) && backing_bdev)
|
||||||
return bdev_logical_block_size(backing_bdev);
|
return bdev_logical_block_size(backing_bdev);
|
||||||
return SECTOR_SIZE;
|
return SECTOR_SIZE;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user