X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=stat.c;h=636955e25c7d6d175db84bfb5c0beae117aa82cd;hb=7d6c5283afe6fb5187d2e2a330376ad65f472537;hp=b4806e0e8c48dfb5557be2f4abcdf31bf4ed41e1;hpb=71619dc28506f7b7b40905b942e992b02f0d5b96;p=fio.git diff --git a/stat.c b/stat.c index b4806e0e..636955e2 100644 --- a/stat.c +++ b/stat.c @@ -381,7 +381,7 @@ static void show_thread_status(struct thread_data *td, if (!(td->io_bytes[0] + td->io_bytes[1]) && !td->error) return; - fprintf(f_out, "%s: (groupid=%d): err=%2d:\n",td->name, td->groupid, td->error); + fprintf(f_out, "%s: (groupid=%d): err=%2d: pid=%d\n",td->name, td->groupid, td->error, td->pid); show_ddir_status(td, rs, td->ddir); if (td->io_bytes[td->ddir ^ 1]) @@ -408,7 +408,7 @@ static void show_thread_status(struct thread_data *td, io_u_dist[i] *= 100.0; } - fprintf(f_out, " IO depths : 1=%3.1f%%, 2=%3.1f%%, 4=%3.1f%%, 8=%3.1f%%, 16=%3.1f%%, 32=%3.1f%%, >32=%3.1f%%\n", io_u_dist[0], io_u_dist[1], io_u_dist[2], io_u_dist[3], io_u_dist[4], io_u_dist[5], io_u_dist[6]); + fprintf(f_out, " IO depths : 1=%3.1f%%, 2=%3.1f%%, 4=%3.1f%%, 8=%3.1f%%, 16=%3.1f%%, 32=%3.1f%%, >=64=%3.1f%%\n", io_u_dist[0], io_u_dist[1], io_u_dist[2], io_u_dist[3], io_u_dist[4], io_u_dist[5], io_u_dist[6]); } static void show_ddir_status_terse(struct thread_data *td, @@ -574,8 +574,8 @@ static inline void add_stat_sample(struct io_stat *is, unsigned long data) is->samples++; } -static void add_log_sample(struct thread_data *td, struct io_log *iolog, - unsigned long val, enum fio_ddir ddir) +static void __add_log_sample(struct io_log *iolog, unsigned long val, + enum fio_ddir ddir, unsigned long time) { if (iolog->nr_samples == iolog->max_samples) { int new_size = sizeof(struct io_sample) * iolog->max_samples*2; @@ -585,11 +585,24 @@ static void add_log_sample(struct thread_data *td, struct io_log *iolog, } iolog->log[iolog->nr_samples].val = val; - iolog->log[iolog->nr_samples].time = mtime_since_now(&td->epoch); + iolog->log[iolog->nr_samples].time = time; iolog->log[iolog->nr_samples].ddir = ddir; iolog->nr_samples++; } +static void add_log_sample(struct thread_data *td, struct io_log *iolog, + unsigned long val, enum fio_ddir ddir) +{ + __add_log_sample(iolog, val, ddir, mtime_since_now(&td->epoch)); +} + +void add_agg_sample(unsigned long val, enum fio_ddir ddir) +{ + struct io_log *iolog = agg_io_log[ddir]; + + __add_log_sample(iolog, val, ddir, mtime_since_genesis()); +} + void add_clat_sample(struct thread_data *td, enum fio_ddir ddir, unsigned long msec) {