X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=ioengines.c;h=c773f2ed3464a08fa6a51464d33d68a0231fc553;hb=0cf59b52d81ec0c70c60b9516b2e740f408b9d1c;hp=315432dae468eeee8469f8944229b9fadaad98f5;hpb=686fbd314c2113db5c9cd367a65f1e5abe47bce1;p=fio.git diff --git a/ioengines.c b/ioengines.c index 315432da..c773f2ed 100644 --- a/ioengines.c +++ b/ioengines.c @@ -368,17 +368,17 @@ int td_io_init(struct thread_data *td) if (td->io_ops->init) { ret = td->io_ops->init(td); - if (ret && td->o.iodepth > 1) { - log_err("fio: io engine init failed. Perhaps try" - " reducing io depth?\n"); - } + if (ret) + log_err("fio: io engine %s init failed.%s\n", + td->io_ops->name, + td->o.iodepth > 1 ? + " Perhaps try reducing io depth?" : ""); + else + td->io_ops_init = 1; if (!td->error) td->error = ret; } - if (!ret && td_ioengine_flagged(td, FIO_NOIO)) - td->flags |= TD_F_NOIO; - return ret; } @@ -618,15 +618,15 @@ int fio_show_ioengine_help(const char *engine) { struct flist_head *entry; struct thread_data td; + struct ioengine_ops *io_ops; char *sep; int ret = 1; if (!engine || !*engine) { log_info("Available IO engines:\n"); flist_for_each(entry, &engine_list) { - td.io_ops = flist_entry(entry, struct ioengine_ops, - list); - log_info("\t%s\n", td.io_ops->name); + io_ops = flist_entry(entry, struct ioengine_ops, list); + log_info("\t%s\n", io_ops->name); } return 0; } @@ -638,16 +638,16 @@ int fio_show_ioengine_help(const char *engine) memset(&td, 0, sizeof(td)); - td.io_ops = load_ioengine(&td, engine); - if (!td.io_ops) { + io_ops = load_ioengine(&td, engine); + if (!io_ops) { log_info("IO engine %s not found\n", engine); return 1; } - if (td.io_ops->options) - ret = show_cmd_help(td.io_ops->options, sep); + if (io_ops->options) + ret = show_cmd_help(io_ops->options, sep); else - log_info("IO engine %s has no options\n", td.io_ops->name); + log_info("IO engine %s has no options\n", io_ops->name); free_ioengine(&td);