X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=engines%2Flibaio.c;h=eea8f55372ea17b59ad6e9e9c78006f963f63c54;hb=84422acde41c9cf462245de115d425cf5a82124c;hp=8f677115056d2e922bda4eaa5f766423db07b6ec;hpb=7101d9c24abec4be58a086d85d6d92ec6e6492e9;p=fio.git diff --git a/engines/libaio.c b/engines/libaio.c index 8f677115..eea8f553 100644 --- a/engines/libaio.c +++ b/engines/libaio.c @@ -60,8 +60,8 @@ static struct io_u *fio_libaio_event(struct thread_data *td, int event) return io_u; } -static int fio_libaio_getevents(struct thread_data *td, int min, int max, - struct timespec *t) +static int fio_libaio_getevents(struct thread_data *td, unsigned int min, + unsigned int max, struct timespec *t) { struct libaio_data *ld = td->io_ops->data; long r; @@ -133,36 +133,26 @@ static int fio_libaio_commit(struct thread_data *td) struct libaio_data *ld = td->io_ops->data; struct iocb **iocbs; struct io_u **io_us; - int ret, iocbs_nr; + int ret; if (!ld->iocbs_nr) return 0; - iocbs_nr = ld->iocbs_nr; io_us = ld->io_us; iocbs = ld->iocbs; do { - ret = io_submit(ld->aio_ctx, iocbs_nr, iocbs); - if (ret == iocbs_nr) { - fio_libaio_queued(td, io_us, ret); - ret = 0; - break; - } else if (ret > 0) { + ret = io_submit(ld->aio_ctx, ld->iocbs_nr, iocbs); + if (ret > 0) { fio_libaio_queued(td, io_us, ret); + ld->iocbs_nr -= ret; io_us += ret; iocbs += ret; - iocbs_nr -= ret; - continue; - } else if (ret == -EAGAIN || !ret) - usleep(100); - else if (ret == -EINTR) + ret = 0; + } else if (!ret || ret == -EAGAIN || ret == -EINTR) continue; else break; - } while (1); - - if (!ret) - ld->iocbs_nr = 0; + } while (ld->iocbs_nr); return ret; }