X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=backend.c;h=5c35757ce1ad0316214a58b83efcd9278cd2887b;hb=155f2f027b34321f6f5abe79c09ece8ecca25046;hp=63d47a29bb63a5ddad78fe8618590db2db499145;hpb=0c5df5f9adccf9e3d8aaba88258ae9a4e0d3b643;p=fio.git diff --git a/backend.c b/backend.c index 63d47a29..5c35757c 100644 --- a/backend.c +++ b/backend.c @@ -54,9 +54,9 @@ #include "lib/getrusage.h" #include "idletime.h" #include "err.h" -#include "lib/tp.h" #include "workqueue.h" #include "lib/mountcheck.h" +#include "rate-submit.h" static pthread_t helper_thread; static pthread_mutex_t helper_lock; @@ -934,7 +934,11 @@ static uint64_t do_io(struct thread_data *td) if (td->error) break; - ret = workqueue_enqueue(&td->io_wq, io_u); + ret = workqueue_enqueue(&td->io_wq, &io_u->work); + if (ret) + ret = FIO_Q_QUEUED; + else + ret = FIO_Q_BUSY; if (ret == FIO_Q_QUEUED && ddir_rw(ddir)) { td->io_issues[ddir]++; @@ -1357,51 +1361,6 @@ static uint64_t do_dry_run(struct thread_data *td) return td->bytes_done[DDIR_WRITE] + td->bytes_done[DDIR_TRIM]; } -static void io_workqueue_fn(struct thread_data *td, struct io_u *io_u) -{ - const enum fio_ddir ddir = io_u->ddir; - int ret; - - dprint(FD_RATE, "io_u %p queued by %u\n", io_u, gettid()); - - io_u_set(io_u, IO_U_F_NO_FILE_PUT); - - td->cur_depth++; - - do { - ret = td_io_queue(td, io_u); - if (ret != FIO_Q_BUSY) - break; - ret = io_u_queued_complete(td, 1); - if (ret > 0) - td->cur_depth -= ret; - io_u_clear(io_u, IO_U_F_FLIGHT); - } while (1); - - dprint(FD_RATE, "io_u %p ret %d by %u\n", io_u, ret, gettid()); - - io_queue_event(td, io_u, &ret, ddir, NULL, 0, NULL); - - if (ret == FIO_Q_COMPLETED) - td->cur_depth--; - else if (ret == FIO_Q_QUEUED) { - unsigned int min_evts; - - if (td->o.iodepth == 1) - min_evts = 1; - else - min_evts = 0; - - ret = io_u_queued_complete(td, min_evts); - if (ret > 0) - td->cur_depth -= ret; - } else if (ret == FIO_Q_BUSY) { - ret = io_u_queued_complete(td, td->cur_depth); - if (ret > 0) - td->cur_depth -= ret; - } -} - /* * Entry point for the thread based jobs. The process based jobs end up * here as well, after a little setup. @@ -1594,13 +1553,13 @@ static void *thread_main(void *data) goto err; } - if (td->flags & TD_F_COMPRESS_LOG) - tp_init(&td->tp_data); + if (iolog_compress_init(td)) + goto err; fio_verify_init(td); if ((o->io_submit_mode == IO_MODE_OFFLOAD) && - workqueue_init(td, &td->io_wq, io_workqueue_fn, td->o.iodepth)) + workqueue_init(td, &td->io_wq, &rated_wq_ops, td->o.iodepth)) goto err; fio_gettime(&td->epoch, NULL); @@ -1701,8 +1660,7 @@ static void *thread_main(void *data) if (o->io_submit_mode == IO_MODE_OFFLOAD) workqueue_exit(&td->io_wq); - if (td->flags & TD_F_COMPRESS_LOG) - tp_exit(&td->tp_data); + iolog_compress_exit(td); if (o->exec_postrun) exec_string(o, o->exec_postrun, (const char *)"postrun");