X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=options.c;h=f8e89f381bbd171fbed1877066f33c744dd7a6e1;hb=22d662132577b9950753369c94c2662c64ad7385;hp=4f30f2c1991aaf8769e2802d4dceef7cb0d83a34;hpb=d2f3ac3592a5674fefa082cb439cc72355d2fed0;p=fio.git diff --git a/options.c b/options.c index 4f30f2c1..f8e89f38 100644 --- a/options.c +++ b/options.c @@ -32,7 +32,7 @@ static int str_rw_cb(void *data, const char *str) struct thread_data *td = data; char *nr = get_opt_postfix(str); - td->o.ddir_nr = 0; + td->o.ddir_nr = 1; if (nr) td->o.ddir_nr = atoi(nr); @@ -531,8 +531,20 @@ static struct fio_option options[] = { .oval = VERIFY_MD5, .help = "Use md5 checksums for verification", }, + { + .ival = "null", + .oval = VERIFY_NULL, + .help = "Pretend to verify", + }, }, }, + { + .name = "verifysort", + .type = FIO_OPT_BOOL, + .off1 = td_var_offset(verifysort), + .help = "Sort written verify blocks for read back", + .def = "1", + }, { .name = "write_iolog", .type = FIO_OPT_STR_STORE, @@ -864,3 +876,41 @@ int fio_show_option_help(const char *opt) { return show_cmd_help(options, opt); } + +static void __options_mem(struct thread_data *td, int alloc) +{ + struct thread_options *o = &td->o; + struct fio_option *opt; + char **ptr; + int i; + + for (i = 0, opt = &options[0]; opt->name; i++, opt = &options[i]) { + if (opt->type != FIO_OPT_STR_STORE) + continue; + + ptr = (void *) o + opt->off1; + if (*ptr) { + if (alloc) + *ptr = strdup(*ptr); + else { + free(*ptr); + *ptr = NULL; + } + } + } +} + +/* + * dupe FIO_OPT_STR_STORE options + */ +void options_mem_dupe(struct thread_data *td) +{ + __options_mem(td, 1); +} + +void options_mem_free(struct thread_data fio_unused *td) +{ +#if 0 + __options_mem(td, 0); +#endif +}