return add_dir_files(td, td->o.opendir);
}
+static int str_header_offset_cb(void *data, unsigned int *off)
+{
+ struct thread_data *td = data;
+ if (*off && *off < sizeof(struct verify_header)) {
+ log_err("fio: header_offset too small\n");
+ return 1;
+ }
+ td->o.header_offset = *off;
+ return 0;
+}
+
#define __stringify_1(x) #x
#define __stringify(x) __stringify_1(x)
.oval = VERIFY_NONE,
.help = "Don't do IO verification",
},
+ { .ival = "md5",
+ .oval = VERIFY_MD5,
+ .help = "Use md5 checksums for verification",
+ },
{ .ival = "crc64",
.oval = VERIFY_CRC64,
.help = "Use crc64 checksums for verification",
.oval = VERIFY_CRC7,
.help = "Use crc7 checksums for verification",
},
- { .ival = "md5",
- .oval = VERIFY_MD5,
- .help = "Use md5 checksums for verification",
- },
{
.ival = "null",
.oval = VERIFY_NULL,
.help = "Sort written verify blocks for read back",
.def = "1",
},
+ {
+ .name = "header_interval",
+ .type = FIO_OPT_STR_VAL_INT,
+ .off1 = td_var_offset(header_interval),
+ .minval = 2 * sizeof(struct verify_header),
+ .help = "Store buffer header every N bytes",
+ },
+ {
+ .name = "header_offset",
+ .type = FIO_OPT_STR_VAL_INT,
+ .help = "Offset header location by N bytes",
+ .def = "0",
+ .cb = str_header_offset_cb,
+ },
{
.name = "write_iolog",
.type = FIO_OPT_STR_STORE,