X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=iolog.h;h=6503acffd10659b2ff4e5d5f187b9d5c516de28b;hb=6348b5dee54f24f2e78872948653942336f4c14e;hp=122a982e0f283fcd47cc4429bc5ca255f285e412;hpb=80666bece308842c36132245e4cbbe9eb0bc506b;p=fio.git diff --git a/iolog.h b/iolog.h index 122a982e..6503acff 100644 --- a/iolog.h +++ b/iolog.h @@ -3,6 +3,7 @@ #include "lib/rbtree.h" #include "lib/ieee754.h" +#include "flist.h" #include "ioengine.h" /* @@ -48,11 +49,16 @@ struct io_log { unsigned int log_type; + /* + * If we fail extending the log, stop collecting more entries. + */ + unsigned int disabled; + /* * Windowed average, for logging single entries average over some * period of time. */ - struct io_stat avg_window[2]; + struct io_stat avg_window[DDIR_RWDIR_CNT]; unsigned long avg_msec; unsigned long avg_last; }; @@ -96,6 +102,7 @@ enum file_log_act { FIO_LOG_UNLINK_FILE, }; +struct io_u; extern int __must_check read_iolog_get(struct thread_data *, struct io_u *); extern void log_io_u(struct thread_data *, struct io_u *); extern void log_file(struct thread_data *, struct fio_file *, enum file_log_act); @@ -116,14 +123,15 @@ extern void add_slat_sample(struct thread_data *, enum fio_ddir, unsigned long, unsigned int); extern void add_bw_sample(struct thread_data *, enum fio_ddir, unsigned int, struct timeval *); -extern void add_iops_sample(struct thread_data *, enum fio_ddir, struct timeval *); +extern void add_iops_sample(struct thread_data *, enum fio_ddir, unsigned int, + struct timeval *); extern void init_disk_util(struct thread_data *); extern void update_rusage_stat(struct thread_data *); extern void setup_log(struct io_log **, unsigned long, int); extern void finish_log(struct thread_data *, struct io_log *, const char *); extern void finish_log_named(struct thread_data *, struct io_log *, const char *, const char *); extern void __finish_log(struct io_log *, const char *); -extern struct io_log *agg_io_log[2]; +extern struct io_log *agg_io_log[DDIR_RWDIR_CNT]; extern int write_bw_log; extern void add_agg_sample(unsigned long, enum fio_ddir, unsigned int);