]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
loop: don't require ->write_iter for writable files in loop_configure
authorChristoph Hellwig <hch@lst.de>
Tue, 20 May 2025 13:54:20 +0000 (15:54 +0200)
committerJens Axboe <axboe@kernel.dk>
Tue, 20 May 2025 15:16:23 +0000 (09:16 -0600)
Block devices can be opened read-write even if they can't be written to
for historic reasons.  Remove the check requiring file->f_op->write_iter
when the block devices was opened in loop_configure. The call to
loop_check_backing_file just below ensures the ->write_iter is present
for backing files opened for writing, which is the only check that is
actually needed.

Fixes: f5c84eff634b ("loop: Add sanity check for read/write_iter")
Reported-by: Christian Hesse <mail@eworm.de>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20250520135420.1177312-1-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/loop.c

index b8ba7de08753951c16ff6663375287ea30a5d101..e2b1f377f58563f3dc5476a1f6da1c54a050d64b 100644 (file)
@@ -979,9 +979,6 @@ static int loop_configure(struct loop_device *lo, blk_mode_t mode,
        if (!file)
                return -EBADF;
 
-       if ((mode & BLK_OPEN_WRITE) && !file->f_op->write_iter)
-               return -EINVAL;
-
        error = loop_check_backing_file(file);
        if (error)
                return error;