X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=io_ddir.h;h=217eb62862efb74938193da9e2f4b786282a6cf1;hb=afb34fb175d1a2de35120807feb6f5af403c581a;hp=d13c6b1ed6bbf7c23bf68760b71decd40e323e1e;hpb=51ede0b1e9c9b570b942b50b44d0455183a0d5ec;p=fio.git diff --git a/io_ddir.h b/io_ddir.h index d13c6b1e..217eb628 100644 --- a/io_ddir.h +++ b/io_ddir.h @@ -5,14 +5,31 @@ enum fio_ddir { DDIR_READ = 0, DDIR_WRITE = 1, DDIR_TRIM = 2, - DDIR_RWDIR_CNT = 3, DDIR_SYNC = 3, DDIR_DATASYNC, DDIR_SYNC_FILE_RANGE, DDIR_WAIT, + DDIR_LAST, DDIR_INVAL = -1, + + DDIR_RWDIR_CNT = 3, + DDIR_RWDIR_SYNC_CNT = 4, }; +#define for_each_rw_ddir(ddir) for (enum fio_ddir ddir = 0; ddir < DDIR_RWDIR_CNT; ddir++) + +static inline const char *io_ddir_name(enum fio_ddir ddir) +{ + static const char *name[] = { "read", "write", "trim", "sync", + "datasync", "sync_file_range", + "wait", }; + + if (ddir >= 0 && ddir < DDIR_LAST) + return name[ddir]; + + return "invalid"; +} + enum td_ddir { TD_DDIR_READ = 1 << 0, TD_DDIR_WRITE = 1 << 1, @@ -23,6 +40,8 @@ enum td_ddir { TD_DDIR_RANDWRITE = TD_DDIR_WRITE | TD_DDIR_RAND, TD_DDIR_RANDRW = TD_DDIR_RW | TD_DDIR_RAND, TD_DDIR_RANDTRIM = TD_DDIR_TRIM | TD_DDIR_RAND, + TD_DDIR_TRIMWRITE = TD_DDIR_TRIM | TD_DDIR_WRITE, + TD_DDIR_RANDTRIMWRITE = TD_DDIR_RANDTRIM | TD_DDIR_WRITE, }; #define td_read(td) ((td)->o.td_ddir & TD_DDIR_READ) @@ -30,7 +49,11 @@ enum td_ddir { #define td_trim(td) ((td)->o.td_ddir & TD_DDIR_TRIM) #define td_rw(td) (((td)->o.td_ddir & TD_DDIR_RW) == TD_DDIR_RW) #define td_random(td) ((td)->o.td_ddir & TD_DDIR_RAND) -#define file_randommap(td, f) (!(td)->o.norandommap && (f)->io_bitmap) +#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) { @@ -43,7 +66,15 @@ static inline int ddir_rw(enum fio_ddir ddir) return ddir == DDIR_READ || ddir == DDIR_WRITE || ddir == DDIR_TRIM; } -#define ddir_trim(ddir) ((ddir) == DDIR_TRIM) +static inline const char *ddir_str(enum td_ddir ddir) +{ + static const char *__str[] = { NULL, "read", "write", "rw", "rand", + "randread", "randwrite", "randrw", + "trim", NULL, "trimwrite", NULL, "randtrim", + NULL, "randtrimwrite" }; + + return __str[ddir]; +} #define ddir_rw_sum(arr) \ ((arr)[DDIR_READ] + (arr)[DDIR_WRITE] + (arr)[DDIR_TRIM])