X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=io_ddir.h;h=a23ea626be83d9877a3c670719e7b3ef160124a4;hp=3d9a2050dfdc58db6e82ebaade22f79624ea957a;hb=ec803e97e616d8a410d760368c478b683625842a;hpb=d6aed795f2e3e403828abf60874dd2d6e8342a1b diff --git a/io_ddir.h b/io_ddir.h index 3d9a2050..a23ea626 100644 --- a/io_ddir.h +++ b/io_ddir.h @@ -3,19 +3,70 @@ enum fio_ddir { DDIR_READ = 0, - DDIR_WRITE, - DDIR_SYNC, + 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, }; +static inline const char *io_ddir_name(enum fio_ddir ddir) +{ + const char *name[] = { "read", "write", "trim", "sync", "datasync", + "sync_file_range", "write", }; + + if (ddir < DDIR_LAST) + return name[ddir]; + + return "invalid"; +} + enum td_ddir { TD_DDIR_READ = 1 << 0, TD_DDIR_WRITE = 1 << 1, TD_DDIR_RAND = 1 << 2, + TD_DDIR_TRIM = 1 << 3, TD_DDIR_RW = TD_DDIR_READ | TD_DDIR_WRITE, TD_DDIR_RANDREAD = TD_DDIR_READ | TD_DDIR_RAND, 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, }; +#define td_read(td) ((td)->o.td_ddir & TD_DDIR_READ) +#define td_write(td) ((td)->o.td_ddir & TD_DDIR_WRITE) +#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_axmap) + +static inline int ddir_sync(enum fio_ddir ddir) +{ + return ddir == DDIR_SYNC || ddir == DDIR_DATASYNC || + ddir == DDIR_SYNC_FILE_RANGE; +} + +static inline int ddir_rw(enum fio_ddir ddir) +{ + return ddir == DDIR_READ || ddir == DDIR_WRITE || ddir == DDIR_TRIM; +} + +static inline const char *ddir_str(enum td_ddir ddir) +{ + const char *ddir_str[] = { NULL, "read", "write", "rw", NULL, + "randread", "randwrite", "randrw", + "trim", NULL, NULL, NULL, "randtrim" }; + + return ddir_str[ddir]; +} + +#define ddir_trim(ddir) ((ddir) == DDIR_TRIM) + +#define ddir_rw_sum(arr) \ + ((arr)[DDIR_READ] + (arr)[DDIR_WRITE] + (arr)[DDIR_TRIM]) + #endif