From: Jens Axboe Date: Fri, 20 Mar 2015 04:32:00 +0000 (-0600) Subject: Add ->bytes_done[] to struct thread_data X-Git-Tag: fio-2.2.8~29^2~5 X-Git-Url: https://git.kernel.dk/?p=fio.git;a=commitdiff_plain;h=55312f9f5572611037b6254912460f64173df574 Add ->bytes_done[] to struct thread_data We can't keep it on the stack for async IO offload. Signed-off-by: Jens Axboe --- diff --git a/backend.c b/backend.c index 25479b49..1dafe68d 100644 --- a/backend.c +++ b/backend.c @@ -229,16 +229,15 @@ static int __check_min_rate(struct thread_data *td, struct timeval *now, return 0; } -static int check_min_rate(struct thread_data *td, struct timeval *now, - uint64_t *bytes_done) +static int check_min_rate(struct thread_data *td, struct timeval *now) { int ret = 0; - if (bytes_done[DDIR_READ]) + if (td->bytes_done[DDIR_READ]) ret |= __check_min_rate(td, now, DDIR_READ); - if (bytes_done[DDIR_WRITE]) + if (td->bytes_done[DDIR_WRITE]) ret |= __check_min_rate(td, now, DDIR_WRITE); - if (bytes_done[DDIR_TRIM]) + if (td->bytes_done[DDIR_TRIM]) ret |= __check_min_rate(td, now, DDIR_TRIM); return ret; @@ -255,7 +254,7 @@ static void cleanup_pending_aio(struct thread_data *td) /* * get immediately available events, if any */ - r = io_u_queued_complete(td, 0, NULL); + r = io_u_queued_complete(td, 0); if (r < 0) return; @@ -276,7 +275,7 @@ static void cleanup_pending_aio(struct thread_data *td) } if (td->cur_depth) - r = io_u_queued_complete(td, td->cur_depth, NULL); + r = io_u_queued_complete(td, td->cur_depth); } /* @@ -306,7 +305,7 @@ requeue: put_io_u(td, io_u); return 1; } else if (ret == FIO_Q_QUEUED) { - if (io_u_queued_complete(td, 1, NULL) < 0) + if (io_u_queued_complete(td, 1) < 0) return 1; } else if (ret == FIO_Q_COMPLETED) { if (io_u->error) { @@ -314,7 +313,7 @@ requeue: return 1; } - if (io_u_sync_complete(td, io_u, NULL) < 0) + if (io_u_sync_complete(td, io_u) < 0) return 1; } else if (ret == FIO_Q_BUSY) { if (td_io_commit(td)) @@ -418,8 +417,7 @@ static void check_update_rusage(struct thread_data *td) } } -static int wait_for_completions(struct thread_data *td, struct timeval *time, - uint64_t *bytes_done) +static int wait_for_completions(struct thread_data *td, struct timeval *time) { const int full = queue_full(td); int min_evts = 0; @@ -438,7 +436,7 @@ static int wait_for_completions(struct thread_data *td, struct timeval *time, fio_gettime(time, NULL); do { - ret = io_u_queued_complete(td, min_evts, bytes_done); + ret = io_u_queued_complete(td, min_evts); if (ret < 0) break; } while (full && (td->cur_depth > td->o.iodepth_low)); @@ -452,7 +450,6 @@ static int wait_for_completions(struct thread_data *td, struct timeval *time, */ static void do_verify(struct thread_data *td, uint64_t verify_bytes) { - uint64_t bytes_done[DDIR_RWDIR_CNT] = { 0, 0, 0 }; struct fio_file *f; struct io_u *io_u; int ret, min_events; @@ -514,7 +511,7 @@ static void do_verify(struct thread_data *td, uint64_t verify_bytes) break; } } else { - if (ddir_rw_sum(bytes_done) + td->o.rw_min_bs > verify_bytes) + if (ddir_rw_sum(td->bytes_done) + td->o.rw_min_bs > verify_bytes) break; while ((io_u = get_io_u(td)) != NULL) { @@ -600,7 +597,7 @@ static void do_verify(struct thread_data *td, uint64_t verify_bytes) requeue_io_u(td, &io_u); } else { sync_done: - ret = io_u_sync_complete(td, io_u, bytes_done); + ret = io_u_sync_complete(td, io_u); if (ret < 0) break; } @@ -630,7 +627,7 @@ sync_done: reap: full = queue_full(td) || (ret == FIO_Q_BUSY && td->cur_depth); if (full || !td->o.iodepth_batch_complete) - ret = wait_for_completions(td, NULL, bytes_done); + ret = wait_for_completions(td, NULL); if (ret < 0) break; @@ -642,7 +639,7 @@ reap: min_events = td->cur_depth; if (min_events) - ret = io_u_queued_complete(td, min_events, NULL); + ret = io_u_queued_complete(td, min_events); } else cleanup_pending_aio(td); @@ -716,7 +713,6 @@ static int io_complete_bytes_exceeded(struct thread_data *td) */ static uint64_t do_io(struct thread_data *td) { - uint64_t bytes_done[DDIR_RWDIR_CNT] = { 0, 0, 0 }; unsigned int i; int ret = 0; uint64_t total_bytes, bytes_issued = 0; @@ -877,7 +873,7 @@ sync_done: __should_check_rate(td, DDIR_TRIM)) fio_gettime(&comp_time, NULL); - ret = io_u_sync_complete(td, io_u, bytes_done); + ret = io_u_sync_complete(td, io_u); if (ret < 0) break; bytes_issued += io_u->xfer_buflen; @@ -917,14 +913,15 @@ sync_done: reap: full = queue_full(td) || (ret == FIO_Q_BUSY && td->cur_depth); if (full || !td->o.iodepth_batch_complete) - ret = wait_for_completions(td, &comp_time, bytes_done); + ret = wait_for_completions(td, &comp_time); if (ret < 0) break; - if (!ddir_rw_sum(bytes_done) && !(td->io_ops->flags & FIO_NOIO)) + if (!ddir_rw_sum(td->bytes_done) && + !(td->io_ops->flags & FIO_NOIO)) continue; - if (!in_ramp_time(td) && should_check_rate(td, bytes_done)) { - if (check_min_rate(td, &comp_time, bytes_done)) { + if (!in_ramp_time(td) && should_check_rate(td)) { + if (check_min_rate(td, &comp_time)) { if (exitall_on_terminate) fio_terminate_threads(td->groupid); td_verror(td, EIO, "check_min_rate"); @@ -967,7 +964,7 @@ reap: i = td->cur_depth; if (i) { - ret = io_u_queued_complete(td, i, bytes_done); + ret = io_u_queued_complete(td, i); if (td->o.fill_device && td->error == ENOSPC) td->error = 0; } @@ -992,7 +989,7 @@ reap: if (!ddir_rw_sum(td->this_io_bytes)) td->done = 1; - return bytes_done[DDIR_WRITE] + bytes_done[DDIR_TRIM]; + return td->bytes_done[DDIR_WRITE] + td->bytes_done[DDIR_TRIM]; } static void cleanup_io_u(struct thread_data *td) @@ -1262,8 +1259,6 @@ static int exec_string(struct thread_options *o, const char *string, const char */ static uint64_t do_dry_run(struct thread_data *td) { - uint64_t bytes_done[DDIR_RWDIR_CNT] = { 0, 0, 0 }; - td_set_runstate(td, TD_RUNNING); while ((td->o.read_iolog_file && !flist_empty(&td->io_log_list)) || @@ -1294,11 +1289,11 @@ static uint64_t do_dry_run(struct thread_data *td) !td->o.experimental_verify) log_io_piece(td, io_u); - ret = io_u_sync_complete(td, io_u, bytes_done); + ret = io_u_sync_complete(td, io_u); (void) ret; } - return bytes_done[DDIR_WRITE] + bytes_done[DDIR_TRIM]; + return td->bytes_done[DDIR_WRITE] + td->bytes_done[DDIR_TRIM]; } /* diff --git a/fio.h b/fio.h index 0fb86eae..44648235 100644 --- a/fio.h +++ b/fio.h @@ -248,10 +248,11 @@ struct thread_data { uint64_t io_blocks[DDIR_RWDIR_CNT]; uint64_t this_io_blocks[DDIR_RWDIR_CNT]; uint64_t io_bytes[DDIR_RWDIR_CNT]; - uint64_t io_skip_bytes; uint64_t this_io_bytes[DDIR_RWDIR_CNT]; + uint64_t io_skip_bytes; uint64_t zone_bytes; struct fio_mutex *mutex; + uint64_t bytes_done[DDIR_RWDIR_CNT]; /* * State for random io, a bitmap of blocks done vs not done @@ -574,16 +575,15 @@ static inline int __should_check_rate(struct thread_data *td, return 0; } -static inline int should_check_rate(struct thread_data *td, - uint64_t *bytes_done) +static inline int should_check_rate(struct thread_data *td) { int ret = 0; - if (bytes_done[DDIR_READ]) + if (td->bytes_done[DDIR_READ]) ret |= __should_check_rate(td, DDIR_READ); - if (bytes_done[DDIR_WRITE]) + if (td->bytes_done[DDIR_WRITE]) ret |= __should_check_rate(td, DDIR_WRITE); - if (bytes_done[DDIR_TRIM]) + if (td->bytes_done[DDIR_TRIM]) ret |= __should_check_rate(td, DDIR_TRIM); return ret; diff --git a/io_u.c b/io_u.c index ebd75c1b..e4fcfd83 100644 --- a/io_u.c +++ b/io_u.c @@ -552,7 +552,7 @@ void io_u_quiesce(struct thread_data *td) while (td->io_u_in_flight) { int fio_unused ret; - ret = io_u_queued_complete(td, 1, NULL); + ret = io_u_queued_complete(td, 1); } } @@ -1785,10 +1785,10 @@ static void ios_completed(struct thread_data *td, /* * Complete a single io_u for the sync engines. */ -int io_u_sync_complete(struct thread_data *td, struct io_u *io_u, - uint64_t *bytes) +int io_u_sync_complete(struct thread_data *td, struct io_u *io_u) { struct io_completion_data icd; + int ddir; init_icd(td, &icd, 1); io_completed(td, &io_u, &icd); @@ -1801,12 +1801,8 @@ int io_u_sync_complete(struct thread_data *td, struct io_u *io_u, return -1; } - if (bytes) { - int ddir; - - for (ddir = DDIR_READ; ddir < DDIR_RWDIR_CNT; ddir++) - bytes[ddir] += icd.bytes_done[ddir]; - } + for (ddir = DDIR_READ; ddir < DDIR_RWDIR_CNT; ddir++) + td->bytes_done[ddir] += icd.bytes_done[ddir]; return 0; } @@ -1814,12 +1810,11 @@ int io_u_sync_complete(struct thread_data *td, struct io_u *io_u, /* * Called to complete min_events number of io for the async engines. */ -int io_u_queued_complete(struct thread_data *td, int min_evts, - uint64_t *bytes) +int io_u_queued_complete(struct thread_data *td, int min_evts) { struct io_completion_data icd; struct timespec *tvp = NULL; - int ret; + int ret, ddir; struct timespec ts = { .tv_sec = 0, .tv_nsec = 0, }; dprint(FD_IO, "io_u_queued_completed: min=%d\n", min_evts); @@ -1843,12 +1838,8 @@ int io_u_queued_complete(struct thread_data *td, int min_evts, return -1; } - if (bytes) { - int ddir; - - for (ddir = DDIR_READ; ddir < DDIR_RWDIR_CNT; ddir++) - bytes[ddir] += icd.bytes_done[ddir]; - } + for (ddir = DDIR_READ; ddir < DDIR_RWDIR_CNT; ddir++) + td->bytes_done[ddir] += icd.bytes_done[ddir]; return 0; } diff --git a/ioengine.h b/ioengine.h index f9a0235c..a55290d4 100644 --- a/ioengine.h +++ b/ioengine.h @@ -209,8 +209,8 @@ extern struct io_u *get_io_u(struct thread_data *); extern void put_io_u(struct thread_data *, struct io_u *); extern void clear_io_u(struct thread_data *, struct io_u *); extern void requeue_io_u(struct thread_data *, struct io_u **); -extern int __must_check io_u_sync_complete(struct thread_data *, struct io_u *, uint64_t *); -extern int __must_check io_u_queued_complete(struct thread_data *, int, uint64_t *); +extern int __must_check io_u_sync_complete(struct thread_data *, struct io_u *); +extern int __must_check io_u_queued_complete(struct thread_data *, int); extern void io_u_queued(struct thread_data *, struct io_u *); extern void io_u_quiesce(struct thread_data *); extern void io_u_log_error(struct thread_data *, struct io_u *); diff --git a/libfio.c b/libfio.c index 57ce725b..ed26114d 100644 --- a/libfio.c +++ b/libfio.c @@ -88,6 +88,7 @@ static void reset_io_counters(struct thread_data *td) td->this_io_blocks[ddir] = 0; td->rate_bytes[ddir] = 0; td->rate_blocks[ddir] = 0; + td->bytes_done[ddir] = 0; } td->zone_bytes = 0;