We need to do a little bit more to make sure that the writes land on the offsets that were trimmed. We only have a single random seed for offsets. So we need to just use the offset from trim commands when issuing writes. When we have variable block sizes we need to make sure that the trim and write commands are the same size. When randommap is enabled we have to let it adjust the block size for trim commands to make sure that the trim command does not touch any blocks that have already been touched. For sizes of write commands just use the size of the trim command. Fixes: c16dc793a3c45780f67ce65244b6e91323dee014 "Add randtrimwrite data direction" Signed-off-by: Vincent Fu <vincent.fu@xxxxxxxxxxx> --- io_ddir.h | 2 ++ io_u.c | 14 +++++++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/io_ddir.h b/io_ddir.h index 7227e9ee..217eb628 100644 --- a/io_ddir.h +++ b/io_ddir.h @@ -52,6 +52,8 @@ enum td_ddir { #define file_randommap(td, f) (!(td)->o.norandommap && fio_file_axmap((f))) #define td_trimwrite(td) (((td)->o.td_ddir & TD_DDIR_TRIMWRITE) \ == TD_DDIR_TRIMWRITE) +#define td_randtrimwrite(td) (((td)->o.td_ddir & TD_DDIR_RANDTRIMWRITE) \ + == TD_DDIR_RANDTRIMWRITE) static inline int ddir_sync(enum fio_ddir ddir) { diff --git a/io_u.c b/io_u.c index eec378dd..3f6c60ee 100644 --- a/io_u.c +++ b/io_u.c @@ -417,7 +417,13 @@ static int get_next_block(struct thread_data *td, struct io_u *io_u, b = offset = -1ULL; - if (rw_seq) { + if (td_randtrimwrite(td) && ddir == DDIR_WRITE) { + /* don't mark randommap for these writes */ + io_u_set(td, io_u, IO_U_F_BUSY_OK); + offset = f->last_start[DDIR_TRIM]; + *is_random = true; + ret = 0; + } else if (rw_seq) { if (td_random(td)) { if (should_do_random(td, ddir)) { ret = get_next_rand_block(td, f, ddir, &b); @@ -530,6 +536,12 @@ static unsigned long long get_next_buflen(struct thread_data *td, struct io_u *i assert(ddir_rw(ddir)); + if (td_randtrimwrite(td) && ddir == DDIR_WRITE) { + struct fio_file *f = io_u->file; + + return f->last_pos[DDIR_TRIM] - f->last_start[DDIR_TRIM]; + } + if (td->o.bs_is_seq_rand) ddir = is_random ? DDIR_WRITE : DDIR_READ; -- 2.25.1