From: Jackie Liu <[email protected]>
To: [email protected]
Cc: [email protected], [email protected], [email protected]
Subject: [PATCH liburing v2] Update link_drain with new kernel method
Date: Fri, 22 Nov 2019 16:18:04 +0800 [thread overview]
Message-ID: <[email protected]> (raw)
From: Jackie Liu <[email protected]>
Now we are dealing with link-drain in a much simpler way,
so the test program is updated as well.
Also fixed a bug that did not close fd when an error occurred.
and some dead code has been modified, like commit e1420b89c do.
Signed-off-by: Jackie Liu <[email protected]>
---
v2: fix miss dead code.
test/link_drain.c | 133 +++++++++++++++++++++++++++++++++++++++-------
1 file changed, 115 insertions(+), 18 deletions(-)
diff --git a/test/link_drain.c b/test/link_drain.c
index c192a5d..cc6f73f 100644
--- a/test/link_drain.c
+++ b/test/link_drain.c
@@ -11,13 +11,7 @@
#include "liburing.h"
-char expect[3][5] = {
- { 0, 1, 2, 3, 4 },
- { 0, 1, 2, 4, 3 },
- { 0, 1, 4, 2, 3 }
-};
-
-static int test_link_drain(struct io_uring *ring)
+static int test_link_drain_one(struct io_uring *ring)
{
struct io_uring_cqe *cqe;
struct io_uring_sqe *sqe[5];
@@ -25,6 +19,7 @@ static int test_link_drain(struct io_uring *ring)
int i, fd, ret;
off_t off = 0;
char data[5] = {0};
+ char expect[5] = {0, 1, 2, 3, 4};
fd = open("testfile", O_WRONLY | O_CREAT, 0644);
if (fd < 0) {
@@ -66,12 +61,12 @@ static int test_link_drain(struct io_uring *ring)
sqe[4]->user_data = 4;
ret = io_uring_submit(ring);
- if (ret < 5) {
- printf("Submitted only %d\n", ret);
- goto err;
- } else if (ret < 0) {
+ if (ret < 0) {
printf("sqe submit failed\n");
goto err;
+ } else if (ret < 5) {
+ printf("Submitted only %d\n", ret);
+ goto err;
}
for (i = 0; i < 5; i++) {
@@ -85,21 +80,121 @@ static int test_link_drain(struct io_uring *ring)
io_uring_cqe_seen(ring, cqe);
}
+ if (memcmp(data, expect, 5) != 0)
+ goto err;
+
free(iovecs.iov_base);
close(fd);
+ unlink("testfile");
+ return 0;
+err:
+ free(iovecs.iov_base);
+ close(fd);
+ unlink("testfile");
+ return 1;
+}
+
+int test_link_drain_multi(struct io_uring *ring)
+{
+ struct io_uring_cqe *cqe;
+ struct io_uring_sqe *sqe[9];
+ struct iovec iovecs;
+ int i, fd, ret;
+ off_t off = 0;
+ char data[9] = {0};
+ char expect[9] = {0, 1, 2, 3, 4, 5, 6, 7, 8};
- for (i = 0; i < 3; i++) {
- if (memcmp(data, expect[i], 5) == 0)
- break;
+ fd = open("testfile", O_WRONLY | O_CREAT, 0644);
+ if (fd < 0) {
+ perror("open");
+ return 1;
+ }
+
+ iovecs.iov_base = malloc(4096);
+ iovecs.iov_len = 4096;
+
+ for (i = 0; i < 9; i++) {
+ sqe[i] = io_uring_get_sqe(ring);
+ if (!sqe[i]) {
+ printf("get sqe failed\n");
+ goto err;
+ }
}
- if (i == 3)
+
+ /* normal heavy io */
+ io_uring_prep_writev(sqe[0], fd, &iovecs, 1, off);
+ sqe[0]->user_data = 0;
+
+ /* link1 io head */
+ io_uring_prep_nop(sqe[1]);
+ sqe[1]->flags |= IOSQE_IO_LINK;
+ sqe[1]->user_data = 1;
+
+ /* link1 drain io */
+ io_uring_prep_nop(sqe[2]);
+ sqe[2]->flags |= (IOSQE_IO_LINK | IOSQE_IO_DRAIN);
+ sqe[2]->user_data = 2;
+
+ /* link1 io end*/
+ io_uring_prep_nop(sqe[3]);
+ sqe[3]->user_data = 3;
+
+ /* link2 io head */
+ io_uring_prep_nop(sqe[4]);
+ sqe[4]->flags |= IOSQE_IO_LINK;
+ sqe[4]->user_data = 4;
+
+ /* link2 io */
+ io_uring_prep_nop(sqe[5]);
+ sqe[5]->flags |= IOSQE_IO_LINK;
+ sqe[5]->user_data = 5;
+
+ /* link2 drain io */
+ io_uring_prep_writev(sqe[6], fd, &iovecs, 1, off);
+ sqe[6]->flags |= (IOSQE_IO_LINK | IOSQE_IO_DRAIN);
+ sqe[6]->user_data = 6;
+
+ /* link2 io end */
+ io_uring_prep_nop(sqe[7]);
+ sqe[7]->user_data = 7;
+
+ /* normal io */
+ io_uring_prep_nop(sqe[8]);
+ sqe[8]->user_data = 8;
+
+ ret = io_uring_submit(ring);
+ if (ret < 0) {
+ printf("sqe submit failed\n");
+ goto err;
+ } else if (ret < 9) {
+ printf("Submitted only %d\n", ret);
+ goto err;
+ }
+
+ for (i = 0; i < 9; i++) {
+ ret = io_uring_wait_cqe(ring, &cqe);
+ if (ret < 0) {
+ printf("child: wait completion %d\n", ret);
+ goto err;
+ }
+
+ data[i] = cqe->user_data;
+ io_uring_cqe_seen(ring, cqe);
+ }
+
+ if (memcmp(data, expect, 9) != 0)
goto err;
+ free(iovecs.iov_base);
+ close(fd);
unlink("testfile");
return 0;
err:
+ free(iovecs.iov_base);
+ close(fd);
unlink("testfile");
return 1;
+
}
int main(int argc, char *argv[])
@@ -107,14 +202,16 @@ int main(int argc, char *argv[])
struct io_uring ring;
int i, ret;
- ret = io_uring_queue_init(5, &ring, 0);
+ ret = io_uring_queue_init(100, &ring, 0);
if (ret) {
printf("ring setup failed\n");
return 1;
}
- for (i = 0; i < 1000; i++)
- ret |= test_link_drain(&ring);
+ for (i = 0; i < 1000; i++) {
+ ret |= test_link_drain_one(&ring);
+ ret |= test_link_drain_multi(&ring);
+ }
if (ret)
return ret;
--
2.17.1
next reply other threads:[~2019-11-22 8:27 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-11-22 8:18 Jackie Liu [this message]
2019-11-22 14:24 ` [PATCH liburing v2] Update link_drain with new kernel method Jens Axboe
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox