X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=fio.h;h=bdc1708123e89f73f704fecdd34301f76f1ca37e;hb=9f988e2ebb3bff7087cc9681a54bd7f0d0e42140;hp=b19101c20a4924892610bd78b0f6d645f3b93e9b;hpb=d529ee1932bc85598900a3ef62f01293af87fbd8;p=fio.git diff --git a/fio.h b/fio.h index b19101c2..bdc17081 100644 --- a/fio.h +++ b/fio.h @@ -28,6 +28,8 @@ #include "io_ddir.h" #include "ioengine.h" #include "iolog.h" +#include "profiles.h" +#include "helpers.h" #ifdef FIO_HAVE_GUASI #include @@ -42,6 +44,7 @@ struct group_run_stats { unsigned long long max_bw[2], min_bw[2]; unsigned long long io_kb[2]; unsigned long long agg[2]; + unsigned int kb_base; }; /* @@ -62,6 +65,8 @@ enum fio_memtype { #define FIO_IO_U_LAT_U_NR 10 #define FIO_IO_U_LAT_M_NR 12 +#define MAX_PATTERN_SIZE 512 + struct thread_stat { char *name; char *verror; @@ -118,6 +123,8 @@ struct thread_stat { unsigned continue_on_error; unsigned long total_err_count; int first_error; + + unsigned int kb_base; }; struct bssplit { @@ -134,6 +141,7 @@ struct thread_options { char *opendir; char *ioengine; enum td_ddir td_ddir; + unsigned int kb_base; unsigned int ddir_nr; unsigned int iodepth; unsigned int iodepth_low; @@ -171,9 +179,10 @@ struct thread_options { unsigned int verifysort; unsigned int verify_interval; unsigned int verify_offset; - unsigned int verify_pattern; + char verify_pattern[MAX_PATTERN_SIZE]; unsigned int verify_pattern_bytes; unsigned int verify_fatal; + unsigned int verify_async; unsigned int use_thread; unsigned int unlink; unsigned int do_disk_util; @@ -209,6 +218,8 @@ struct thread_options { unsigned int numjobs; os_cpu_mask_t cpumask; unsigned int cpumask_set; + os_cpu_mask_t verify_cpumask; + unsigned int verify_cpumask_set; unsigned int iolog; unsigned int rwmixcycle; unsigned int rwmix[2]; @@ -216,6 +227,7 @@ struct thread_options { unsigned int file_service_type; unsigned int group_reporting; unsigned int fadvise_hint; + unsigned int fallocate; unsigned int zero_buffers; unsigned int refill_buffers; unsigned int time_based; @@ -255,6 +267,20 @@ struct thread_options { * I/O Error handling */ unsigned int continue_on_error; + + /* + * Benchmark profile type + */ + unsigned int profile; + + /* + * blkio cgroup support + */ + char *cgroup; + unsigned int cgroup_weight; + + unsigned int uid; + unsigned int gid; }; #define FIO_VERROR_SIZE 128 @@ -319,11 +345,22 @@ struct thread_data { struct flist_head io_u_freelist; struct flist_head io_u_busylist; struct flist_head io_u_requeues; + pthread_mutex_t io_u_lock; + pthread_cond_t free_cond; + + /* + * async verify offload + */ + struct flist_head verify_list; + pthread_t *verify_threads; + unsigned int nr_verify_threads; + pthread_cond_t verify_cond; + int verify_thread_exit; /* * Rate state */ - unsigned long rate_usec_cycle[2]; + unsigned long rate_nsec_cycle[2]; long rate_pending_usleep[2]; unsigned long rate_bytes[2]; unsigned long rate_blocks[2]; @@ -493,6 +530,7 @@ extern int in_ramp_time(struct thread_data *); */ extern int __must_check parse_options(int, char **); extern int fio_options_parse(struct thread_data *, char **, int); +extern void fio_keywords_init(void); extern int fio_cmd_option_parse(struct thread_data *, const char *, char *); extern void fio_fill_default_options(struct thread_data *); extern int fio_show_option_help(const char *); @@ -661,4 +699,26 @@ static inline int is_power_of_2(unsigned int val) return (val != 0 && ((val & (val - 1)) == 0)); } +/* + * We currently only need to do locking if we have verifier threads + * accessing our internal structures too + */ +static inline void td_io_u_lock(struct thread_data *td) +{ + if (td->o.verify_async) + pthread_mutex_lock(&td->io_u_lock); +} + +static inline void td_io_u_unlock(struct thread_data *td) +{ + if (td->o.verify_async) + pthread_mutex_unlock(&td->io_u_lock); +} + +static inline void td_io_u_free_notify(struct thread_data *td) +{ + if (td->o.verify_async) + pthread_cond_signal(&td->free_cond); +} + #endif