| #include "../fio.h" |
| #include "../profile.h" |
| #include "../parse.h" |
| |
| static unsigned long long size; |
| static unsigned int loops = 1; |
| static unsigned int bs = 4096; |
| static unsigned int nthreads = 1; |
| static char *dir; |
| |
| static char sz_idx[80], bs_idx[80], loop_idx[80], dir_idx[80], t_idx[80]; |
| |
| static const char *tb_opts[] = { |
| "buffered=0", sz_idx, bs_idx, loop_idx, dir_idx, t_idx, |
| "timeout=600", "group_reporting", "thread", "overwrite=1", |
| "filename=.fio.tio.1:.fio.tio.2:.fio.tio.3:.fio.tio.4", |
| "ioengine=sync", |
| "name=seqwrite", "rw=write", "end_fsync=1", |
| "name=randwrite", "stonewall", "rw=randwrite", "end_fsync=1", |
| "name=seqread", "stonewall", "rw=read", |
| "name=randread", "stonewall", "rw=randread", NULL, |
| }; |
| |
| struct tiobench_options { |
| unsigned int pad; |
| unsigned long long size; |
| unsigned int loops; |
| unsigned int bs; |
| unsigned int nthreads; |
| char *dir; |
| }; |
| |
| static struct tiobench_options tiobench_options; |
| |
| static struct fio_option options[] = { |
| { |
| .name = "size", |
| .lname = "Tiobench size", |
| .type = FIO_OPT_STR_VAL, |
| .off1 = offsetof(struct tiobench_options, size), |
| .help = "Size in MB", |
| .category = FIO_OPT_C_PROFILE, |
| .group = FIO_OPT_G_TIOBENCH, |
| }, |
| { |
| .name = "block", |
| .lname = "Tiobench block", |
| .type = FIO_OPT_INT, |
| .off1 = offsetof(struct tiobench_options, bs), |
| .help = "Block size in bytes", |
| .def = "4k", |
| .category = FIO_OPT_C_PROFILE, |
| .group = FIO_OPT_G_TIOBENCH, |
| }, |
| { |
| .name = "numruns", |
| .lname = "Tiobench numruns", |
| .type = FIO_OPT_INT, |
| .off1 = offsetof(struct tiobench_options, loops), |
| .help = "Number of runs", |
| .category = FIO_OPT_C_PROFILE, |
| .group = FIO_OPT_G_TIOBENCH, |
| }, |
| { |
| .name = "dir", |
| .lname = "Tiobench directory", |
| .type = FIO_OPT_STR_STORE, |
| .off1 = offsetof(struct tiobench_options, dir), |
| .help = "Test directory", |
| .category = FIO_OPT_C_PROFILE, |
| .group = FIO_OPT_G_TIOBENCH, |
| }, |
| { |
| .name = "threads", |
| .lname = "Tiobench threads", |
| .type = FIO_OPT_INT, |
| .off1 = offsetof(struct tiobench_options, nthreads), |
| .help = "Number of Threads", |
| .category = FIO_OPT_C_PROFILE, |
| .group = FIO_OPT_G_TIOBENCH, |
| }, |
| { |
| .name = NULL, |
| }, |
| }; |
| |
| /* |
| * Fill our private options into the command line |
| */ |
| static int tb_prep_cmdline(void) |
| { |
| /* |
| * tiobench uses size as MB, so multiply up |
| */ |
| size *= 1024 * 1024ULL; |
| if (size) |
| sprintf(sz_idx, "size=%llu", size); |
| else |
| strcpy(sz_idx, "size=4*1024*$mb_memory"); |
| |
| sprintf(bs_idx, "bs=%u", bs); |
| sprintf(loop_idx, "loops=%u", loops); |
| |
| if (dir) |
| sprintf(dir_idx, "directory=%s", dir); |
| else |
| sprintf(dir_idx, "directory=./"); |
| |
| sprintf(t_idx, "numjobs=%u", nthreads); |
| return 0; |
| } |
| |
| static struct profile_ops tiobench_profile = { |
| .name = "tiobench", |
| .desc = "tiotest/tiobench benchmark", |
| .prep_cmd = tb_prep_cmdline, |
| .cmdline = tb_opts, |
| .options = options, |
| .opt_data = &tiobench_options, |
| }; |
| |
| static void fio_init tiobench_register(void) |
| { |
| if (register_profile(&tiobench_profile)) |
| log_err("fio: failed to register profile 'tiobench'\n"); |
| } |
| |
| static void fio_exit tiobench_unregister(void) |
| { |
| unregister_profile(&tiobench_profile); |
| } |