diff options
author | Jens Axboe <axboe@kernel.dk> | 2019-03-06 17:03:50 +0100 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2019-03-06 21:00:16 +0100 |
commit | 21b4aa5d20fd07207e73270cadffed5c63fb4343 (patch) | |
tree | f9efcd15b170905dd1d9a4f1801b26b0ec90c34e /tools/io_uring/README | |
parent | io_uring: allow workqueue item to handle multiple buffered requests (diff) | |
download | linux-21b4aa5d20fd07207e73270cadffed5c63fb4343.tar.xz linux-21b4aa5d20fd07207e73270cadffed5c63fb4343.zip |
io_uring: add a few test tools
This adds two test programs in tools/io_uring/ that demonstrate both
the raw io_uring API (and all features) through a small benchmark
app, io_uring-bench, and the liburing exposed API in a simplified
cp(1) implementation through io_uring-cp.
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'tools/io_uring/README')
-rw-r--r-- | tools/io_uring/README | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/tools/io_uring/README b/tools/io_uring/README new file mode 100644 index 000000000000..67fd70115cff --- /dev/null +++ b/tools/io_uring/README @@ -0,0 +1,29 @@ +This directory includes a few programs that demonstrate how to use io_uring +in an application. The examples are: + +io_uring-cp + A very basic io_uring implementation of cp(1). It takes two + arguments, copies the first argument to the second. This example + is part of liburing, and hence uses the simplified liburing API + for setting up an io_uring instance, submitting IO, completing IO, + etc. The support functions in queue.c and setup.c are straight + out of liburing. + +io_uring-bench + Benchmark program that does random reads on a number of files. This + app demonstrates the various features of io_uring, like fixed files, + fixed buffers, and polled IO. There are options in the program to + control which features to use. Arguments is the file (or files) that + io_uring-bench should operate on. This uses the raw io_uring + interface. + +liburing can be cloned with git here: + + git://git.kernel.dk/liburing + +and contains a number of unit tests as well for testing io_uring. It also +comes with man pages for the three system calls. + +Fio includes an io_uring engine, you can clone fio here: + + git://git.kernel.dk/fio |