X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=engines%2Fposixaio.c;h=10340571af57fa79f2621027f937bcb424d6b554;hp=ef4d78ebe8a58c03465eb33cdc58aa7f90b52d7c;hb=b2560f3ca4677e2908fc4111f4d04fae5df3b229;hpb=f8fe35e8c9e88dd681ea151251d75f6116a958b4 diff --git a/engines/posixaio.c b/engines/posixaio.c index ef4d78eb..10340571 100644 --- a/engines/posixaio.c +++ b/engines/posixaio.c @@ -67,8 +67,8 @@ static int fio_posixaio_prep(struct thread_data fio_unused *td, struct fio_file *f = io_u->file; aiocb->aio_fildes = f->fd; - aiocb->aio_buf = io_u->buf; - aiocb->aio_nbytes = io_u->buflen; + aiocb->aio_buf = io_u->xfer_buf; + aiocb->aio_nbytes = io_u->xfer_buflen; aiocb->aio_offset = io_u->offset; io_u->seen = 0; @@ -100,6 +100,7 @@ restart: default: io_u->error = err; case ECANCELED: + io_u->resid = io_u->xfer_buflen; case 0: pd->aio_events[r++] = io_u; io_u->seen = 1; @@ -151,10 +152,13 @@ static int fio_posixaio_queue(struct thread_data fio_unused *td, else ret = aio_fsync(O_SYNC, aiocb); - if (ret) + if (ret) { io_u->error = errno; - - return io_u->error; + td_verror(td, io_u->error, "xfer"); + return FIO_Q_COMPLETED; + } + + return FIO_Q_QUEUED; } static void fio_posixaio_cleanup(struct thread_data *td)