X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=diskutil.h;h=15ec681a449c4a9b34929933ab95f1c85b3c1257;hp=d86e4ec7e69b7b0b3b41cb36e22dd5aa61f79d79;hb=01bf5128d0581e267383f280c6a1dcd26517240f;hpb=a3b4cf7dcae447729f0f4a4ea122f605b909ed70 diff --git a/diskutil.h b/diskutil.h index d86e4ec7..15ec681a 100644 --- a/diskutil.h +++ b/diskutil.h @@ -3,15 +3,16 @@ #include "json.h" #define FIO_DU_NAME_SZ 64 -extern volatile int disk_util_exit; +#include "helper_thread.h" +#include "fio_sem.h" struct disk_util_stats { - uint32_t ios[2]; - uint32_t merges[2]; + uint64_t ios[2]; + uint64_t merges[2]; uint64_t sectors[2]; - uint32_t ticks[2]; - uint32_t io_ticks; - uint32_t time_in_queue; + uint64_t ticks[2]; + uint64_t io_ticks; + uint64_t time_in_queue; uint64_t msec; }; @@ -24,13 +25,14 @@ struct disk_util_stat { }; struct disk_util_agg { - uint32_t ios[2]; - uint32_t merges[2]; + uint64_t ios[2]; + uint64_t merges[2]; uint64_t sectors[2]; - uint32_t ticks[2]; - uint32_t io_ticks; - uint32_t time_in_queue; + uint64_t ticks[2]; + uint64_t io_ticks; + uint64_t time_in_queue; uint32_t slavecount; + uint32_t pad; fio_fp64_t max_util; }; @@ -44,7 +46,6 @@ struct disk_util { */ struct flist_head slavelist; - char *name; char *sysfs_root; char path[PATH_MAX]; int major, minor; @@ -63,9 +64,9 @@ struct disk_util { */ struct flist_head slaves; - struct timeval time; + struct timespec time; - struct fio_mutex *lock; + struct fio_sem *lock; unsigned long users; }; @@ -74,7 +75,7 @@ static inline void disk_util_mod(struct disk_util *du, int val) if (du) { struct flist_head *n; - fio_mutex_down(du->lock); + fio_sem_down(du->lock); du->users += val; flist_for_each(n, &du->slavelist) { @@ -83,7 +84,7 @@ static inline void disk_util_mod(struct disk_util *du, int val) slave = flist_entry(n, struct disk_util, slavelist); slave->users += val; } - fio_mutex_up(du->lock); + fio_sem_up(du->lock); } } static inline void disk_util_inc(struct disk_util *du) @@ -100,14 +101,12 @@ static inline void disk_util_dec(struct disk_util *du) extern struct flist_head disk_list; -extern void wait_for_disk_thread_exit(void); - /* * disk util stuff */ #ifdef FIO_HAVE_DISK_UTIL -extern void print_disk_util(struct disk_util_stat *, struct disk_util_agg *, int terse); -extern void show_disk_util(int terse, struct json_object *parent); +extern void print_disk_util(struct disk_util_stat *, struct disk_util_agg *, int terse, struct buf_output *); +extern void show_disk_util(int terse, struct json_object *parent, struct buf_output *); extern void json_array_add_disk_util(struct disk_util_stat *dus, struct disk_util_agg *agg, struct json_array *parent); extern void init_disk_util(struct thread_data *); @@ -115,11 +114,13 @@ extern int update_io_ticks(void); extern void setup_disk_util(void); extern void disk_util_prune_entries(void); #else +/* keep this as a function to avoid a warning in handle_du() */ static inline void print_disk_util(struct disk_util_stat *du, - struct disk_util_agg *agg, int terse) + struct disk_util_agg *agg, int terse, + struct buf_output *out) { } -#define show_disk_util(terse, parent) +#define show_disk_util(terse, parent, out) #define disk_util_prune_entries() #define init_disk_util(td) #define setup_disk_util() @@ -127,12 +128,8 @@ static inline void print_disk_util(struct disk_util_stat *du, static inline int update_io_ticks(void) { - return disk_util_exit; + return helper_should_exit(); } #endif -static inline void disk_util_start_exit(void) -{ - disk_util_exit = 1; -} #endif