]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
selftests: ublk: support non-O_DIRECT backing files
authorCaleb Sander Mateos <csander@purestorage.com>
Thu, 8 Jan 2026 09:19:44 +0000 (02:19 -0700)
committerJens Axboe <axboe@kernel.dk>
Mon, 12 Jan 2026 16:16:38 +0000 (09:16 -0700)
A subsequent commit will add support for using a backing file to store
integrity data. Since integrity data is accessed in intervals of
metadata_size, which may be much smaller than a logical block on the
backing device, direct I/O cannot be used. Add an argument to
backing_file_tgt_init() to specify the number of files to open for
direct I/O. The remaining files will use buffered I/O. For now, continue
to request direct I/O for all the files.

Signed-off-by: Caleb Sander Mateos <csander@purestorage.com>
Reviewed-by: Ming Lei <ming.lei@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
tools/testing/selftests/ublk/common.c
tools/testing/selftests/ublk/file_backed.c
tools/testing/selftests/ublk/kublk.h
tools/testing/selftests/ublk/stripe.c

index 01580a6f8519664e5b22638515622df18698e482..d9873d4d50d0dd3827e0633d742b764a89f65444 100644 (file)
@@ -12,7 +12,7 @@ void backing_file_tgt_deinit(struct ublk_dev *dev)
        }
 }
 
-int backing_file_tgt_init(struct ublk_dev *dev)
+int backing_file_tgt_init(struct ublk_dev *dev, unsigned int nr_direct)
 {
        int fd, i;
 
@@ -25,7 +25,7 @@ int backing_file_tgt_init(struct ublk_dev *dev)
 
                ublk_dbg(UBLK_DBG_DEV, "%s: file %d: %s\n", __func__, i, file);
 
-               fd = open(file, O_RDWR | O_DIRECT);
+               fd = open(file, O_RDWR | (i < nr_direct ? O_DIRECT : 0));
                if (fd < 0) {
                        ublk_err("%s: backing file %s can't be opened: %s\n",
                                        __func__, file, strerror(errno));
index c14ce6608696de5012ed38cb88c572c72437aa55..db4c176a4f288e1e81a5b07a2afe0988139adcc3 100644 (file)
@@ -163,7 +163,7 @@ static int ublk_loop_tgt_init(const struct dev_ctx *ctx, struct ublk_dev *dev)
                return -EINVAL;
        }
 
-       ret = backing_file_tgt_init(dev);
+       ret = backing_file_tgt_init(dev, 1);
        if (ret)
                return ret;
 
index 830b49a7716ac6acd1a470d6525516f73954e2f5..96c66b337bc01dc1dfc11e15752bc5906c0b170c 100644 (file)
@@ -462,6 +462,6 @@ extern const struct ublk_tgt_ops stripe_tgt_ops;
 extern const struct ublk_tgt_ops fault_inject_tgt_ops;
 
 void backing_file_tgt_deinit(struct ublk_dev *dev);
-int backing_file_tgt_init(struct ublk_dev *dev);
+int backing_file_tgt_init(struct ublk_dev *dev, unsigned int nr_direct);
 
 #endif
index d4aaf3351d7126ee2c7e32092e204e4b0a156acf..2be1c36438e7811d1887235c0d01374cc87adc42 100644 (file)
@@ -315,7 +315,7 @@ static int ublk_stripe_tgt_init(const struct dev_ctx *ctx, struct ublk_dev *dev)
 
        chunk_shift = ilog2(chunk_size);
 
-       ret = backing_file_tgt_init(dev);
+       ret = backing_file_tgt_init(dev, dev->tgt.nr_backing_files);
        if (ret)
                return ret;