uringmachine 0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (307) hide show
  1. checksums.yaml +7 -0
  2. data/.github/dependabot.yml +12 -0
  3. data/.github/workflows/test.yml +35 -0
  4. data/.gitignore +59 -0
  5. data/.gitmodules +3 -0
  6. data/CHANGELOG.md +7 -0
  7. data/Gemfile +3 -0
  8. data/LICENSE +21 -0
  9. data/README.md +11 -0
  10. data/Rakefile +39 -0
  11. data/TODO.md +0 -0
  12. data/examples/echo_server.rb +52 -0
  13. data/examples/event_loop.rb +69 -0
  14. data/examples/fibers.rb +105 -0
  15. data/examples/http_server.rb +56 -0
  16. data/examples/http_server_multishot.rb +57 -0
  17. data/examples/http_server_simpler.rb +34 -0
  18. data/ext/um/extconf.rb +71 -0
  19. data/ext/um/iou.h +101 -0
  20. data/ext/um/op_ctx.c +138 -0
  21. data/ext/um/ring.c +755 -0
  22. data/ext/um/um.c +267 -0
  23. data/ext/um/um.h +97 -0
  24. data/ext/um/um_class.c +175 -0
  25. data/ext/um/um_ext.c +11 -0
  26. data/ext/um/um_op.c +87 -0
  27. data/ext/um/um_utils.c +23 -0
  28. data/lib/uringmachine/version.rb +3 -0
  29. data/lib/uringmachine.rb +8 -0
  30. data/test/helper.rb +70 -0
  31. data/test/test_iou.rb +876 -0
  32. data/test/test_um.rb +168 -0
  33. data/uringmachine.gemspec +27 -0
  34. data/vendor/liburing/.github/actions/codespell/stopwords +7 -0
  35. data/vendor/liburing/.github/pull_request_template.md +86 -0
  36. data/vendor/liburing/.github/workflows/build.yml +137 -0
  37. data/vendor/liburing/.github/workflows/codespell.yml +25 -0
  38. data/vendor/liburing/.github/workflows/shellcheck.yml +20 -0
  39. data/vendor/liburing/.gitignore +41 -0
  40. data/vendor/liburing/CHANGELOG +111 -0
  41. data/vendor/liburing/CITATION.cff +11 -0
  42. data/vendor/liburing/COPYING +502 -0
  43. data/vendor/liburing/COPYING.GPL +339 -0
  44. data/vendor/liburing/LICENSE +20 -0
  45. data/vendor/liburing/Makefile +96 -0
  46. data/vendor/liburing/Makefile.common +7 -0
  47. data/vendor/liburing/Makefile.quiet +11 -0
  48. data/vendor/liburing/README +106 -0
  49. data/vendor/liburing/SECURITY.md +6 -0
  50. data/vendor/liburing/configure +624 -0
  51. data/vendor/liburing/debian/README.Debian +7 -0
  52. data/vendor/liburing/debian/changelog +38 -0
  53. data/vendor/liburing/debian/control +39 -0
  54. data/vendor/liburing/debian/copyright +49 -0
  55. data/vendor/liburing/debian/liburing-dev.install +4 -0
  56. data/vendor/liburing/debian/liburing-dev.manpages +5 -0
  57. data/vendor/liburing/debian/liburing2.install +1 -0
  58. data/vendor/liburing/debian/liburing2.symbols +56 -0
  59. data/vendor/liburing/debian/patches/series +1 -0
  60. data/vendor/liburing/debian/rules +29 -0
  61. data/vendor/liburing/debian/source/format +1 -0
  62. data/vendor/liburing/debian/source/local-options +2 -0
  63. data/vendor/liburing/debian/source/options +1 -0
  64. data/vendor/liburing/debian/watch +3 -0
  65. data/vendor/liburing/examples/Makefile +53 -0
  66. data/vendor/liburing/examples/helpers.c +62 -0
  67. data/vendor/liburing/examples/helpers.h +7 -0
  68. data/vendor/liburing/examples/io_uring-close-test.c +123 -0
  69. data/vendor/liburing/examples/io_uring-cp.c +282 -0
  70. data/vendor/liburing/examples/io_uring-test.c +112 -0
  71. data/vendor/liburing/examples/io_uring-udp.c +403 -0
  72. data/vendor/liburing/examples/link-cp.c +193 -0
  73. data/vendor/liburing/examples/napi-busy-poll-client.c +509 -0
  74. data/vendor/liburing/examples/napi-busy-poll-server.c +450 -0
  75. data/vendor/liburing/examples/poll-bench.c +101 -0
  76. data/vendor/liburing/examples/proxy.c +2461 -0
  77. data/vendor/liburing/examples/proxy.h +102 -0
  78. data/vendor/liburing/examples/rsrc-update-bench.c +100 -0
  79. data/vendor/liburing/examples/send-zerocopy.c +658 -0
  80. data/vendor/liburing/examples/ucontext-cp.c +258 -0
  81. data/vendor/liburing/liburing-ffi.pc.in +12 -0
  82. data/vendor/liburing/liburing.pc.in +12 -0
  83. data/vendor/liburing/liburing.spec +66 -0
  84. data/vendor/liburing/make-debs.sh +55 -0
  85. data/vendor/liburing/src/Makefile +129 -0
  86. data/vendor/liburing/src/arch/aarch64/lib.h +47 -0
  87. data/vendor/liburing/src/arch/aarch64/syscall.h +91 -0
  88. data/vendor/liburing/src/arch/generic/lib.h +17 -0
  89. data/vendor/liburing/src/arch/generic/syscall.h +100 -0
  90. data/vendor/liburing/src/arch/riscv64/lib.h +48 -0
  91. data/vendor/liburing/src/arch/riscv64/syscall.h +100 -0
  92. data/vendor/liburing/src/arch/syscall-defs.h +94 -0
  93. data/vendor/liburing/src/arch/x86/lib.h +11 -0
  94. data/vendor/liburing/src/arch/x86/syscall.h +296 -0
  95. data/vendor/liburing/src/ffi.c +15 -0
  96. data/vendor/liburing/src/include/liburing/barrier.h +81 -0
  97. data/vendor/liburing/src/include/liburing/io_uring.h +818 -0
  98. data/vendor/liburing/src/include/liburing.h +1602 -0
  99. data/vendor/liburing/src/int_flags.h +11 -0
  100. data/vendor/liburing/src/lib.h +52 -0
  101. data/vendor/liburing/src/liburing-ffi.map +211 -0
  102. data/vendor/liburing/src/liburing.map +104 -0
  103. data/vendor/liburing/src/nolibc.c +55 -0
  104. data/vendor/liburing/src/queue.c +468 -0
  105. data/vendor/liburing/src/register.c +374 -0
  106. data/vendor/liburing/src/setup.c +689 -0
  107. data/vendor/liburing/src/setup.h +9 -0
  108. data/vendor/liburing/src/syscall.c +29 -0
  109. data/vendor/liburing/src/syscall.h +53 -0
  110. data/vendor/liburing/src/version.c +21 -0
  111. data/vendor/liburing/test/232c93d07b74.c +305 -0
  112. data/vendor/liburing/test/35fa71a030ca.c +329 -0
  113. data/vendor/liburing/test/500f9fbadef8.c +91 -0
  114. data/vendor/liburing/test/7ad0e4b2f83c.c +94 -0
  115. data/vendor/liburing/test/8a9973408177.c +107 -0
  116. data/vendor/liburing/test/917257daa0fe.c +54 -0
  117. data/vendor/liburing/test/Makefile +297 -0
  118. data/vendor/liburing/test/a0908ae19763.c +59 -0
  119. data/vendor/liburing/test/a4c0b3decb33.c +181 -0
  120. data/vendor/liburing/test/accept-link.c +255 -0
  121. data/vendor/liburing/test/accept-non-empty.c +256 -0
  122. data/vendor/liburing/test/accept-reuse.c +163 -0
  123. data/vendor/liburing/test/accept-test.c +83 -0
  124. data/vendor/liburing/test/accept.c +919 -0
  125. data/vendor/liburing/test/across-fork.c +284 -0
  126. data/vendor/liburing/test/b19062a56726.c +54 -0
  127. data/vendor/liburing/test/b5837bd5311d.c +78 -0
  128. data/vendor/liburing/test/bind-listen.c +408 -0
  129. data/vendor/liburing/test/buf-ring-nommap.c +123 -0
  130. data/vendor/liburing/test/buf-ring-put.c +83 -0
  131. data/vendor/liburing/test/buf-ring.c +473 -0
  132. data/vendor/liburing/test/ce593a6c480a.c +139 -0
  133. data/vendor/liburing/test/close-opath.c +123 -0
  134. data/vendor/liburing/test/config +14 -0
  135. data/vendor/liburing/test/connect-rep.c +204 -0
  136. data/vendor/liburing/test/connect.c +442 -0
  137. data/vendor/liburing/test/coredump.c +60 -0
  138. data/vendor/liburing/test/cq-full.c +97 -0
  139. data/vendor/liburing/test/cq-overflow.c +530 -0
  140. data/vendor/liburing/test/cq-peek-batch.c +103 -0
  141. data/vendor/liburing/test/cq-ready.c +95 -0
  142. data/vendor/liburing/test/cq-size.c +65 -0
  143. data/vendor/liburing/test/d4ae271dfaae.c +96 -0
  144. data/vendor/liburing/test/d77a67ed5f27.c +65 -0
  145. data/vendor/liburing/test/defer-taskrun.c +391 -0
  146. data/vendor/liburing/test/defer-tw-timeout.c +173 -0
  147. data/vendor/liburing/test/defer.c +319 -0
  148. data/vendor/liburing/test/double-poll-crash.c +195 -0
  149. data/vendor/liburing/test/drop-submit.c +94 -0
  150. data/vendor/liburing/test/eeed8b54e0df.c +120 -0
  151. data/vendor/liburing/test/empty-eownerdead.c +45 -0
  152. data/vendor/liburing/test/eploop.c +74 -0
  153. data/vendor/liburing/test/eventfd-disable.c +179 -0
  154. data/vendor/liburing/test/eventfd-reg.c +77 -0
  155. data/vendor/liburing/test/eventfd-ring.c +98 -0
  156. data/vendor/liburing/test/eventfd.c +113 -0
  157. data/vendor/liburing/test/evloop.c +73 -0
  158. data/vendor/liburing/test/exec-target.c +6 -0
  159. data/vendor/liburing/test/exit-no-cleanup.c +117 -0
  160. data/vendor/liburing/test/fadvise.c +202 -0
  161. data/vendor/liburing/test/fallocate.c +265 -0
  162. data/vendor/liburing/test/fc2a85cb02ef.c +132 -0
  163. data/vendor/liburing/test/fd-install.c +500 -0
  164. data/vendor/liburing/test/fd-pass.c +237 -0
  165. data/vendor/liburing/test/fdinfo.c +419 -0
  166. data/vendor/liburing/test/file-register.c +1189 -0
  167. data/vendor/liburing/test/file-update.c +231 -0
  168. data/vendor/liburing/test/file-verify.c +654 -0
  169. data/vendor/liburing/test/files-exit-hang-poll.c +114 -0
  170. data/vendor/liburing/test/files-exit-hang-timeout.c +137 -0
  171. data/vendor/liburing/test/fixed-buf-iter.c +115 -0
  172. data/vendor/liburing/test/fixed-buf-merge.c +101 -0
  173. data/vendor/liburing/test/fixed-hugepage.c +411 -0
  174. data/vendor/liburing/test/fixed-link.c +90 -0
  175. data/vendor/liburing/test/fixed-reuse.c +160 -0
  176. data/vendor/liburing/test/fpos.c +255 -0
  177. data/vendor/liburing/test/fsnotify.c +118 -0
  178. data/vendor/liburing/test/fsync.c +224 -0
  179. data/vendor/liburing/test/futex.c +571 -0
  180. data/vendor/liburing/test/hardlink.c +170 -0
  181. data/vendor/liburing/test/helpers.c +318 -0
  182. data/vendor/liburing/test/helpers.h +108 -0
  183. data/vendor/liburing/test/ignore-single-mmap.c +48 -0
  184. data/vendor/liburing/test/init-mem.c +164 -0
  185. data/vendor/liburing/test/io-cancel.c +561 -0
  186. data/vendor/liburing/test/io_uring_enter.c +264 -0
  187. data/vendor/liburing/test/io_uring_passthrough.c +482 -0
  188. data/vendor/liburing/test/io_uring_register.c +503 -0
  189. data/vendor/liburing/test/io_uring_setup.c +110 -0
  190. data/vendor/liburing/test/iopoll-leak.c +85 -0
  191. data/vendor/liburing/test/iopoll-overflow.c +118 -0
  192. data/vendor/liburing/test/iopoll.c +465 -0
  193. data/vendor/liburing/test/lfs-openat-write.c +119 -0
  194. data/vendor/liburing/test/lfs-openat.c +273 -0
  195. data/vendor/liburing/test/link-timeout.c +1108 -0
  196. data/vendor/liburing/test/link.c +497 -0
  197. data/vendor/liburing/test/link_drain.c +255 -0
  198. data/vendor/liburing/test/madvise.c +195 -0
  199. data/vendor/liburing/test/min-timeout-wait.c +354 -0
  200. data/vendor/liburing/test/min-timeout.c +233 -0
  201. data/vendor/liburing/test/mkdir.c +112 -0
  202. data/vendor/liburing/test/msg-ring-fd.c +331 -0
  203. data/vendor/liburing/test/msg-ring-flags.c +212 -0
  204. data/vendor/liburing/test/msg-ring-overflow.c +159 -0
  205. data/vendor/liburing/test/msg-ring.c +467 -0
  206. data/vendor/liburing/test/multicqes_drain.c +429 -0
  207. data/vendor/liburing/test/napi-test.c +215 -0
  208. data/vendor/liburing/test/napi-test.sh +48 -0
  209. data/vendor/liburing/test/no-mmap-inval.c +42 -0
  210. data/vendor/liburing/test/nolibc.c +62 -0
  211. data/vendor/liburing/test/nop-all-sizes.c +99 -0
  212. data/vendor/liburing/test/nop.c +177 -0
  213. data/vendor/liburing/test/nvme.h +169 -0
  214. data/vendor/liburing/test/ooo-file-unreg.c +82 -0
  215. data/vendor/liburing/test/open-close.c +261 -0
  216. data/vendor/liburing/test/open-direct-link.c +188 -0
  217. data/vendor/liburing/test/open-direct-pick.c +180 -0
  218. data/vendor/liburing/test/openat2.c +312 -0
  219. data/vendor/liburing/test/personality.c +204 -0
  220. data/vendor/liburing/test/pipe-bug.c +95 -0
  221. data/vendor/liburing/test/pipe-eof.c +83 -0
  222. data/vendor/liburing/test/pipe-reuse.c +105 -0
  223. data/vendor/liburing/test/poll-cancel-all.c +496 -0
  224. data/vendor/liburing/test/poll-cancel-ton.c +135 -0
  225. data/vendor/liburing/test/poll-cancel.c +228 -0
  226. data/vendor/liburing/test/poll-link.c +221 -0
  227. data/vendor/liburing/test/poll-many.c +230 -0
  228. data/vendor/liburing/test/poll-mshot-overflow.c +265 -0
  229. data/vendor/liburing/test/poll-mshot-update.c +323 -0
  230. data/vendor/liburing/test/poll-race-mshot.c +276 -0
  231. data/vendor/liburing/test/poll-race.c +105 -0
  232. data/vendor/liburing/test/poll-ring.c +48 -0
  233. data/vendor/liburing/test/poll-v-poll.c +353 -0
  234. data/vendor/liburing/test/poll.c +327 -0
  235. data/vendor/liburing/test/probe.c +135 -0
  236. data/vendor/liburing/test/read-before-exit.c +129 -0
  237. data/vendor/liburing/test/read-mshot-empty.c +153 -0
  238. data/vendor/liburing/test/read-mshot.c +404 -0
  239. data/vendor/liburing/test/read-write.c +1013 -0
  240. data/vendor/liburing/test/recv-msgall-stream.c +398 -0
  241. data/vendor/liburing/test/recv-msgall.c +263 -0
  242. data/vendor/liburing/test/recv-multishot.c +602 -0
  243. data/vendor/liburing/test/recvsend_bundle.c +691 -0
  244. data/vendor/liburing/test/reg-fd-only.c +131 -0
  245. data/vendor/liburing/test/reg-hint.c +56 -0
  246. data/vendor/liburing/test/reg-reg-ring.c +90 -0
  247. data/vendor/liburing/test/regbuf-merge.c +91 -0
  248. data/vendor/liburing/test/register-restrictions.c +633 -0
  249. data/vendor/liburing/test/rename.c +132 -0
  250. data/vendor/liburing/test/ring-leak.c +283 -0
  251. data/vendor/liburing/test/ring-leak2.c +249 -0
  252. data/vendor/liburing/test/ringbuf-read.c +196 -0
  253. data/vendor/liburing/test/ringbuf-status.c +242 -0
  254. data/vendor/liburing/test/rsrc_tags.c +461 -0
  255. data/vendor/liburing/test/runtests-loop.sh +16 -0
  256. data/vendor/liburing/test/runtests-quiet.sh +11 -0
  257. data/vendor/liburing/test/runtests.sh +168 -0
  258. data/vendor/liburing/test/rw_merge_test.c +98 -0
  259. data/vendor/liburing/test/self.c +91 -0
  260. data/vendor/liburing/test/send-zerocopy.c +971 -0
  261. data/vendor/liburing/test/send_recv.c +412 -0
  262. data/vendor/liburing/test/send_recvmsg.c +444 -0
  263. data/vendor/liburing/test/shared-wq.c +84 -0
  264. data/vendor/liburing/test/short-read.c +75 -0
  265. data/vendor/liburing/test/shutdown.c +165 -0
  266. data/vendor/liburing/test/sigfd-deadlock.c +88 -0
  267. data/vendor/liburing/test/single-issuer.c +169 -0
  268. data/vendor/liburing/test/skip-cqe.c +428 -0
  269. data/vendor/liburing/test/socket-getsetsock-cmd.c +346 -0
  270. data/vendor/liburing/test/socket-io-cmd.c +237 -0
  271. data/vendor/liburing/test/socket-rw-eagain.c +149 -0
  272. data/vendor/liburing/test/socket-rw-offset.c +149 -0
  273. data/vendor/liburing/test/socket-rw.c +137 -0
  274. data/vendor/liburing/test/socket.c +408 -0
  275. data/vendor/liburing/test/splice.c +512 -0
  276. data/vendor/liburing/test/sq-full-cpp.cc +45 -0
  277. data/vendor/liburing/test/sq-full.c +45 -0
  278. data/vendor/liburing/test/sq-poll-dup.c +211 -0
  279. data/vendor/liburing/test/sq-poll-kthread.c +169 -0
  280. data/vendor/liburing/test/sq-poll-share.c +138 -0
  281. data/vendor/liburing/test/sq-space_left.c +159 -0
  282. data/vendor/liburing/test/sqpoll-disable-exit.c +196 -0
  283. data/vendor/liburing/test/sqpoll-exec.c +132 -0
  284. data/vendor/liburing/test/sqpoll-exit-hang.c +78 -0
  285. data/vendor/liburing/test/sqpoll-sleep.c +69 -0
  286. data/vendor/liburing/test/statx.c +172 -0
  287. data/vendor/liburing/test/stdout.c +232 -0
  288. data/vendor/liburing/test/submit-and-wait.c +108 -0
  289. data/vendor/liburing/test/submit-link-fail.c +156 -0
  290. data/vendor/liburing/test/submit-reuse.c +237 -0
  291. data/vendor/liburing/test/symlink.c +117 -0
  292. data/vendor/liburing/test/sync-cancel.c +235 -0
  293. data/vendor/liburing/test/teardowns.c +58 -0
  294. data/vendor/liburing/test/test.h +36 -0
  295. data/vendor/liburing/test/thread-exit.c +143 -0
  296. data/vendor/liburing/test/timeout-new.c +256 -0
  297. data/vendor/liburing/test/timeout.c +1798 -0
  298. data/vendor/liburing/test/truncate.c +186 -0
  299. data/vendor/liburing/test/tty-write-dpoll.c +60 -0
  300. data/vendor/liburing/test/unlink.c +112 -0
  301. data/vendor/liburing/test/version.c +25 -0
  302. data/vendor/liburing/test/wait-timeout.c +287 -0
  303. data/vendor/liburing/test/waitid.c +373 -0
  304. data/vendor/liburing/test/wakeup-hang.c +162 -0
  305. data/vendor/liburing/test/wq-aff.c +146 -0
  306. data/vendor/liburing/test/xattr.c +442 -0
  307. metadata +412 -0
