@nxtedition/rocksdb 7.0.5 → 7.0.8

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 (262) hide show
  1. package/binding.cc +363 -329
  2. package/chained-batch.js +6 -1
  3. package/deps/rocksdb/rocksdb/CMakeLists.txt +8 -3
  4. package/deps/rocksdb/rocksdb/Makefile +10 -4
  5. package/deps/rocksdb/rocksdb/TARGETS +6 -4
  6. package/deps/rocksdb/rocksdb/cache/cache_bench_tool.cc +9 -0
  7. package/deps/rocksdb/rocksdb/cache/cache_test.cc +14 -0
  8. package/deps/rocksdb/rocksdb/cache/clock_cache.cc +8 -8
  9. package/deps/rocksdb/rocksdb/cache/fast_lru_cache.cc +272 -174
  10. package/deps/rocksdb/rocksdb/cache/fast_lru_cache.h +201 -57
  11. package/deps/rocksdb/rocksdb/cache/lru_cache.cc +19 -19
  12. package/deps/rocksdb/rocksdb/cache/lru_cache.h +2 -1
  13. package/deps/rocksdb/rocksdb/cmake/modules/CxxFlags.cmake +7 -0
  14. package/deps/rocksdb/rocksdb/cmake/modules/FindJeMalloc.cmake +29 -0
  15. package/deps/rocksdb/rocksdb/cmake/modules/FindNUMA.cmake +29 -0
  16. package/deps/rocksdb/rocksdb/cmake/modules/FindSnappy.cmake +29 -0
  17. package/deps/rocksdb/rocksdb/cmake/modules/FindTBB.cmake +33 -0
  18. package/deps/rocksdb/rocksdb/cmake/modules/Findgflags.cmake +29 -0
  19. package/deps/rocksdb/rocksdb/cmake/modules/Findlz4.cmake +29 -0
  20. package/deps/rocksdb/rocksdb/cmake/modules/Finduring.cmake +26 -0
  21. package/deps/rocksdb/rocksdb/cmake/modules/Findzstd.cmake +29 -0
  22. package/deps/rocksdb/rocksdb/cmake/modules/ReadVersion.cmake +10 -0
  23. package/deps/rocksdb/rocksdb/db/blob/blob_source.cc +170 -0
  24. package/deps/rocksdb/rocksdb/db/blob/blob_source.h +95 -0
  25. package/deps/rocksdb/rocksdb/db/blob/blob_source_test.cc +298 -0
  26. package/deps/rocksdb/rocksdb/db/blob/db_blob_basic_test.cc +172 -0
  27. package/deps/rocksdb/rocksdb/db/column_family.cc +8 -3
  28. package/deps/rocksdb/rocksdb/db/column_family.h +6 -3
  29. package/deps/rocksdb/rocksdb/db/compaction/compaction_job.cc +10 -0
  30. package/deps/rocksdb/rocksdb/db/compaction/compaction_job_test.cc +6 -6
  31. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.cc +22 -2
  32. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_test.cc +38 -0
  33. package/deps/rocksdb/rocksdb/db/db_basic_test.cc +17 -5
  34. package/deps/rocksdb/rocksdb/db/db_block_cache_test.cc +4 -7
  35. package/deps/rocksdb/rocksdb/db/db_bloom_filter_test.cc +74 -71
  36. package/deps/rocksdb/rocksdb/db/db_compaction_test.cc +70 -1
  37. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.cc +13 -12
  38. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.h +36 -0
  39. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_compaction_flush.cc +11 -4
  40. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_files.cc +1 -1
  41. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_open.cc +139 -91
  42. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_write.cc +48 -14
  43. package/deps/rocksdb/rocksdb/db/db_kv_checksum_test.cc +90 -55
  44. package/deps/rocksdb/rocksdb/db/db_rate_limiter_test.cc +9 -4
  45. package/deps/rocksdb/rocksdb/db/db_test.cc +3 -1
  46. package/deps/rocksdb/rocksdb/db/db_wal_test.cc +12 -7
  47. package/deps/rocksdb/rocksdb/db/db_write_test.cc +35 -0
  48. package/deps/rocksdb/rocksdb/db/dbformat.cc +3 -1
  49. package/deps/rocksdb/rocksdb/db/dbformat.h +5 -3
  50. package/deps/rocksdb/rocksdb/db/flush_job_test.cc +1 -1
  51. package/deps/rocksdb/rocksdb/db/memtable.cc +1 -0
  52. package/deps/rocksdb/rocksdb/db/memtable_list_test.cc +4 -2
  53. package/deps/rocksdb/rocksdb/db/repair.cc +1 -1
  54. package/deps/rocksdb/rocksdb/db/version_builder.cc +43 -1
  55. package/deps/rocksdb/rocksdb/db/version_edit.cc +13 -5
  56. package/deps/rocksdb/rocksdb/db/version_edit.h +22 -1
  57. package/deps/rocksdb/rocksdb/db/version_edit_handler.cc +4 -5
  58. package/deps/rocksdb/rocksdb/db/version_set.cc +109 -41
  59. package/deps/rocksdb/rocksdb/db/version_set.h +36 -3
  60. package/deps/rocksdb/rocksdb/db/version_set_sync_and_async.h +1 -4
  61. package/deps/rocksdb/rocksdb/db/version_set_test.cc +10 -10
  62. package/deps/rocksdb/rocksdb/db/version_util.h +1 -1
  63. package/deps/rocksdb/rocksdb/db/wal_manager_test.cc +1 -1
  64. package/deps/rocksdb/rocksdb/db/write_batch.cc +34 -10
  65. package/deps/rocksdb/rocksdb/db/write_batch_internal.h +2 -0
  66. package/deps/rocksdb/rocksdb/db/write_callback_test.cc +4 -0
  67. package/deps/rocksdb/rocksdb/db_stress_tool/batched_ops_stress.cc +2 -0
  68. package/deps/rocksdb/rocksdb/db_stress_tool/cf_consistency_stress.cc +4 -1
  69. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.h +1 -1
  70. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_gflags.cc +7 -5
  71. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.cc +5 -10
  72. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_tool.cc +0 -7
  73. package/deps/rocksdb/rocksdb/db_stress_tool/no_batched_ops_stress.cc +2 -0
  74. package/deps/rocksdb/rocksdb/file/random_access_file_reader.cc +24 -3
  75. package/deps/rocksdb/rocksdb/file/writable_file_writer.cc +8 -0
  76. package/deps/rocksdb/rocksdb/file/writable_file_writer.h +10 -0
  77. package/deps/rocksdb/rocksdb/include/rocksdb/advanced_options.h +5 -0
  78. package/deps/rocksdb/rocksdb/include/rocksdb/cache.h +4 -4
  79. package/deps/rocksdb/rocksdb/include/rocksdb/options.h +9 -5
  80. package/deps/rocksdb/rocksdb/include/rocksdb/statistics.h +5 -0
  81. package/deps/rocksdb/rocksdb/include/rocksdb/types.h +1 -0
  82. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/write_batch_with_index.h +1 -1
  83. package/deps/rocksdb/rocksdb/include/rocksdb/version.h +1 -1
  84. package/deps/rocksdb/rocksdb/include/rocksdb/write_batch.h +0 -3
  85. package/deps/rocksdb/rocksdb/microbench/ribbon_bench.cc +8 -6
  86. package/deps/rocksdb/rocksdb/monitoring/statistics.cc +3 -1
  87. package/deps/rocksdb/rocksdb/options/options_helper.cc +4 -2
  88. package/deps/rocksdb/rocksdb/options/options_test.cc +1 -11
  89. package/deps/rocksdb/rocksdb/port/port_posix.h +7 -0
  90. package/deps/rocksdb/rocksdb/port/win/port_win.h +11 -3
  91. package/deps/rocksdb/rocksdb/src.mk +6 -2
  92. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.cc +4 -33
  93. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.h +3 -3
  94. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.cc +38 -118
  95. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.h +6 -8
  96. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_sync_and_async.h +10 -13
  97. package/deps/rocksdb/rocksdb/table/block_based/block_like_traits.h +4 -9
  98. package/deps/rocksdb/rocksdb/table/block_based/block_type.h +0 -1
  99. package/deps/rocksdb/rocksdb/table/block_based/filter_block.h +10 -28
  100. package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.cc +2 -3
  101. package/deps/rocksdb/rocksdb/table/block_based/filter_policy.cc +0 -91
  102. package/deps/rocksdb/rocksdb/table/block_based/filter_policy_internal.h +2 -30
  103. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.cc +6 -27
  104. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.h +11 -13
  105. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block_test.cc +28 -40
  106. package/deps/rocksdb/rocksdb/table/block_based/mock_block_based_table.h +0 -1
  107. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.cc +22 -43
  108. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.h +11 -22
  109. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block_test.cc +24 -25
  110. package/deps/rocksdb/rocksdb/table/block_fetcher.cc +0 -1
  111. package/deps/rocksdb/rocksdb/table/get_context.h +0 -1
  112. package/deps/rocksdb/rocksdb/table/table_test.cc +3 -18
  113. package/deps/rocksdb/rocksdb/tools/db_bench_tool.cc +3 -16
  114. package/deps/rocksdb/rocksdb/tools/ldb_cmd.cc +3 -3
  115. package/deps/rocksdb/rocksdb/tools/ldb_cmd_test.cc +1 -1
  116. package/deps/rocksdb/rocksdb/util/bloom_test.cc +0 -201
  117. package/deps/rocksdb/rocksdb/util/distributed_mutex.h +48 -0
  118. package/deps/rocksdb/rocksdb/util/filter_bench.cc +5 -11
  119. package/deps/rocksdb/rocksdb/utilities/backup/backup_engine.cc +3 -0
  120. package/deps/rocksdb/rocksdb/utilities/cache_dump_load_impl.cc +7 -21
  121. package/deps/rocksdb/rocksdb/utilities/cache_dump_load_impl.h +1 -1
  122. package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_test.cc +45 -0
  123. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction_db.h +21 -14
  124. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_base.cc +10 -1
  125. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn.cc +3 -1
  126. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.cc +9 -0
  127. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn.cc +3 -2
  128. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn_db.cc +3 -1
  129. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index.cc +5 -4
  130. package/deps/rocksdb/rocksdb.gyp +1 -1
  131. package/index.js +36 -14
  132. package/package-lock.json +23687 -0
  133. package/package.json +1 -1
  134. package/prebuilds/darwin-arm64/node.napi.node +0 -0
  135. package/prebuilds/darwin-x64/node.napi.node +0 -0
  136. package/prebuilds/linux-x64/node.napi.node +0 -0
  137. package/deps/liburing/liburing/README +0 -46
  138. package/deps/liburing/liburing/test/232c93d07b74-test.c +0 -305
  139. package/deps/liburing/liburing/test/35fa71a030ca-test.c +0 -329
  140. package/deps/liburing/liburing/test/500f9fbadef8-test.c +0 -89
  141. package/deps/liburing/liburing/test/7ad0e4b2f83c-test.c +0 -93
  142. package/deps/liburing/liburing/test/8a9973408177-test.c +0 -106
  143. package/deps/liburing/liburing/test/917257daa0fe-test.c +0 -53
  144. package/deps/liburing/liburing/test/Makefile +0 -312
  145. package/deps/liburing/liburing/test/a0908ae19763-test.c +0 -58
  146. package/deps/liburing/liburing/test/a4c0b3decb33-test.c +0 -180
  147. package/deps/liburing/liburing/test/accept-link.c +0 -251
  148. package/deps/liburing/liburing/test/accept-reuse.c +0 -164
  149. package/deps/liburing/liburing/test/accept-test.c +0 -79
  150. package/deps/liburing/liburing/test/accept.c +0 -476
  151. package/deps/liburing/liburing/test/across-fork.c +0 -283
  152. package/deps/liburing/liburing/test/b19062a56726-test.c +0 -53
  153. package/deps/liburing/liburing/test/b5837bd5311d-test.c +0 -77
  154. package/deps/liburing/liburing/test/ce593a6c480a-test.c +0 -135
  155. package/deps/liburing/liburing/test/close-opath.c +0 -122
  156. package/deps/liburing/liburing/test/config +0 -10
  157. package/deps/liburing/liburing/test/connect.c +0 -398
  158. package/deps/liburing/liburing/test/cq-full.c +0 -96
  159. package/deps/liburing/liburing/test/cq-overflow.c +0 -294
  160. package/deps/liburing/liburing/test/cq-peek-batch.c +0 -102
  161. package/deps/liburing/liburing/test/cq-ready.c +0 -94
  162. package/deps/liburing/liburing/test/cq-size.c +0 -58
  163. package/deps/liburing/liburing/test/d4ae271dfaae-test.c +0 -96
  164. package/deps/liburing/liburing/test/d77a67ed5f27-test.c +0 -65
  165. package/deps/liburing/liburing/test/defer.c +0 -307
  166. package/deps/liburing/liburing/test/double-poll-crash.c +0 -186
  167. package/deps/liburing/liburing/test/eeed8b54e0df-test.c +0 -114
  168. package/deps/liburing/liburing/test/empty-eownerdead.c +0 -42
  169. package/deps/liburing/liburing/test/eventfd-disable.c +0 -151
  170. package/deps/liburing/liburing/test/eventfd-ring.c +0 -97
  171. package/deps/liburing/liburing/test/eventfd.c +0 -112
  172. package/deps/liburing/liburing/test/fadvise.c +0 -202
  173. package/deps/liburing/liburing/test/fallocate.c +0 -249
  174. package/deps/liburing/liburing/test/fc2a85cb02ef-test.c +0 -138
  175. package/deps/liburing/liburing/test/file-register.c +0 -843
  176. package/deps/liburing/liburing/test/file-update.c +0 -173
  177. package/deps/liburing/liburing/test/files-exit-hang-poll.c +0 -128
  178. package/deps/liburing/liburing/test/files-exit-hang-timeout.c +0 -134
  179. package/deps/liburing/liburing/test/fixed-link.c +0 -90
  180. package/deps/liburing/liburing/test/fsync.c +0 -224
  181. package/deps/liburing/liburing/test/hardlink.c +0 -136
  182. package/deps/liburing/liburing/test/helpers.c +0 -135
  183. package/deps/liburing/liburing/test/helpers.h +0 -67
  184. package/deps/liburing/liburing/test/io-cancel.c +0 -537
  185. package/deps/liburing/liburing/test/io_uring_enter.c +0 -296
  186. package/deps/liburing/liburing/test/io_uring_register.c +0 -664
  187. package/deps/liburing/liburing/test/io_uring_setup.c +0 -192
  188. package/deps/liburing/liburing/test/iopoll.c +0 -366
  189. package/deps/liburing/liburing/test/lfs-openat-write.c +0 -117
  190. package/deps/liburing/liburing/test/lfs-openat.c +0 -273
  191. package/deps/liburing/liburing/test/link-timeout.c +0 -1107
  192. package/deps/liburing/liburing/test/link.c +0 -496
  193. package/deps/liburing/liburing/test/link_drain.c +0 -229
  194. package/deps/liburing/liburing/test/madvise.c +0 -195
  195. package/deps/liburing/liburing/test/mkdir.c +0 -108
  196. package/deps/liburing/liburing/test/multicqes_drain.c +0 -383
  197. package/deps/liburing/liburing/test/nop-all-sizes.c +0 -107
  198. package/deps/liburing/liburing/test/nop.c +0 -115
  199. package/deps/liburing/liburing/test/open-close.c +0 -146
  200. package/deps/liburing/liburing/test/openat2.c +0 -240
  201. package/deps/liburing/liburing/test/personality.c +0 -204
  202. package/deps/liburing/liburing/test/pipe-eof.c +0 -81
  203. package/deps/liburing/liburing/test/pipe-reuse.c +0 -105
  204. package/deps/liburing/liburing/test/poll-cancel-ton.c +0 -139
  205. package/deps/liburing/liburing/test/poll-cancel.c +0 -135
  206. package/deps/liburing/liburing/test/poll-link.c +0 -227
  207. package/deps/liburing/liburing/test/poll-many.c +0 -208
  208. package/deps/liburing/liburing/test/poll-mshot-update.c +0 -273
  209. package/deps/liburing/liburing/test/poll-ring.c +0 -48
  210. package/deps/liburing/liburing/test/poll-v-poll.c +0 -353
  211. package/deps/liburing/liburing/test/poll.c +0 -109
  212. package/deps/liburing/liburing/test/probe.c +0 -137
  213. package/deps/liburing/liburing/test/read-write.c +0 -876
  214. package/deps/liburing/liburing/test/register-restrictions.c +0 -633
  215. package/deps/liburing/liburing/test/rename.c +0 -134
  216. package/deps/liburing/liburing/test/ring-leak.c +0 -173
  217. package/deps/liburing/liburing/test/ring-leak2.c +0 -249
  218. package/deps/liburing/liburing/test/rsrc_tags.c +0 -449
  219. package/deps/liburing/liburing/test/runtests-loop.sh +0 -16
  220. package/deps/liburing/liburing/test/runtests.sh +0 -170
  221. package/deps/liburing/liburing/test/rw_merge_test.c +0 -97
  222. package/deps/liburing/liburing/test/self.c +0 -91
  223. package/deps/liburing/liburing/test/send_recv.c +0 -291
  224. package/deps/liburing/liburing/test/send_recvmsg.c +0 -345
  225. package/deps/liburing/liburing/test/sendmsg_fs_cve.c +0 -198
  226. package/deps/liburing/liburing/test/shared-wq.c +0 -84
  227. package/deps/liburing/liburing/test/short-read.c +0 -75
  228. package/deps/liburing/liburing/test/shutdown.c +0 -163
  229. package/deps/liburing/liburing/test/sigfd-deadlock.c +0 -74
  230. package/deps/liburing/liburing/test/socket-rw-eagain.c +0 -156
  231. package/deps/liburing/liburing/test/socket-rw.c +0 -147
  232. package/deps/liburing/liburing/test/splice.c +0 -511
  233. package/deps/liburing/liburing/test/sq-full-cpp.cc +0 -45
  234. package/deps/liburing/liburing/test/sq-full.c +0 -45
  235. package/deps/liburing/liburing/test/sq-poll-dup.c +0 -200
  236. package/deps/liburing/liburing/test/sq-poll-kthread.c +0 -168
  237. package/deps/liburing/liburing/test/sq-poll-share.c +0 -137
  238. package/deps/liburing/liburing/test/sq-space_left.c +0 -159
  239. package/deps/liburing/liburing/test/sqpoll-cancel-hang.c +0 -159
  240. package/deps/liburing/liburing/test/sqpoll-disable-exit.c +0 -195
  241. package/deps/liburing/liburing/test/sqpoll-exit-hang.c +0 -77
  242. package/deps/liburing/liburing/test/sqpoll-sleep.c +0 -68
  243. package/deps/liburing/liburing/test/statx.c +0 -172
  244. package/deps/liburing/liburing/test/stdout.c +0 -232
  245. package/deps/liburing/liburing/test/submit-link-fail.c +0 -154
  246. package/deps/liburing/liburing/test/submit-reuse.c +0 -239
  247. package/deps/liburing/liburing/test/symlink.c +0 -116
  248. package/deps/liburing/liburing/test/teardowns.c +0 -58
  249. package/deps/liburing/liburing/test/thread-exit.c +0 -131
  250. package/deps/liburing/liburing/test/timeout-new.c +0 -246
  251. package/deps/liburing/liburing/test/timeout-overflow.c +0 -204
  252. package/deps/liburing/liburing/test/timeout.c +0 -1354
  253. package/deps/liburing/liburing/test/unlink.c +0 -111
  254. package/deps/liburing/liburing/test/wakeup-hang.c +0 -162
  255. package/deps/rocksdb/rocksdb/README.md +0 -32
  256. package/deps/rocksdb/rocksdb/microbench/README.md +0 -60
  257. package/deps/rocksdb/rocksdb/plugin/README.md +0 -43
  258. package/deps/rocksdb/rocksdb/port/README +0 -10
  259. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.cc +0 -358
  260. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.h +0 -127
  261. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block_test.cc +0 -219
  262. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/README +0 -13
