do {
ret = io_submit(ld->aio_ctx, 1, &iocb);
if (ret == 1)
- return 0;
+ break;
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);
- ld->sync_io_u = io_u;
+ if (fsync(io_u->file->fd) < 0)
+ ret = errno;
+ else {
+ ret = 1;
+ ld->sync_io_u = io_u;
+ }
break;
} else
break;
if (ret <= 0) {
io_u->resid = io_u->xfer_buflen;
io_u->error = -ret;
+ td_verror(td, io_u->error);
return 1;
}