X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=fio-ini.c;h=9f9dd2a3e7d4061460b83be201d666629afb7716;hp=0c83f70246d4b23f59af47b54a862920db2edc7f;hb=3d60d1ed78b663659967e04cc92e1359bd50fb3a;hpb=8b611c349e3d6f17b4f1aa61cdb0f1ad5a4e1eb9;ds=sidebyside diff --git a/fio-ini.c b/fio-ini.c index 0c83f702..9f9dd2a3 100644 --- a/fio-ini.c +++ b/fio-ini.c @@ -164,7 +164,8 @@ static void put_job(struct thread_data *td) static int add_job(struct thread_data *td, const char *jobname, int prioclass, int prio) { - char *ddir_str[] = { "read", "write", "randread", "randwrite" }; + char *ddir_str[] = { "read", "write", "randread", "randwrite", + "rw", NULL, "randrw" }; struct stat sb; int numjobs, ddir; @@ -229,7 +230,7 @@ static int add_job(struct thread_data *td, const char *jobname, int prioclass, td->min_bs = td->bs; if (td->max_bs == -1U) td->max_bs = td->bs; - if (td_read(td)) + if (td_read(td) && !td_rw(td)) td->verify = 0; if (td->stonewall && td->thread_number > 1) @@ -247,7 +248,7 @@ static int add_job(struct thread_data *td, const char *jobname, int prioclass, if (write_bw_log) setup_log(&td->bw_log); - ddir = td->ddir + (!td->sequential << 1); + ddir = td->ddir + (!td->sequential << 1) + (td->iomix << 2); printf("Client%d (g=%d): rw=%s, prio=%d/%d, odir=%d, bs=%d-%d, rate=%d, ioengine=%s, iodepth=%d\n", td->thread_number, td->groupid, ddir_str[ddir], prioclass, prio, td->odirect, td->min_bs, td->max_bs, td->rate, td->io_engine_name, td->iodepth); /* @@ -540,6 +541,16 @@ static int str_rw_cb(struct thread_data *td, char *mem) td->ddir = DDIR_WRITE; td->sequential = 0; return 0; + } else if (!strncmp(mem, "rw", 2)) { + td->ddir = 0; + td->iomix = 1; + td->sequential = 1; + return 0; + } else if (!strncmp(mem, "randrw", 6)) { + td->ddir = 0; + td->iomix = 1; + td->sequential = 0; + return 0; } fprintf(stderr, "bad data direction: %s\n", mem); @@ -846,6 +857,7 @@ static int fill_def_thread(void) * fill globals */ def_thread.ddir = DDIR_READ; + def_thread.iomix = 0; def_thread.bs = DEF_BS; def_thread.min_bs = -1; def_thread.max_bs = -1;