@@ -1,1107 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: run various linked timeout cases
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
- #include <sys/poll.h>
13
-
14
- #include "liburing.h"
15
-
16
- static int test_fail_lone_link_timeouts(struct io_uring *ring)
17
- {
18
- struct __kernel_timespec ts;
19
- struct io_uring_cqe *cqe;
20
- struct io_uring_sqe *sqe;
21
- int ret;
22
-
23
- sqe = io_uring_get_sqe(ring);
24
- if (!sqe) {
25
- printf("get sqe failed\n");
26
- goto err;
27
- }
28
- io_uring_prep_link_timeout(sqe, &ts, 0);
29
- ts.tv_sec = 1;
30
- ts.tv_nsec = 0;
31
- sqe->user_data = 1;
32
- sqe->flags |= IOSQE_IO_LINK;
33
-
34
- ret = io_uring_submit(ring);
35
- if (ret != 1) {
36
- printf("sqe submit failed: %d\n", ret);
37
- goto err;
38
- }
39
-
40
- ret = io_uring_wait_cqe(ring, &cqe);
41
- if (ret < 0) {
42
- printf("wait completion %d\n", ret);
43
- goto err;
44
- }
45
-
46
- if (cqe->user_data != 1) {
47
- fprintf(stderr, "invalid user data %d\n", cqe->res);
48
- goto err;
49
- }
50
- if (cqe->res != -EINVAL) {
51
- fprintf(stderr, "got %d, wanted -EINVAL\n", cqe->res);
52
- goto err;
53
- }
54
- io_uring_cqe_seen(ring, cqe);
55
-
56
- return 0;
57
- err:
58
- return 1;
59
- }
60
-
61
- static int test_fail_two_link_timeouts(struct io_uring *ring)
62
- {
63
- struct __kernel_timespec ts;
64
- struct io_uring_cqe *cqe;
65
- struct io_uring_sqe *sqe;
66
- int ret, i, nr_wait;
67
-
68
- ts.tv_sec = 1;
69
- ts.tv_nsec = 0;
70
-
71
- /*
72
- * sqe_1: write destined to fail
73
- * use buf=NULL, to do that during the issuing stage
74
- */
75
- sqe = io_uring_get_sqe(ring);
76
- if (!sqe) {
77
- printf("get sqe failed\n");
78
- goto err;
79
- }
80
- io_uring_prep_writev(sqe, 0, NULL, 1, 0);
81
- sqe->flags |= IOSQE_IO_LINK;
82
- sqe->user_data = 1;
83
-
84
-
85
- /* sqe_2: valid linked timeout */
86
- sqe = io_uring_get_sqe(ring);
87
- if (!sqe) {
88
- printf("get sqe failed\n");
89
- goto err;
90
- }
91
- io_uring_prep_link_timeout(sqe, &ts, 0);
92
- sqe->user_data = 2;
93
- sqe->flags |= IOSQE_IO_LINK;
94
-
95
-
96
- /* sqe_3: invalid linked timeout */
97
- sqe = io_uring_get_sqe(ring);
98
- if (!sqe) {
99
- printf("get sqe failed\n");
100
- goto err;
101
- }
102
- io_uring_prep_link_timeout(sqe, &ts, 0);
103
- sqe->flags |= IOSQE_IO_LINK;
104
- sqe->user_data = 3;
105
-
106
- /* sqe_4: invalid linked timeout */
107
- sqe = io_uring_get_sqe(ring);
108
- if (!sqe) {
109
- printf("get sqe failed\n");
110
- goto err;
111
- }
112
- io_uring_prep_link_timeout(sqe, &ts, 0);
113
- sqe->flags |= IOSQE_IO_LINK;
114
- sqe->user_data = 4;
115
-
116
- ret = io_uring_submit(ring);
117
- if (ret < 3) {
118
- printf("sqe submit failed: %d\n", ret);
119
- goto err;
120
- }
121
- nr_wait = ret;
122
-
123
- for (i = 0; i < nr_wait; i++) {
124
- ret = io_uring_wait_cqe(ring, &cqe);
125
- if (ret < 0) {
126
- printf("wait completion %d\n", ret);
127
- goto err;
128
- }
129
-
130
- switch (cqe->user_data) {
131
- case 1:
132
- if (cqe->res != -EFAULT && cqe->res != -ECANCELED) {
133
- fprintf(stderr, "write got %d, wanted -EFAULT "
134
- "or -ECANCELED\n", cqe->res);
135
- goto err;
136
- }
137
- break;
138
- case 2:
139
- if (cqe->res != -ECANCELED) {
140
- fprintf(stderr, "Link timeout got %d, wanted -ECACNCELED\n", cqe->res);
141
- goto err;
142
- }
143
- break;
144
- case 3:
145
- /* fall through */
146
- case 4:
147
- if (cqe->res != -ECANCELED && cqe->res != -EINVAL) {
148
- fprintf(stderr, "Invalid link timeout got %d"
149
- ", wanted -ECACNCELED || -EINVAL\n", cqe->res);
150
- goto err;
151
- }
152
- break;
153
- }
154
- io_uring_cqe_seen(ring, cqe);
155
- }
156
-
157
- return 0;
158
- err:
159
- return 1;
160
- }
161
-
162
- /*
163
- * Test linked timeout with timeout (timeoutception)
164
- */
165
- static int test_single_link_timeout_ception(struct io_uring *ring)
166
- {
167
- struct __kernel_timespec ts1, ts2;
168
- struct io_uring_cqe *cqe;
169
- struct io_uring_sqe *sqe;
170
- int ret, i;
171
-
172
- sqe = io_uring_get_sqe(ring);
173
- if (!sqe) {
174
- printf("get sqe failed\n");
175
- goto err;
176
- }
177
-
178
- ts1.tv_sec = 1;
179
- ts1.tv_nsec = 0;
180
- io_uring_prep_timeout(sqe, &ts1, -1U, 0);
181
- sqe->flags |= IOSQE_IO_LINK;
182
- sqe->user_data = 1;
183
-
184
- sqe = io_uring_get_sqe(ring);
185
- if (!sqe) {
186
- printf("get sqe failed\n");
187
- goto err;
188
- }
189
-
190
- ts2.tv_sec = 2;
191
- ts2.tv_nsec = 0;
192
- io_uring_prep_link_timeout(sqe, &ts2, 0);
193
- sqe->user_data = 2;
194
-
195
- ret = io_uring_submit(ring);
196
- if (ret != 2) {
197
- printf("sqe submit failed: %d\n", ret);
198
- goto err;
199
- }
200
-
201
- for (i = 0; i < 2; i++) {
202
- ret = io_uring_wait_cqe(ring, &cqe);
203
- if (ret < 0) {
204
- printf("wait completion %d\n", ret);
205
- goto err;
206
- }
207
- switch (cqe->user_data) {
208
- case 1:
209
- /* newer kernels allow timeout links */
210
- if (cqe->res != -EINVAL && cqe->res != -ETIME) {
211
- fprintf(stderr, "Timeout got %d, wanted "
212
- "-EINVAL or -ETIME\n", cqe->res);
213
- goto err;
214
- }
215
- break;
216
- case 2:
217
- if (cqe->res != -ECANCELED) {
218
- fprintf(stderr, "Link timeout got %d, wanted -ECANCELED\n", cqe->res);
219
- goto err;
220
- }
221
- break;
222
- }
223
- io_uring_cqe_seen(ring, cqe);
224
- }
225
-
226
- return 0;
227
- err:
228
- return 1;
229
- }
230
-
231
- /*
232
- * Test linked timeout with NOP
233
- */
234
- static int test_single_link_timeout_nop(struct io_uring *ring)
235
- {
236
- struct __kernel_timespec ts;
237
- struct io_uring_cqe *cqe;
238
- struct io_uring_sqe *sqe;
239
- int ret, i;
240
-
241
- sqe = io_uring_get_sqe(ring);
242
- if (!sqe) {
243
- printf("get sqe failed\n");
244
- goto err;
245
- }
246
-
247
- io_uring_prep_nop(sqe);
248
- sqe->flags |= IOSQE_IO_LINK;
249
- sqe->user_data = 1;
250
-
251
- sqe = io_uring_get_sqe(ring);
252
- if (!sqe) {
253
- printf("get sqe failed\n");
254
- goto err;
255
- }
256
-
257
- ts.tv_sec = 1;
258
- ts.tv_nsec = 0;
259
- io_uring_prep_link_timeout(sqe, &ts, 0);
260
- sqe->user_data = 2;
261
-
262
- ret = io_uring_submit(ring);
263
- if (ret != 2) {
264
- printf("sqe submit failed: %d\n", ret);
265
- goto err;
266
- }
267
-
268
- for (i = 0; i < 2; i++) {
269
- ret = io_uring_wait_cqe(ring, &cqe);
270
- if (ret < 0) {
271
- printf("wait completion %d\n", ret);
272
- goto err;
273
- }
274
- switch (cqe->user_data) {
275
- case 1:
276
- if (cqe->res) {
277
- fprintf(stderr, "NOP got %d, wanted 0\n", cqe->res);
278
- goto err;
279
- }
280
- break;
281
- case 2:
282
- if (cqe->res != -ECANCELED) {
283
- fprintf(stderr, "Link timeout got %d, wanted -ECACNCELED\n", cqe->res);
284
- goto err;
285
- }
286
- break;
287
- }
288
- io_uring_cqe_seen(ring, cqe);
289
- }
290
-
291
- return 0;
292
- err:
293
- return 1;
294
- }
295
-
296
- /*
297
- * Test read that will not complete, with a linked timeout behind it that
298
- * has errors in the SQE
299
- */
300
- static int test_single_link_timeout_error(struct io_uring *ring)
301
- {
302
- struct __kernel_timespec ts;
303
- struct io_uring_cqe *cqe;
304
- struct io_uring_sqe *sqe;
305
- int fds[2], ret, i;
306
- struct iovec iov;
307
- char buffer[128];
308
-
309
- if (pipe(fds)) {
310
- perror("pipe");
311
- return 1;
312
- }
313
-
314
- sqe = io_uring_get_sqe(ring);
315
- if (!sqe) {
316
- printf("get sqe failed\n");
317
- goto err;
318
- }
319
-
320
- iov.iov_base = buffer;
321
- iov.iov_len = sizeof(buffer);
322
- io_uring_prep_readv(sqe, fds[0], &iov, 1, 0);
323
- sqe->flags |= IOSQE_IO_LINK;
324
- sqe->user_data = 1;
325
-
326
- sqe = io_uring_get_sqe(ring);
327
- if (!sqe) {
328
- printf("get sqe failed\n");
329
- goto err;
330
- }
331
-
332
- ts.tv_sec = 1;
333
- ts.tv_nsec = 0;
334
- io_uring_prep_link_timeout(sqe, &ts, 0);
335
- /* set invalid field, it'll get failed */
336
- sqe->ioprio = 89;
337
- sqe->user_data = 2;
338
-
339
- ret = io_uring_submit(ring);
340
- if (ret != 2) {
341
- printf("sqe submit failed: %d\n", ret);
342
- goto err;
343
- }
344
-
345
- for (i = 0; i < 2; i++) {
346
- ret = io_uring_wait_cqe(ring, &cqe);
347
- if (ret < 0) {
348
- printf("wait completion %d\n", ret);
349
- goto err;
350
- }
351
- switch (cqe->user_data) {
352
- case 1:
353
- if (cqe->res != -ECANCELED) {
354
- fprintf(stderr, "Read got %d, wanted -ECANCELED\n",
355
- cqe->res);
356
- goto err;
357
- }
358
- break;
359
- case 2:
360
- if (cqe->res != -EINVAL) {
361
- fprintf(stderr, "Link timeout got %d, wanted -EINVAL\n", cqe->res);
362
- goto err;
363
- }
364
- break;
365
- }
366
- io_uring_cqe_seen(ring, cqe);
367
- }
368
-
369
- return 0;
370
- err:
371
- return 1;
372
- }
373
-
374
- /*
375
- * Test read that will complete, with a linked timeout behind it
376
- */
377
- static int test_single_link_no_timeout(struct io_uring *ring)
378
- {
379
- struct __kernel_timespec ts;
380
- struct io_uring_cqe *cqe;
381
- struct io_uring_sqe *sqe;
382
- int fds[2], ret, i;
383
- struct iovec iov;
384
- char buffer[128];
385
-
386
- if (pipe(fds)) {
387
- perror("pipe");
388
- return 1;
389
- }
390
-
391
- sqe = io_uring_get_sqe(ring);
392
- if (!sqe) {
393
- printf("get sqe failed\n");
394
- goto err;
395
- }
396
-
397
- iov.iov_base = buffer;
398
- iov.iov_len = sizeof(buffer);
399
- io_uring_prep_readv(sqe, fds[0], &iov, 1, 0);
400
- sqe->flags |= IOSQE_IO_LINK;
401
- sqe->user_data = 1;
402
-
403
- sqe = io_uring_get_sqe(ring);
404
- if (!sqe) {
405
- printf("get sqe failed\n");
406
- goto err;
407
- }
408
-
409
- ts.tv_sec = 1;
410
- ts.tv_nsec = 0;
411
- io_uring_prep_link_timeout(sqe, &ts, 0);
412
- sqe->user_data = 2;
413
-
414
- sqe = io_uring_get_sqe(ring);
415
- if (!sqe) {
416
- printf("get sqe failed\n");
417
- goto err;
418
- }
419
-
420
- iov.iov_base = buffer;
421
- iov.iov_len = sizeof(buffer);
422
- io_uring_prep_writev(sqe, fds[1], &iov, 1, 0);
423
- sqe->user_data = 3;
424
-
425
- ret = io_uring_submit(ring);
426
- if (ret != 3) {
427
- printf("sqe submit failed: %d\n", ret);
428
- goto err;
429
- }
430
-
431
- for (i = 0; i < 3; i++) {
432
- ret = io_uring_wait_cqe(ring, &cqe);
433
- if (ret < 0) {
434
- printf("wait completion %d\n", ret);
435
- goto err;
436
- }
437
- switch (cqe->user_data) {
438
- case 1:
439
- case 3:
440
- if (cqe->res != sizeof(buffer)) {
441
- fprintf(stderr, "R/W got %d, wanted %d\n", cqe->res,
442
- (int) sizeof(buffer));
443
- goto err;
444
- }
445
- break;
446
- case 2:
447
- if (cqe->res != -ECANCELED) {
448
- fprintf(stderr, "Link timeout %d, wanted -ECANCELED\n",
449
- cqe->res);
450
- goto err;
451
- }
452
- break;
453
- }
454
- io_uring_cqe_seen(ring, cqe);
455
- }
456
-
457
- return 0;
458
- err:
459
- return 1;
460
- }
461
-
462
- /*
463
- * Test read that will not complete, with a linked timeout behind it
464
- */
465
- static int test_single_link_timeout(struct io_uring *ring, unsigned nsec)
466
- {
467
- struct __kernel_timespec ts;
468
- struct io_uring_cqe *cqe;
469
- struct io_uring_sqe *sqe;
470
- int fds[2], ret, i;
471
- struct iovec iov;
472
- char buffer[128];
473
-
474
- if (pipe(fds)) {
475
- perror("pipe");
476
- return 1;
477
- }
478
-
479
- sqe = io_uring_get_sqe(ring);
480
- if (!sqe) {
481
- printf("get sqe failed\n");
482
- goto err;
483
- }
484
-
485
- iov.iov_base = buffer;
486
- iov.iov_len = sizeof(buffer);
487
- io_uring_prep_readv(sqe, fds[0], &iov, 1, 0);
488
- sqe->flags |= IOSQE_IO_LINK;
489
- sqe->user_data = 1;
490
-
491
- sqe = io_uring_get_sqe(ring);
492
- if (!sqe) {
493
- printf("get sqe failed\n");
494
- goto err;
495
- }
496
-
497
- ts.tv_sec = 0;
498
- ts.tv_nsec = nsec;
499
- io_uring_prep_link_timeout(sqe, &ts, 0);
500
- sqe->user_data = 2;
501
-
502
- ret = io_uring_submit(ring);
503
- if (ret != 2) {
504
- printf("sqe submit failed: %d\n", ret);
505
- goto err;
506
- }
507
-
508
- for (i = 0; i < 2; i++) {
509
- ret = io_uring_wait_cqe(ring, &cqe);
510
- if (ret < 0) {
511
- printf("wait completion %d\n", ret);
512
- goto err;
513
- }
514
- switch (cqe->user_data) {
515
- case 1:
516
- if (cqe->res != -EINTR && cqe->res != -ECANCELED) {
517
- fprintf(stderr, "Read got %d\n", cqe->res);
518
- goto err;
519
- }
520
- break;
521
- case 2:
522
- if (cqe->res != -EALREADY && cqe->res != -ETIME &&
523
- cqe->res != 0) {
524
- fprintf(stderr, "Link timeout got %d\n", cqe->res);
525
- goto err;
526
- }
527
- break;
528
- }
529
- io_uring_cqe_seen(ring, cqe);
530
- }
531
-
532
- close(fds[0]);
533
- close(fds[1]);
534
- return 0;
535
- err:
536
- return 1;
537
- }
538
-
539
- static int test_timeout_link_chain1(struct io_uring *ring)
540
- {
541
- struct __kernel_timespec ts;
542
- struct io_uring_cqe *cqe;
543
- struct io_uring_sqe *sqe;
544
- int fds[2], ret, i;
545
- struct iovec iov;
546
- char buffer[128];
547
-
548
- if (pipe(fds)) {
549
- perror("pipe");
550
- return 1;
551
- }
552
-
553
- sqe = io_uring_get_sqe(ring);
554
- if (!sqe) {
555
- printf("get sqe failed\n");
556
- goto err;
557
- }
558
- iov.iov_base = buffer;
559
- iov.iov_len = sizeof(buffer);
560
- io_uring_prep_readv(sqe, fds[0], &iov, 1, 0);
561
- sqe->flags |= IOSQE_IO_LINK;
562
- sqe->user_data = 1;
563
-
564
- sqe = io_uring_get_sqe(ring);
565
- if (!sqe) {
566
- printf("get sqe failed\n");
567
- goto err;
568
- }
569
- ts.tv_sec = 0;
570
- ts.tv_nsec = 1000000;
571
- io_uring_prep_link_timeout(sqe, &ts, 0);
572
- sqe->flags |= IOSQE_IO_LINK;
573
- sqe->user_data = 2;
574
-
575
- sqe = io_uring_get_sqe(ring);
576
- if (!sqe) {
577
- printf("get sqe failed\n");
578
- goto err;
579
- }
580
- io_uring_prep_nop(sqe);
581
- sqe->user_data = 3;
582
-
583
- ret = io_uring_submit(ring);
584
- if (ret != 3) {
585
- printf("sqe submit failed: %d\n", ret);
586
- goto err;
587
- }
588
-
589
- for (i = 0; i < 3; i++) {
590
- ret = io_uring_wait_cqe(ring, &cqe);
591
- if (ret < 0) {
592
- printf("wait completion %d\n", ret);
593
- goto err;
594
- }
595
- switch (cqe->user_data) {
596
- case 1:
597
- if (cqe->res != -EINTR && cqe->res != -ECANCELED) {
598
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
599
- cqe->res);
600
- goto err;
601
- }
602
- break;
603
- case 2:
604
- /* FASTPOLL kernels can cancel successfully */
605
- if (cqe->res != -EALREADY && cqe->res != -ETIME) {
606
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
607
- cqe->res);
608
- goto err;
609
- }
610
- break;
611
- case 3:
612
- if (cqe->res != -ECANCELED) {
613
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
614
- cqe->res);
615
- goto err;
616
- }
617
- break;
618
- }
619
-
620
- io_uring_cqe_seen(ring, cqe);
621
- }
622
-
623
- close(fds[0]);
624
- close(fds[1]);
625
- return 0;
626
- err:
627
- return 1;
628
- }
629
-
630
- static int test_timeout_link_chain2(struct io_uring *ring)
631
- {
632
- struct __kernel_timespec ts;
633
- struct io_uring_cqe *cqe;
634
- struct io_uring_sqe *sqe;
635
- int fds[2], ret, i;
636
-
637
- if (pipe(fds)) {
638
- perror("pipe");
639
- return 1;
640
- }
641
-
642
- sqe = io_uring_get_sqe(ring);
643
- if (!sqe) {
644
- printf("get sqe failed\n");
645
- goto err;
646
- }
647
- io_uring_prep_poll_add(sqe, fds[0], POLLIN);
648
- sqe->flags |= IOSQE_IO_LINK;
649
- sqe->user_data = 1;
650
-
651
- sqe = io_uring_get_sqe(ring);
652
- if (!sqe) {
653
- printf("get sqe failed\n");
654
- goto err;
655
- }
656
- ts.tv_sec = 0;
657
- ts.tv_nsec = 1000000;
658
- io_uring_prep_link_timeout(sqe, &ts, 0);
659
- sqe->flags |= IOSQE_IO_LINK;
660
- sqe->user_data = 2;
661
-
662
- sqe = io_uring_get_sqe(ring);
663
- if (!sqe) {
664
- printf("get sqe failed\n");
665
- goto err;
666
- }
667
- io_uring_prep_nop(sqe);
668
- sqe->flags |= IOSQE_IO_LINK;
669
- sqe->user_data = 3;
670
-
671
- sqe = io_uring_get_sqe(ring);
672
- if (!sqe) {
673
- printf("get sqe failed\n");
674
- goto err;
675
- }
676
- io_uring_prep_nop(sqe);
677
- sqe->user_data = 4;
678
-
679
- ret = io_uring_submit(ring);
680
- if (ret != 4) {
681
- printf("sqe submit failed: %d\n", ret);
682
- goto err;
683
- }
684
-
685
- for (i = 0; i < 4; i++) {
686
- ret = io_uring_wait_cqe(ring, &cqe);
687
- if (ret < 0) {
688
- printf("wait completion %d\n", ret);
689
- goto err;
690
- }
691
- switch (cqe->user_data) {
692
- /* poll cancel really should return -ECANCEL... */
693
- case 1:
694
- if (cqe->res != -ECANCELED) {
695
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
696
- cqe->res);
697
- goto err;
698
- }
699
- break;
700
- case 2:
701
- if (cqe->res != -ETIME) {
702
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
703
- cqe->res);
704
- goto err;
705
- }
706
- break;
707
- case 3:
708
- case 4:
709
- if (cqe->res != -ECANCELED) {
710
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
711
- cqe->res);
712
- goto err;
713
- }
714
- break;
715
- }
716
- io_uring_cqe_seen(ring, cqe);
717
- }
718
-
719
- close(fds[0]);
720
- close(fds[1]);
721
- return 0;
722
- err:
723
- return 1;
724
- }
725
-
726
- static int test_timeout_link_chain3(struct io_uring *ring)
727
- {
728
- struct __kernel_timespec ts;
729
- struct io_uring_cqe *cqe;
730
- struct io_uring_sqe *sqe;
731
- int fds[2], ret, i;
732
-
733
- if (pipe(fds)) {
734
- perror("pipe");
735
- return 1;
736
- }
737
-
738
- sqe = io_uring_get_sqe(ring);
739
- if (!sqe) {
740
- printf("get sqe failed\n");
741
- goto err;
742
- }
743
- io_uring_prep_poll_add(sqe, fds[0], POLLIN);
744
- sqe->flags |= IOSQE_IO_LINK;
745
- sqe->user_data = 1;
746
-
747
- sqe = io_uring_get_sqe(ring);
748
- if (!sqe) {
749
- printf("get sqe failed\n");
750
- goto err;
751
- }
752
- ts.tv_sec = 0;
753
- ts.tv_nsec = 1000000;
754
- io_uring_prep_link_timeout(sqe, &ts, 0);
755
- sqe->flags |= IOSQE_IO_LINK;
756
- sqe->user_data = 2;
757
-
758
- sqe = io_uring_get_sqe(ring);
759
- if (!sqe) {
760
- printf("get sqe failed\n");
761
- goto err;
762
- }
763
- io_uring_prep_nop(sqe);
764
- sqe->flags |= IOSQE_IO_LINK;
765
- sqe->user_data = 3;
766
-
767
- /* POLL -> TIMEOUT -> NOP */
768
-
769
- sqe = io_uring_get_sqe(ring);
770
- if (!sqe) {
771
- printf("get sqe failed\n");
772
- goto err;
773
- }
774
- io_uring_prep_poll_add(sqe, fds[0], POLLIN);
775
- sqe->flags |= IOSQE_IO_LINK;
776
- sqe->user_data = 4;
777
-
778
- sqe = io_uring_get_sqe(ring);
779
- if (!sqe) {
780
- printf("get sqe failed\n");
781
- goto err;
782
- }
783
- ts.tv_sec = 0;
784
- ts.tv_nsec = 1000000;
785
- io_uring_prep_link_timeout(sqe, &ts, 0);
786
- sqe->user_data = 5;
787
-
788
- /* poll on pipe + timeout */
789
-
790
- sqe = io_uring_get_sqe(ring);
791
- if (!sqe) {
792
- printf("get sqe failed\n");
793
- goto err;
794
- }
795
- io_uring_prep_nop(sqe);
796
- sqe->user_data = 6;
797
-
798
- /* nop */
799
-
800
- ret = io_uring_submit(ring);
801
- if (ret != 6) {
802
- printf("sqe submit failed: %d\n", ret);
803
- goto err;
804
- }
805
-
806
- for (i = 0; i < 6; i++) {
807
- ret = io_uring_wait_cqe(ring, &cqe);
808
- if (ret < 0) {
809
- printf("wait completion %d\n", ret);
810
- goto err;
811
- }
812
- switch (cqe->user_data) {
813
- case 2:
814
- if (cqe->res != -ETIME) {
815
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
816
- cqe->res);
817
- goto err;
818
- }
819
- break;
820
- case 1:
821
- case 3:
822
- case 4:
823
- case 5:
824
- if (cqe->res != -ECANCELED) {
825
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
826
- cqe->res);
827
- goto err;
828
- }
829
- break;
830
- case 6:
831
- if (cqe->res) {
832
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
833
- cqe->res);
834
- goto err;
835
- }
836
- break;
837
- }
838
- io_uring_cqe_seen(ring, cqe);
839
- }
840
-
841
- close(fds[0]);
842
- close(fds[1]);
843
- return 0;
844
- err:
845
- return 1;
846
- }
847
-
848
- static int test_timeout_link_chain4(struct io_uring *ring)
849
- {
850
- struct __kernel_timespec ts;
851
- struct io_uring_cqe *cqe;
852
- struct io_uring_sqe *sqe;
853
- int fds[2], ret, i;
854
-
855
- if (pipe(fds)) {
856
- perror("pipe");
857
- return 1;
858
- }
859
-
860
- sqe = io_uring_get_sqe(ring);
861
- if (!sqe) {
862
- printf("get sqe failed\n");
863
- goto err;
864
- }
865
- io_uring_prep_nop(sqe);
866
- sqe->flags |= IOSQE_IO_LINK;
867
- sqe->user_data = 1;
868
-
869
- sqe = io_uring_get_sqe(ring);
870
- if (!sqe) {
871
- printf("get sqe failed\n");
872
- goto err;
873
- }
874
- io_uring_prep_poll_add(sqe, fds[0], POLLIN);
875
- sqe->flags |= IOSQE_IO_LINK;
876
- sqe->user_data = 2;
877
-
878
- sqe = io_uring_get_sqe(ring);
879
- if (!sqe) {
880
- printf("get sqe failed\n");
881
- goto err;
882
- }
883
- ts.tv_sec = 0;
884
- ts.tv_nsec = 1000000;
885
- io_uring_prep_link_timeout(sqe, &ts, 0);
886
- sqe->user_data = 3;
887
-
888
- ret = io_uring_submit(ring);
889
- if (ret != 3) {
890
- printf("sqe submit failed: %d\n", ret);
891
- goto err;
892
- }
893
-
894
- for (i = 0; i < 3; i++) {
895
- ret = io_uring_wait_cqe(ring, &cqe);
896
- if (ret < 0) {
897
- printf("wait completion %d\n", ret);
898
- goto err;
899
- }
900
- switch (cqe->user_data) {
901
- /* poll cancel really should return -ECANCEL... */
902
- case 1:
903
- if (cqe->res) {
904
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
905
- cqe->res);
906
- goto err;
907
- }
908
- break;
909
- case 2:
910
- if (cqe->res != -ECANCELED) {
911
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
912
- cqe->res);
913
- goto err;
914
- }
915
- break;
916
- case 3:
917
- if (cqe->res != -ETIME) {
918
- fprintf(stderr, "Req %" PRIu64 " got %d\n", (uint64_t) cqe->user_data,
919
- cqe->res);
920
- goto err;
921
- }
922
- break;
923
- }
924
- io_uring_cqe_seen(ring, cqe);
925
- }
926
-
927
- close(fds[0]);
928
- close(fds[1]);
929
- return 0;
930
- err:
931
- return 1;
932
- }
933
-
934
- static int test_timeout_link_chain5(struct io_uring *ring)
935
- {
936
- struct __kernel_timespec ts1, ts2;
937
- struct io_uring_cqe *cqe;
938
- struct io_uring_sqe *sqe;
939
- int ret, i;
940
-
941
- sqe = io_uring_get_sqe(ring);
942
- if (!sqe) {
943
- printf("get sqe failed\n");
944
- goto err;
945
- }
946
- io_uring_prep_nop(sqe);
947
- sqe->flags |= IOSQE_IO_LINK;
948
- sqe->user_data = 1;
949
-
950
- sqe = io_uring_get_sqe(ring);
951
- if (!sqe) {
952
- printf("get sqe failed\n");
953
- goto err;
954
- }
955
- ts1.tv_sec = 1;
956
- ts1.tv_nsec = 0;
957
- io_uring_prep_link_timeout(sqe, &ts1, 0);
958
- sqe->flags |= IOSQE_IO_LINK;
959
- sqe->user_data = 2;
960
-
961
- sqe = io_uring_get_sqe(ring);
962
- if (!sqe) {
963
- printf("get sqe failed\n");
964
- goto err;
965
- }
966
- ts2.tv_sec = 2;
967
- ts2.tv_nsec = 0;
968
- io_uring_prep_link_timeout(sqe, &ts2, 0);
969
- sqe->user_data = 3;
970
-
971
- ret = io_uring_submit(ring);
972
- if (ret != 3) {
973
- printf("sqe submit failed: %d\n", ret);
974
- goto err;
975
- }
976
-
977
- for (i = 0; i < 3; i++) {
978
- ret = io_uring_wait_cqe(ring, &cqe);
979
- if (ret < 0) {
980
- printf("wait completion %d\n", ret);
981
- goto err;
982
- }
983
- switch (cqe->user_data) {
984
- case 1:
985
- case 2:
986
- if (cqe->res && cqe->res != -ECANCELED) {
987
- fprintf(stderr, "Request got %d, wanted -EINVAL "
988
- "or -ECANCELED\n",
989
- cqe->res);
990
- goto err;
991
- }
992
- break;
993
- case 3:
994
- if (cqe->res != -ECANCELED && cqe->res != -EINVAL) {
995
- fprintf(stderr, "Link timeout got %d, wanted -ECANCELED\n", cqe->res);
996
- goto err;
997
- }
998
- break;
999
- }
1000
- io_uring_cqe_seen(ring, cqe);
1001
- }
1002
-
1003
- return 0;
1004
- err:
1005
- return 1;
1006
- }
1007
-
1008
- int main(int argc, char *argv[])
1009
- {
1010
- struct io_uring ring;
1011
- int ret;
1012
-
1013
- if (argc > 1)
1014
- return 0;
1015
-
1016
- ret = io_uring_queue_init(8, &ring, 0);
1017
- if (ret) {
1018
- printf("ring setup failed\n");
1019
- return 1;
1020
- }
1021
-
1022
- ret = test_timeout_link_chain1(&ring);
1023
- if (ret) {
1024
- printf("test_single_link_chain1 failed\n");
1025
- return ret;
1026
- }
1027
-
1028
- ret = test_timeout_link_chain2(&ring);
1029
- if (ret) {
1030
- printf("test_single_link_chain2 failed\n");
1031
- return ret;
1032
- }
1033
-
1034
- ret = test_timeout_link_chain3(&ring);
1035
- if (ret) {
1036
- printf("test_single_link_chain3 failed\n");
1037
- return ret;
1038
- }
1039
-
1040
- ret = test_timeout_link_chain4(&ring);
1041
- if (ret) {
1042
- printf("test_single_link_chain4 failed\n");
1043
- return ret;
1044
- }
1045
-
1046
- ret = test_timeout_link_chain5(&ring);
1047
- if (ret) {
1048
- printf("test_single_link_chain5 failed\n");
1049
- return ret;
1050
- }
1051
-
1052
- ret = test_single_link_timeout(&ring, 10);
1053
- if (ret) {
1054
- printf("test_single_link_timeout 10 failed\n");
1055
- return ret;
1056
- }
1057
-
1058
- ret = test_single_link_timeout(&ring, 100000ULL);
1059
- if (ret) {
1060
- printf("test_single_link_timeout 100000 failed\n");
1061
- return ret;
1062
- }
1063
-
1064
- ret = test_single_link_timeout(&ring, 500000000ULL);
1065
- if (ret) {
1066
- printf("test_single_link_timeout 500000000 failed\n");
1067
- return ret;
1068
- }
1069
-
1070
- ret = test_single_link_no_timeout(&ring);
1071
- if (ret) {
1072
- printf("test_single_link_no_timeout failed\n");
1073
- return ret;
1074
- }
1075
-
1076
- ret = test_single_link_timeout_error(&ring);
1077
- if (ret) {
1078
- printf("test_single_link_timeout_error failed\n");
1079
- return ret;
1080
- }
1081
-
1082
- ret = test_single_link_timeout_nop(&ring);
1083
- if (ret) {
1084
- printf("test_single_link_timeout_nop failed\n");
1085
- return ret;
1086
- }
1087
-
1088
- ret = test_single_link_timeout_ception(&ring);
1089
- if (ret) {
1090
- printf("test_single_link_timeout_ception failed\n");
1091
- return ret;
1092
- }
1093
-
1094
- ret = test_fail_lone_link_timeouts(&ring);
1095
- if (ret) {
1096
- printf("test_fail_lone_link_timeouts failed\n");
1097
- return ret;
1098
- }
1099
-
1100
- ret = test_fail_two_link_timeouts(&ring);
1101
- if (ret) {
1102
- printf("test_fail_two_link_timeouts failed\n");
1103
- return ret;
1104
- }
1105
-
1106
- return 0;
1107
- }