X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=eta.c;h=6118d1af21b5afccee8c9f106bc4cbd93b557c61;hp=5b912eb7166c81b1cb310e42a5c61701ecb6e9c0;hb=01bff3b891c164413b67f8d349ec7e8108d962e2;hpb=d5e3a0c6f5376e0d76143edb2c1622efd77f995f diff --git a/eta.c b/eta.c index 5b912eb7..6118d1af 100644 --- a/eta.c +++ b/eta.c @@ -230,7 +230,7 @@ static void calc_iops(unsigned long mtime, unsigned long long *io_iops, * Print status of the jobs we know about. This includes rate estimates, * ETA, thread state, etc. */ -int calc_thread_status(struct jobs_eta *je) +int calc_thread_status(struct jobs_eta *je, int force) { struct thread_data *td; int i; @@ -245,11 +245,13 @@ int calc_thread_status(struct jobs_eta *je) static struct timeval rate_prev_time, disp_prev_time; int i2p = 0; - if (temp_stall_ts || terse_output || eta_print == FIO_ETA_NEVER) - return 0; + if (!force) { + if (temp_stall_ts || terse_output || eta_print == FIO_ETA_NEVER) + return 0; - if (!isatty(STDOUT_FILENO) && (eta_print != FIO_ETA_ALWAYS)) - return 0; + if (!isatty(STDOUT_FILENO) && (eta_print != FIO_ETA_ALWAYS)) + return 0; + } if (!rate_io_bytes[0] && !rate_io_bytes[1]) fill_start_time(&rate_prev_time); @@ -332,7 +334,7 @@ int calc_thread_status(struct jobs_eta *je) /* * Allow a little slack, the target is to print it every 1000 msecs */ - if (disp_time < 900) + if (!force && disp_time < 900) return 0; calc_rate(disp_time, io_bytes, disp_io_bytes, je->rate); @@ -340,7 +342,7 @@ int calc_thread_status(struct jobs_eta *je) memcpy(&disp_prev_time, &now, sizeof(now)); - if (!je->nr_running && !je->nr_pending) + if (!force && !je->nr_running && !je->nr_pending) return 0; je->nr_threads = thread_number; @@ -416,12 +418,16 @@ void display_thread_status(struct jobs_eta *je) void print_thread_status(void) { struct jobs_eta *je; + size_t size; - je = malloc(sizeof(*je) + thread_number * sizeof(char)); + if (!thread_number) + return; - memset(je, 0, sizeof(*je) + thread_number * sizeof(char)); + size = sizeof(*je) + thread_number * sizeof(char) + 1; + je = malloc(size); + memset(je, 0, size); - if (calc_thread_status(je)) + if (calc_thread_status(je, 0)) display_thread_status(je); free(je);