X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=fio.h;h=62ff7abba5f1a25d7c52ecb5aa1e3a877464161a;hb=947569c1e49760843343fb4af56901bc611328c3;hp=0da0bc5d97442544d2b2269b32c7b8ae64c79ba3;hpb=78475ac3b9453eff01c34778d70a2aed4aecffe8;p=fio.git diff --git a/fio.h b/fio.h index 0da0bc5d..62ff7abb 100644 --- a/fio.h +++ b/fio.h @@ -41,6 +41,7 @@ #include "flow.h" #include "io_u_queue.h" #include "workqueue.h" +#include "steadystate.h" #ifdef CONFIG_SOLARISAIO #include @@ -109,6 +110,13 @@ enum { RATE_PROCESS_POISSON = 1, }; +enum { + F_ADV_NONE = 0, + F_ADV_TYPE, + F_ADV_RANDOM, + F_ADV_SEQUENTIAL, +}; + /* * Per-thread/process specific data. Only used for the network client * for now. @@ -269,10 +277,10 @@ struct thread_data { * Rate state */ uint64_t rate_bps[DDIR_RWDIR_CNT]; - unsigned long rate_next_io_time[DDIR_RWDIR_CNT]; + uint64_t rate_next_io_time[DDIR_RWDIR_CNT]; unsigned long rate_bytes[DDIR_RWDIR_CNT]; unsigned long rate_blocks[DDIR_RWDIR_CNT]; - unsigned long rate_io_issue_bytes[DDIR_RWDIR_CNT]; + unsigned long long rate_io_issue_bytes[DDIR_RWDIR_CNT]; struct timeval lastrate[DDIR_RWDIR_CNT]; int64_t last_usec; struct frand_state poisson_state; @@ -311,6 +319,7 @@ struct thread_data { struct timeval start; /* start of this loop */ struct timeval epoch; /* time job was started */ + unsigned long long unix_epoch; /* Time job was started, unix epoch based. */ struct timeval last_issue; long time_offset; struct timeval tv_cache; @@ -394,6 +403,8 @@ struct thread_data { void *pinned_mem; + struct steadystate_data ss; + char verror[FIO_VERROR_SIZE]; }; @@ -475,7 +486,7 @@ static inline void fio_ro_check(const struct thread_data *td, struct io_u *io_u) assert(!(io_u->ddir == DDIR_WRITE && !td_write(td))); } -#define REAL_MAX_JOBS 2048 +#define REAL_MAX_JOBS 4096 static inline int should_fsync(struct thread_data *td) { @@ -524,6 +535,13 @@ extern uintptr_t page_size; extern int initialize_fio(char *envp[]); extern void deinitialize_fio(void); +#define N2S_NONE 0 +#define N2S_BITPERSEC 1 /* match unit_base for bit rates */ +#define N2S_PERSEC 2 +#define N2S_BIT 3 +#define N2S_BYTE 4 +#define N2S_BYTEPERSEC 8 /* match unit_base for byte rates */ + #define FIO_GETOPT_JOB 0x89000000 #define FIO_GETOPT_IOENGINE 0x98000000 #define FIO_NR_OPTIONS (FIO_MAX_OPTS + 128) @@ -563,7 +581,8 @@ enum { static inline enum fio_ioengine_flags td_ioengine_flags(struct thread_data *td) { - return (td->flags >> TD_ENG_FLAG_SHIFT) & TD_ENG_FLAG_MASK; + return (enum fio_ioengine_flags) + ((td->flags >> TD_ENG_FLAG_SHIFT) & TD_ENG_FLAG_MASK); } static inline void td_set_ioengine_flags(struct thread_data *td) @@ -571,9 +590,10 @@ static inline void td_set_ioengine_flags(struct thread_data *td) td->flags |= (td->io_ops->flags << TD_ENG_FLAG_SHIFT); } -static inline bool td_ioengine_flagged(struct thread_data *td, unsigned int val) +static inline bool td_ioengine_flagged(struct thread_data *td, + enum fio_ioengine_flags flags) { - return ((td->flags >> TD_ENG_FLAG_SHIFT) & val) != 0; + return ((td->flags >> TD_ENG_FLAG_SHIFT) & flags) != 0; } extern void td_set_runstate(struct thread_data *, int); @@ -585,7 +605,7 @@ extern const char *runstate_to_name(int runstate); * Allow 60 seconds for a job to quit on its own, otherwise reap with * a vengeance. */ -#define FIO_REAP_TIMEOUT 60 +#define FIO_REAP_TIMEOUT 300 #define TERMINATE_ALL (-1U) extern void fio_terminate_threads(unsigned int);