From: Jens Axboe Date: Thu, 25 Apr 2019 19:27:54 +0000 (-0600) Subject: io_uring: remove cachehit information X-Git-Tag: fio-3.14~11 X-Git-Url: https://git.kernel.dk/?p=fio.git;a=commitdiff_plain;h=051382218cbe5101a5caa83eab55ed04608f8475 io_uring: remove cachehit information This patch never made it into the upstream kernel, remove knowledge of it from fio. Signed-off-by: Jens Axboe --- diff --git a/engines/io_uring.c b/engines/io_uring.c index 014f954e..5b3509a9 100644 --- a/engines/io_uring.c +++ b/engines/io_uring.c @@ -62,9 +62,6 @@ struct ioring_data { int cq_ring_off; unsigned iodepth; - uint64_t cachehit; - uint64_t cachemiss; - struct ioring_mmap mmap[3]; }; @@ -197,13 +194,6 @@ static struct io_u *fio_ioring_event(struct thread_data *td, int event) } else io_u->error = 0; - if (io_u->ddir == DDIR_READ) { - if (cqe->flags & IOCQE_FLAG_CACHEHIT) - ld->cachehit++; - else - ld->cachemiss++; - } - return io_u; } @@ -391,9 +381,6 @@ static void fio_ioring_cleanup(struct thread_data *td) struct ioring_data *ld = td->io_ops_data; if (ld) { - td->ts.cachehit += ld->cachehit; - td->ts.cachemiss += ld->cachemiss; - if (!(td->flags & TD_F_CHILD)) fio_ioring_unmap(ld); diff --git a/os/linux/io_uring.h b/os/linux/io_uring.h index 24906e99..e2340869 100644 --- a/os/linux/io_uring.h +++ b/os/linux/io_uring.h @@ -69,11 +69,6 @@ struct io_uring_cqe { __u32 flags; }; -/* - * io_uring_event->flags - */ -#define IOCQE_FLAG_CACHEHIT (1U << 0) /* IO did not hit media */ - /* * Magic offsets for the application to mmap the data it needs */ diff --git a/t/io_uring.c b/t/io_uring.c index 363cba3e..79a92311 100644 --- a/t/io_uring.c +++ b/t/io_uring.c @@ -71,7 +71,6 @@ struct submitter { unsigned long reaps; unsigned long done; unsigned long calls; - unsigned long cachehit, cachemiss; volatile int finish; __s32 *fds; @@ -269,10 +268,6 @@ static int reap_events(struct submitter *s) return -1; } } - if (cqe->flags & IOCQE_FLAG_CACHEHIT) - s->cachehit++; - else - s->cachemiss++; reaped++; head++; } while (1); @@ -497,7 +492,7 @@ static void usage(char *argv) int main(int argc, char *argv[]) { struct submitter *s; - unsigned long done, calls, reap, cache_hit, cache_miss; + unsigned long done, calls, reap; int err, i, flags, fd, opt; char *fdepths; void *ret; @@ -600,44 +595,29 @@ int main(int argc, char *argv[]) pthread_create(&s->thread, NULL, submitter_fn, s); fdepths = malloc(8 * s->nr_files); - cache_hit = cache_miss = reap = calls = done = 0; + reap = calls = done = 0; do { unsigned long this_done = 0; unsigned long this_reap = 0; unsigned long this_call = 0; - unsigned long this_cache_hit = 0; - unsigned long this_cache_miss = 0; unsigned long rpc = 0, ipc = 0; - double hit = 0.0; sleep(1); this_done += s->done; this_call += s->calls; this_reap += s->reaps; - this_cache_hit += s->cachehit; - this_cache_miss += s->cachemiss; - if (this_cache_hit && this_cache_miss) { - unsigned long hits, total; - - hits = this_cache_hit - cache_hit; - total = hits + this_cache_miss - cache_miss; - hit = (double) hits / (double) total; - hit *= 100.0; - } if (this_call - calls) { rpc = (this_done - done) / (this_call - calls); ipc = (this_reap - reap) / (this_call - calls); } else rpc = ipc = -1; file_depths(fdepths); - printf("IOPS=%lu, IOS/call=%ld/%ld, inflight=%u (%s), Cachehit=%0.2f%%\n", + printf("IOPS=%lu, IOS/call=%ld/%ld, inflight=%u (%s)\n", this_done - done, rpc, ipc, s->inflight, - fdepths, hit); + fdepths); done = this_done; calls = this_call; reap = this_reap; - cache_hit = s->cachehit; - cache_miss = s->cachemiss; } while (!finish); pthread_join(s->thread, &ret);