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 <[email protected]>
---
 tools/testing/selftests/ublk/common.c      | 4 ++--
 tools/testing/selftests/ublk/file_backed.c | 2 +-
 tools/testing/selftests/ublk/kublk.h       | 2 +-
 tools/testing/selftests/ublk/stripe.c      | 2 +-
 4 files changed, 5 insertions(+), 5 deletions(-)

diff --git a/tools/testing/selftests/ublk/common.c 
b/tools/testing/selftests/ublk/common.c
index 01580a6f8519..d9873d4d50d0 100644
--- a/tools/testing/selftests/ublk/common.c
+++ b/tools/testing/selftests/ublk/common.c
@@ -10,11 +10,11 @@ void backing_file_tgt_deinit(struct ublk_dev *dev)
                fsync(dev->fds[i]);
                close(dev->fds[i]);
        }
 }
 
-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;
 
        assert(dev->nr_fds == 1);
 
@@ -23,11 +23,11 @@ int backing_file_tgt_init(struct ublk_dev *dev)
                unsigned long bytes;
                struct stat st;
 
                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));
                        return -EBADF;
                }
diff --git a/tools/testing/selftests/ublk/file_backed.c 
b/tools/testing/selftests/ublk/file_backed.c
index c14ce6608696..db4c176a4f28 100644
--- a/tools/testing/selftests/ublk/file_backed.c
+++ b/tools/testing/selftests/ublk/file_backed.c
@@ -161,11 +161,11 @@ static int ublk_loop_tgt_init(const struct dev_ctx *ctx, 
struct ublk_dev *dev)
        if (ctx->metadata_size) {
                ublk_err("%s: integrity not supported\n", __func__);
                return -EINVAL;
        }
 
-       ret = backing_file_tgt_init(dev);
+       ret = backing_file_tgt_init(dev, 1);
        if (ret)
                return ret;
 
        if (dev->tgt.nr_backing_files != 1)
                return -EINVAL;
diff --git a/tools/testing/selftests/ublk/kublk.h 
b/tools/testing/selftests/ublk/kublk.h
index 830b49a7716a..96c66b337bc0 100644
--- a/tools/testing/selftests/ublk/kublk.h
+++ b/tools/testing/selftests/ublk/kublk.h
@@ -460,8 +460,8 @@ extern const struct ublk_tgt_ops null_tgt_ops;
 extern const struct ublk_tgt_ops loop_tgt_ops;
 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
diff --git a/tools/testing/selftests/ublk/stripe.c 
b/tools/testing/selftests/ublk/stripe.c
index d4aaf3351d71..2be1c36438e7 100644
--- a/tools/testing/selftests/ublk/stripe.c
+++ b/tools/testing/selftests/ublk/stripe.c
@@ -313,11 +313,11 @@ static int ublk_stripe_tgt_init(const struct dev_ctx 
*ctx, struct ublk_dev *dev)
                return -EINVAL;
        }
 
        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;
 
        if (!dev->tgt.nr_backing_files || dev->tgt.nr_backing_files > NR_STRIPE)
                return -EINVAL;
-- 
2.45.2


Reply via email to