Skip to content

Commit a180544

Browse files
calebsanderaxboe
authored andcommitted
selftests: ublk: support non-O_DIRECT backing files
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>
1 parent 24f8a44 commit a180544

4 files changed

Lines changed: 5 additions & 5 deletions

File tree

tools/testing/selftests/ublk/common.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,7 @@ void backing_file_tgt_deinit(struct ublk_dev *dev)
1212
}
1313
}
1414

15-
int backing_file_tgt_init(struct ublk_dev *dev)
15+
int backing_file_tgt_init(struct ublk_dev *dev, unsigned int nr_direct)
1616
{
1717
int fd, i;
1818

@@ -25,7 +25,7 @@ int backing_file_tgt_init(struct ublk_dev *dev)
2525

2626
ublk_dbg(UBLK_DBG_DEV, "%s: file %d: %s\n", __func__, i, file);
2727

28-
fd = open(file, O_RDWR | O_DIRECT);
28+
fd = open(file, O_RDWR | (i < nr_direct ? O_DIRECT : 0));
2929
if (fd < 0) {
3030
ublk_err("%s: backing file %s can't be opened: %s\n",
3131
__func__, file, strerror(errno));

tools/testing/selftests/ublk/file_backed.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -163,7 +163,7 @@ static int ublk_loop_tgt_init(const struct dev_ctx *ctx, struct ublk_dev *dev)
163163
return -EINVAL;
164164
}
165165

166-
ret = backing_file_tgt_init(dev);
166+
ret = backing_file_tgt_init(dev, 1);
167167
if (ret)
168168
return ret;
169169

tools/testing/selftests/ublk/kublk.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -462,6 +462,6 @@ extern const struct ublk_tgt_ops stripe_tgt_ops;
462462
extern const struct ublk_tgt_ops fault_inject_tgt_ops;
463463

464464
void backing_file_tgt_deinit(struct ublk_dev *dev);
465-
int backing_file_tgt_init(struct ublk_dev *dev);
465+
int backing_file_tgt_init(struct ublk_dev *dev, unsigned int nr_direct);
466466

467467
#endif

tools/testing/selftests/ublk/stripe.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -315,7 +315,7 @@ static int ublk_stripe_tgt_init(const struct dev_ctx *ctx, struct ublk_dev *dev)
315315

316316
chunk_shift = ilog2(chunk_size);
317317

318-
ret = backing_file_tgt_init(dev);
318+
ret = backing_file_tgt_init(dev, dev->tgt.nr_backing_files);
319319
if (ret)
320320
return ret;
321321

0 commit comments

Comments
 (0)