do {
ret = io_submit(ld->aio_ctx, 1, &iocb);
if (ret == 1)
- return 0;
+ return FIO_Q_QUEUED;
else if (ret == -EAGAIN || !ret)
usleep(100);
else if (ret == -EINTR)
* with libaio (still), we don't have pending
* requests to flush first.
*/
- ret = fsync(io_u->file->fd);
+ if (fsync(io_u->file->fd) < 0)
+ ret = errno;
+ else
+ ret = FIO_Q_COMPLETED;
break;
} else
break;
if (ret <= 0) {
io_u->resid = io_u->xfer_buflen;
io_u->error = -ret;
- return 1;
+ td_verror(td, io_u->error);
+ return FIO_Q_COMPLETED;
}
- return 0;
+ return ret;
}
static int fio_libaio_cancel(struct thread_data *td, struct io_u *io_u)