unsigned int unlink;
};
+/*
+ * How many depth levels to log
+ */
+#define FIO_IO_U_MAP_NR 8
+#define FIO_IO_U_LAT_NR 12
+
struct thread_stat {
+ char *name;
+ char *verror;
+ int error;
+ int groupid;
+ pid_t pid;
+ char *description;
+
struct io_log *slat_log;
struct io_log *clat_log;
struct io_log *bw_log;
unsigned long usr_time;
unsigned long sys_time;
unsigned long ctx;
-};
-/*
- * How many depth levels to log
- */
-#define FIO_IO_U_MAP_NR 8
-#define FIO_IO_U_LAT_NR 12
+ /*
+ * IO depth and latency stats
+ */
+ unsigned int io_u_map[FIO_IO_U_MAP_NR];
+ unsigned int io_u_lat[FIO_IO_U_LAT_NR];
+ unsigned long total_io_u;
+
+ unsigned long long io_bytes[2];
+ unsigned long runtime[2];
+ unsigned long total_run_time;
+};
/*
* This describes a single thread/process executing a fio job.
unsigned int rwmixwrite;
unsigned int nice;
unsigned int file_service_type;
+ unsigned int group_reporting;
char *read_iolog_file;
char *write_iolog_file;
* Current IO depth and list of free and busy io_u's.
*/
unsigned int cur_depth;
- unsigned int io_u_map[FIO_IO_U_MAP_NR];
- unsigned int io_u_lat[FIO_IO_U_LAT_NR];
- unsigned long total_io_u;
struct list_head io_u_freelist;
struct list_head io_u_busylist;
struct list_head io_u_requeues;
unsigned long rate_bytes;
struct timeval lastrate;
- unsigned long runtime[2]; /* msec */
unsigned long long io_size;
unsigned long long total_file_size;
unsigned long long start_offset;
struct timeval start; /* start of this loop */
struct timeval epoch; /* time job was started */
- struct timeval end_time;/* time job ended */
/*
* read/write mixed workload state
extern long __must_check io_u_sync_complete(struct thread_data *, struct io_u *);
extern long __must_check io_u_queued_complete(struct thread_data *, int);
extern void io_u_queued(struct thread_data *, struct io_u *);
+extern void io_u_log_error(struct thread_data *, struct io_u *);
extern void io_u_init_timeout(void);
extern void io_u_set_timeout(struct thread_data *);