Fully parallellize io_u verification
Keep a full queue whenever possible, do verifications while
io is in progress.
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
diff --git a/io_u.c b/io_u.c
index 6439979..ebcc8bb 100644
--- a/io_u.c
+++ b/io_u.c
@@ -389,6 +389,7 @@
if (!io_u->error) {
unsigned int bytes = io_u->buflen - io_u->resid;
const enum fio_ddir idx = io_u->ddir;
+ int ret;
td->io_blocks[idx]++;
td->io_bytes[idx] += bytes;
@@ -407,14 +408,23 @@
log_io_piece(td, io_u);
icd->bytes_done[idx] += bytes;
+
+ if (icd->handler) {
+ ret = icd->handler(io_u);
+ if (ret && !icd->error)
+ icd->error = ret;
+ }
} else
icd->error = io_u->error;
}
-void init_icd(struct io_completion_data *icd)
+void init_icd(struct io_completion_data *icd, icd_handler *handler, int nr)
{
fio_gettime(&icd->time, NULL);
+ icd->handler = handler;
+ icd->nr = nr;
+
icd->error = 0;
icd->bytes_done[0] = icd->bytes_done[1] = 0;
}
@@ -424,8 +434,6 @@
struct io_u *io_u;
int i;
- init_icd(icd);
-
for (i = 0; i < icd->nr; i++) {
io_u = td->io_ops->event(td, i);