+ if (!td->io_ops->commit) {
+ io_u_mark_submit(td, 1);
+ io_u_mark_complete(td, 1);
+ }
+
+ if (ret == FIO_Q_COMPLETED) {
+ if (ddir_rw(io_u->ddir)) {
+ io_u_mark_depth(td, 1);
+ td->ts.total_io_u[io_u->ddir]++;
+ } else if (io_u->ddir == DDIR_TRIM)
+ td->ts.total_io_u[2]++;
+ } else if (ret == FIO_Q_QUEUED) {
+ int r;
+
+ if (ddir_rw(io_u->ddir)) {
+ td->io_u_queued++;
+ td->ts.total_io_u[io_u->ddir]++;
+ }
+
+ if (td->io_u_queued >= td->o.iodepth_batch) {
+ r = td_io_commit(td);
+ if (r < 0)
+ return r;
+ }
+ }
+
+ if ((td->io_ops->flags & FIO_SYNCIO) == 0) {
+ if (fio_fill_issue_time(td))
+ fio_gettime(&io_u->issue_time, NULL);
+
+ /*
+ * only used for iolog
+ */
+ if (td->o.read_iolog_file)
+ memcpy(&td->last_issue, &io_u->issue_time,
+ sizeof(struct timeval));
+ }
+
+ return ret;
+}
+
+int td_io_init(struct thread_data *td)
+{
+ int ret = 0;
+
+ 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");
+ }