@@ -0,0 +1,497 @@
1
+ /* SPDX-License-Identifier: MIT */
2
+ /*
3
+ * Description: run various linked sqe tests
4
+ *
5
+ */
6
+ #include <errno.h>
7
+ #include <stdio.h>
8
+ #include <unistd.h>
9
+ #include <stdlib.h>
10
+ #include <string.h>
11
+ #include <fcntl.h>
12
+
13
+ #include "liburing.h"
14
+ #include "helpers.h"
15
+
16
+ static int no_hardlink;
17
+
18
+ /*
19
+ * Timer with single nop
20
+ */
21
+ static int test_single_hardlink(struct io_uring *ring)
22
+ {
23
+ struct __kernel_timespec ts;
24
+ struct io_uring_cqe *cqe;
25
+ struct io_uring_sqe *sqe;
26
+ int ret, i;
27
+
28
+ sqe = io_uring_get_sqe(ring);
29
+ if (!sqe) {
30
+ fprintf(stderr, "get sqe failed\n");
31
+ goto err;
32
+ }
33
+ ts.tv_sec = 0;
34
+ ts.tv_nsec = 10000000ULL;
35
+ io_uring_prep_timeout(sqe, &ts, 0, 0);
36
+ sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
37
+ sqe->user_data = 1;
38
+
39
+ sqe = io_uring_get_sqe(ring);
40
+ if (!sqe) {
41
+ fprintf(stderr, "get sqe failed\n");
42
+ goto err;
43
+ }
44
+ io_uring_prep_nop(sqe);
45
+ sqe->user_data = 2;
46
+
47
+ ret = io_uring_submit(ring);
48
+ if (ret <= 0) {
49
+ fprintf(stderr, "sqe submit failed: %d\n", ret);
50
+ goto err;
51
+ }
52
+
53
+ for (i = 0; i < 2; i++) {
54
+ ret = io_uring_wait_cqe(ring, &cqe);
55
+ if (ret < 0) {
56
+ fprintf(stderr, "wait completion %d\n", ret);
57
+ goto err;
58
+ }
59
+ if (!cqe) {
60
+ fprintf(stderr, "failed to get cqe\n");
61
+ goto err;
62
+ }
63
+ if (no_hardlink)
64
+ goto next;
65
+ if (cqe->user_data == 1 && cqe->res == -EINVAL) {
66
+ fprintf(stdout, "Hard links not supported, skipping\n");
67
+ no_hardlink = 1;
68
+ goto next;
69
+ }
70
+ if (cqe->user_data == 1 && cqe->res != -ETIME) {
71
+ fprintf(stderr, "timeout failed with %d\n", cqe->res);
72
+ goto err;
73
+ }
74
+ if (cqe->user_data == 2 && cqe->res) {
75
+ fprintf(stderr, "nop failed with %d\n", cqe->res);
76
+ goto err;
77
+ }
78
+ next:
79
+ io_uring_cqe_seen(ring, cqe);
80
+ }
81
+
82
+ return 0;
83
+ err:
84
+ return 1;
85
+ }
86
+
87
+ /*
88
+ * Timer -> timer -> nop
89
+ */
90
+ static int test_double_hardlink(struct io_uring *ring)
91
+ {
92
+ struct __kernel_timespec ts1, ts2;
93
+ struct io_uring_cqe *cqe;
94
+ struct io_uring_sqe *sqe;
95
+ int ret, i;
96
+
97
+ if (no_hardlink)
98
+ return 0;
99
+
100
+ sqe = io_uring_get_sqe(ring);
101
+ if (!sqe) {
102
+ fprintf(stderr, "get sqe failed\n");
103
+ goto err;
104
+ }
105
+ ts1.tv_sec = 0;
106
+ ts1.tv_nsec = 10000000ULL;
107
+ io_uring_prep_timeout(sqe, &ts1, 0, 0);
108
+ sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
109
+ sqe->user_data = 1;
110
+
111
+ sqe = io_uring_get_sqe(ring);
112
+ if (!sqe) {
113
+ fprintf(stderr, "get sqe failed\n");
114
+ goto err;
115
+ }
116
+ ts2.tv_sec = 0;
117
+ ts2.tv_nsec = 15000000ULL;
118
+ io_uring_prep_timeout(sqe, &ts2, 0, 0);
119
+ sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
120
+ sqe->user_data = 2;
121
+
122
+ sqe = io_uring_get_sqe(ring);
123
+ if (!sqe) {
124
+ fprintf(stderr, "get sqe failed\n");
125
+ goto err;
126
+ }
127
+ io_uring_prep_nop(sqe);
128
+ sqe->user_data = 3;
129
+
130
+ ret = io_uring_submit(ring);
131
+ if (ret <= 0) {
132
+ fprintf(stderr, "sqe submit failed: %d\n", ret);
133
+ goto err;
134
+ }
135
+
136
+ for (i = 0; i < 3; i++) {
137
+ ret = io_uring_wait_cqe(ring, &cqe);
138
+ if (ret < 0) {
139
+ fprintf(stderr, "wait completion %d\n", ret);
140
+ goto err;
141
+ }
142
+ if (!cqe) {
143
+ fprintf(stderr, "failed to get cqe\n");
144
+ goto err;
145
+ }
146
+ if (cqe->user_data == 1 && cqe->res != -ETIME) {
147
+ fprintf(stderr, "timeout failed with %d\n", cqe->res);
148
+ goto err;
149
+ }
150
+ if (cqe->user_data == 2 && cqe->res != -ETIME) {
151
+ fprintf(stderr, "timeout failed with %d\n", cqe->res);
152
+ goto err;
153
+ }
154
+ if (cqe->user_data == 3 && cqe->res) {
155
+ fprintf(stderr, "nop failed with %d\n", cqe->res);
156
+ goto err;
157
+ }
158
+ io_uring_cqe_seen(ring, cqe);
159
+ }
160
+
161
+ return 0;
162
+ err:
163
+ return 1;
164
+
165
+ }
166
+
167
+ /*
168
+ * Test failing head of chain, and dependent getting -ECANCELED
169
+ */
170
+ static int test_single_link_fail(struct io_uring *ring)
171
+ {
172
+ struct io_uring_cqe *cqe;
173
+ struct io_uring_sqe *sqe;
174
+ int ret, i;
175
+
176
+ sqe = io_uring_get_sqe(ring);
177
+ if (!sqe) {
178
+ printf("get sqe failed\n");
179
+ goto err;
180
+ }
181
+
182
+ io_uring_prep_remove_buffers(sqe, 10, 1);
183
+ sqe->flags |= IOSQE_IO_LINK;
184
+
185
+ sqe = io_uring_get_sqe(ring);
186
+ if (!sqe) {
187
+ printf("get sqe failed\n");
188
+ goto err;
189
+ }
190
+
191
+ io_uring_prep_nop(sqe);
192
+
193
+ ret = io_uring_submit(ring);
194
+ if (ret <= 0) {
195
+ printf("sqe submit failed: %d\n", ret);
196
+ goto err;
197
+ }
198
+
199
+ for (i = 0; i < 2; i++) {
200
+ ret = io_uring_peek_cqe(ring, &cqe);
201
+ if (ret < 0) {
202
+ printf("wait completion %d\n", ret);
203
+ goto err;
204
+ }
205
+ if (!cqe) {
206
+ printf("failed to get cqe\n");
207
+ goto err;
208
+ }
209
+ if (i == 0 && cqe->res != -ENOENT) {
210
+ printf("sqe0 failed with %d, wanted -ENOENT\n", cqe->res);
211
+ goto err;
212
+ }
213
+ if (i == 1 && cqe->res != -ECANCELED) {
214
+ printf("sqe1 failed with %d, wanted -ECANCELED\n", cqe->res);
215
+ goto err;
216
+ }
217
+ io_uring_cqe_seen(ring, cqe);
218
+ }
219
+
220
+ return 0;
221
+ err:
222
+ return 1;
223
+ }
224
+
225
+ /*
226
+ * Test two independent chains
227
+ */
228
+ static int test_double_chain(struct io_uring *ring)
229
+ {
230
+ struct io_uring_cqe *cqe;
231
+ struct io_uring_sqe *sqe;
232
+ int ret, i;
233
+
234
+ sqe = io_uring_get_sqe(ring);
235
+ if (!sqe) {
236
+ printf("get sqe failed\n");
237
+ goto err;
238
+ }
239
+
240
+ io_uring_prep_nop(sqe);
241
+ sqe->flags |= IOSQE_IO_LINK;
242
+
243
+ sqe = io_uring_get_sqe(ring);
244
+ if (!sqe) {
245
+ printf("get sqe failed\n");
246
+ goto err;
247
+ }
248
+
249
+ io_uring_prep_nop(sqe);
250
+
251
+ sqe = io_uring_get_sqe(ring);
252
+ if (!sqe) {
253
+ printf("get sqe failed\n");
254
+ goto err;
255
+ }
256
+
257
+ io_uring_prep_nop(sqe);
258
+ sqe->flags |= IOSQE_IO_LINK;
259
+
260
+ sqe = io_uring_get_sqe(ring);
261
+ if (!sqe) {
262
+ printf("get sqe failed\n");
263
+ goto err;
264
+ }
265
+
266
+ io_uring_prep_nop(sqe);
267
+
268
+ ret = io_uring_submit(ring);
269
+ if (ret <= 0) {
270
+ printf("sqe submit failed: %d\n", ret);
271
+ goto err;
272
+ }
273
+
274
+ for (i = 0; i < 4; i++) {
275
+ ret = io_uring_wait_cqe(ring, &cqe);
276
+ if (ret < 0) {
277
+ printf("wait completion %d\n", ret);
278
+ goto err;
279
+ }
280
+ io_uring_cqe_seen(ring, cqe);
281
+ }
282
+
283
+ return 0;
284
+ err:
285
+ return 1;
286
+ }
287
+
288
+ /*
289
+ * Test multiple dependents
290
+ */
291
+ static int test_double_link(struct io_uring *ring)
292
+ {
293
+ struct io_uring_cqe *cqe;
294
+ struct io_uring_sqe *sqe;
295
+ int ret, i;
296
+
297
+ sqe = io_uring_get_sqe(ring);
298
+ if (!sqe) {
299
+ printf("get sqe failed\n");
300
+ goto err;
301
+ }
302
+
303
+ io_uring_prep_nop(sqe);
304
+ sqe->flags |= IOSQE_IO_LINK;
305
+
306
+ sqe = io_uring_get_sqe(ring);
307
+ if (!sqe) {
308
+ printf("get sqe failed\n");
309
+ goto err;
310
+ }
311
+
312
+ io_uring_prep_nop(sqe);
313
+ sqe->flags |= IOSQE_IO_LINK;
314
+
315
+ sqe = io_uring_get_sqe(ring);
316
+ if (!sqe) {
317
+ printf("get sqe failed\n");
318
+ goto err;
319
+ }
320
+
321
+ io_uring_prep_nop(sqe);
322
+
323
+ ret = io_uring_submit(ring);
324
+ if (ret <= 0) {
325
+ printf("sqe submit failed: %d\n", ret);
326
+ goto err;
327
+ }
328
+
329
+ for (i = 0; i < 3; i++) {
330
+ ret = io_uring_wait_cqe(ring, &cqe);
331
+ if (ret < 0) {
332
+ printf("wait completion %d\n", ret);
333
+ goto err;
334
+ }
335
+ io_uring_cqe_seen(ring, cqe);
336
+ }
337
+
338
+ return 0;
339
+ err:
340
+ return 1;
341
+ }
342
+
343
+ /*
344
+ * Test single dependency
345
+ */
346
+ static int test_single_link(struct io_uring *ring)
347
+ {
348
+ struct io_uring_cqe *cqe;
349
+ struct io_uring_sqe *sqe;
350
+ int ret, i;
351
+
352
+ sqe = io_uring_get_sqe(ring);
353
+ if (!sqe) {
354
+ printf("get sqe failed\n");
355
+ goto err;
356
+ }
357
+
358
+ io_uring_prep_nop(sqe);
359
+ sqe->flags |= IOSQE_IO_LINK;
360
+
361
+ sqe = io_uring_get_sqe(ring);
362
+ if (!sqe) {
363
+ printf("get sqe failed\n");
364
+ goto err;
365
+ }
366
+
367
+ io_uring_prep_nop(sqe);
368
+
369
+ ret = io_uring_submit(ring);
370
+ if (ret <= 0) {
371
+ printf("sqe submit failed: %d\n", ret);
372
+ goto err;
373
+ }
374
+
375
+ for (i = 0; i < 2; i++) {
376
+ ret = io_uring_wait_cqe(ring, &cqe);
377
+ if (ret < 0) {
378
+ printf("wait completion %d\n", ret);
379
+ goto err;
380
+ }
381
+ io_uring_cqe_seen(ring, cqe);
382
+ }
383
+
384
+ return 0;
385
+ err:
386
+ return 1;
387
+ }
388
+
389
+ static int test_early_fail_and_wait(void)
390
+ {
391
+ struct io_uring ring;
392
+ struct io_uring_sqe *sqe;
393
+ int ret, invalid_fd = 42;
394
+ struct iovec iov = { .iov_base = NULL, .iov_len = 0 };
395
+
396
+ /* create a new ring as it leaves it dirty */
397
+ ret = io_uring_queue_init(8, &ring, 0);
398
+ if (ret) {
399
+ printf("ring setup failed\n");
400
+ return 1;
401
+ }
402
+
403
+ sqe = io_uring_get_sqe(&ring);
404
+ if (!sqe) {
405
+ printf("get sqe failed\n");
406
+ goto err;
407
+ }
408
+
409
+ io_uring_prep_readv(sqe, invalid_fd, &iov, 1, 0);
410
+ sqe->flags |= IOSQE_IO_LINK;
411
+
412
+ sqe = io_uring_get_sqe(&ring);
413
+ if (!sqe) {
414
+ printf("get sqe failed\n");
415
+ goto err;
416
+ }
417
+
418
+ io_uring_prep_nop(sqe);
419
+
420
+ ret = io_uring_submit_and_wait(&ring, 2);
421
+ if (ret <= 0 && ret != -EAGAIN) {
422
+ printf("sqe submit failed: %d\n", ret);
423
+ goto err;
424
+ }
425
+
426
+ io_uring_queue_exit(&ring);
427
+ return 0;
428
+ err:
429
+ io_uring_queue_exit(&ring);
430
+ return 1;
431
+ }
432
+
433
+ int main(int argc, char *argv[])
434
+ {
435
+ struct io_uring ring, poll_ring;
436
+ int ret;
437
+
438
+ if (argc > 1)
439
+ return T_EXIT_SKIP;
440
+
441
+ ret = io_uring_queue_init(8, &ring, 0);
442
+ if (ret) {
443
+ printf("ring setup failed\n");
444
+ return T_EXIT_FAIL;
445
+
446
+ }
447
+
448
+ ret = io_uring_queue_init(8, &poll_ring, IORING_SETUP_IOPOLL);
449
+ if (ret) {
450
+ printf("poll_ring setup failed\n");
451
+ return T_EXIT_FAIL;
452
+ }
453
+
454
+ ret = test_single_link(&ring);
455
+ if (ret) {
456
+ printf("test_single_link failed\n");
457
+ return ret;
458
+ }
459
+
460
+ ret = test_double_link(&ring);
461
+ if (ret) {
462
+ printf("test_double_link failed\n");
463
+ return ret;
464
+ }
465
+
466
+ ret = test_double_chain(&ring);
467
+ if (ret) {
468
+ printf("test_double_chain failed\n");
469
+ return ret;
470
+ }
471
+
472
+ ret = test_single_link_fail(&poll_ring);
473
+ if (ret) {
474
+ printf("test_single_link_fail failed\n");
475
+ return ret;
476
+ }
477
+
478
+ ret = test_single_hardlink(&ring);
479
+ if (ret) {
480
+ fprintf(stderr, "test_single_hardlink\n");
481
+ return ret;
482
+ }
483
+
484
+ ret = test_double_hardlink(&ring);
485
+ if (ret) {
486
+ fprintf(stderr, "test_double_hardlink\n");
487
+ return ret;
488
+ }
489
+
490
+ ret = test_early_fail_and_wait();
491
+ if (ret) {
492
+ fprintf(stderr, "test_early_fail_and_wait\n");
493
+ return ret;
494
+ }
495
+
496
+ return T_EXIT_PASS;
497
+ }