X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=fio.c;h=69014ddbb14b2c8d631755337010b50f73684dc2;hb=6cd4d583c75042bf1edd3d2d5c6626883755bfe4;hp=72c7c8709e5296043d6522df320c29c7163e2e98;hpb=a569b45f68ebaa93fbbaca424dc827f4bbc5d655;p=fio.git diff --git a/fio.c b/fio.c index 72c7c870..69014ddb 100644 --- a/fio.c +++ b/fio.c @@ -30,15 +30,41 @@ int main(int argc, char *argv[], char *envp[]) { + int ret = 1; + if (initialize_fio(envp)) return 1; + +#if !defined(CONFIG_GETTIMEOFDAY) && !defined(CONFIG_CLOCK_GETTIME) +#error "No available clock source!" +#endif + + if (fio_server_create_sk_key()) + goto done; + if (parse_options(argc, argv)) - return 1; + goto done_key; + + /* + * line buffer stdout to avoid output lines from multiple + * threads getting mixed + */ + setvbuf(stdout, NULL, _IOLBF, 0); fio_time_init(); - if (nr_clients) - return fio_handle_clients(); - else - return fio_backend(); + if (nr_clients) { + set_genesis_time(); + + if (fio_start_all_clients()) + goto done_key; + ret = fio_handle_clients(&fio_client_ops); + } else + ret = fio_backend(NULL); + +done_key: + fio_server_destroy_sk_key(); +done: + deinitialize_fio(); + return ret; }