- if (td->cur_depth) {
- r = td_io_getevents(td, td->cur_depth, td->cur_depth, NULL);
- if (r > 0) {
- icd.nr = r;
- ios_completed(td, &icd);
+ if (td->cur_depth)
+ r = io_u_queued_complete(td, td->cur_depth);
+}
+
+/*
+ * Helper to handle the final sync of a file. Works just like the normal
+ * io path, just does everything sync.
+ */
+static int fio_io_sync(struct thread_data *td, struct fio_file *f)
+{
+ struct io_u *io_u = __get_io_u(td);
+ int ret;
+
+ if (!io_u)
+ return 1;
+
+ io_u->ddir = DDIR_SYNC;
+ io_u->file = f;
+
+ if (td_io_prep(td, io_u)) {
+ put_io_u(td, io_u);
+ return 1;
+ }
+
+requeue:
+ ret = td_io_queue(td, io_u);
+ if (ret < 0) {
+ td_verror(td, io_u->error, "td_io_queue");
+ put_io_u(td, io_u);
+ return 1;
+ } else if (ret == FIO_Q_QUEUED) {
+ if (io_u_queued_complete(td, 1) < 0)
+ return 1;
+ } else if (ret == FIO_Q_COMPLETED) {
+ if (io_u->error) {
+ td_verror(td, io_u->error, "td_io_queue");
+ return 1;