@nxtedition/rocksdb 7.0.5 → 7.0.6

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 (261) hide show
  1. package/binding.cc +320 -324
  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/linux-x64/node.napi.node +0 -0
  136. package/deps/liburing/liburing/README +0 -46
  137. package/deps/liburing/liburing/test/232c93d07b74-test.c +0 -305
  138. package/deps/liburing/liburing/test/35fa71a030ca-test.c +0 -329
  139. package/deps/liburing/liburing/test/500f9fbadef8-test.c +0 -89
  140. package/deps/liburing/liburing/test/7ad0e4b2f83c-test.c +0 -93
  141. package/deps/liburing/liburing/test/8a9973408177-test.c +0 -106
  142. package/deps/liburing/liburing/test/917257daa0fe-test.c +0 -53
  143. package/deps/liburing/liburing/test/Makefile +0 -312
  144. package/deps/liburing/liburing/test/a0908ae19763-test.c +0 -58
  145. package/deps/liburing/liburing/test/a4c0b3decb33-test.c +0 -180
  146. package/deps/liburing/liburing/test/accept-link.c +0 -251
  147. package/deps/liburing/liburing/test/accept-reuse.c +0 -164
  148. package/deps/liburing/liburing/test/accept-test.c +0 -79
  149. package/deps/liburing/liburing/test/accept.c +0 -476
  150. package/deps/liburing/liburing/test/across-fork.c +0 -283
  151. package/deps/liburing/liburing/test/b19062a56726-test.c +0 -53
  152. package/deps/liburing/liburing/test/b5837bd5311d-test.c +0 -77
  153. package/deps/liburing/liburing/test/ce593a6c480a-test.c +0 -135
  154. package/deps/liburing/liburing/test/close-opath.c +0 -122
  155. package/deps/liburing/liburing/test/config +0 -10
  156. package/deps/liburing/liburing/test/connect.c +0 -398
  157. package/deps/liburing/liburing/test/cq-full.c +0 -96
  158. package/deps/liburing/liburing/test/cq-overflow.c +0 -294
  159. package/deps/liburing/liburing/test/cq-peek-batch.c +0 -102
  160. package/deps/liburing/liburing/test/cq-ready.c +0 -94
  161. package/deps/liburing/liburing/test/cq-size.c +0 -58
  162. package/deps/liburing/liburing/test/d4ae271dfaae-test.c +0 -96
  163. package/deps/liburing/liburing/test/d77a67ed5f27-test.c +0 -65
  164. package/deps/liburing/liburing/test/defer.c +0 -307
  165. package/deps/liburing/liburing/test/double-poll-crash.c +0 -186
  166. package/deps/liburing/liburing/test/eeed8b54e0df-test.c +0 -114
  167. package/deps/liburing/liburing/test/empty-eownerdead.c +0 -42
  168. package/deps/liburing/liburing/test/eventfd-disable.c +0 -151
  169. package/deps/liburing/liburing/test/eventfd-ring.c +0 -97
  170. package/deps/liburing/liburing/test/eventfd.c +0 -112
  171. package/deps/liburing/liburing/test/fadvise.c +0 -202
  172. package/deps/liburing/liburing/test/fallocate.c +0 -249
  173. package/deps/liburing/liburing/test/fc2a85cb02ef-test.c +0 -138
  174. package/deps/liburing/liburing/test/file-register.c +0 -843
  175. package/deps/liburing/liburing/test/file-update.c +0 -173
  176. package/deps/liburing/liburing/test/files-exit-hang-poll.c +0 -128
  177. package/deps/liburing/liburing/test/files-exit-hang-timeout.c +0 -134
  178. package/deps/liburing/liburing/test/fixed-link.c +0 -90
  179. package/deps/liburing/liburing/test/fsync.c +0 -224
  180. package/deps/liburing/liburing/test/hardlink.c +0 -136
  181. package/deps/liburing/liburing/test/helpers.c +0 -135
  182. package/deps/liburing/liburing/test/helpers.h +0 -67
  183. package/deps/liburing/liburing/test/io-cancel.c +0 -537
  184. package/deps/liburing/liburing/test/io_uring_enter.c +0 -296
  185. package/deps/liburing/liburing/test/io_uring_register.c +0 -664
  186. package/deps/liburing/liburing/test/io_uring_setup.c +0 -192
  187. package/deps/liburing/liburing/test/iopoll.c +0 -366
  188. package/deps/liburing/liburing/test/lfs-openat-write.c +0 -117
  189. package/deps/liburing/liburing/test/lfs-openat.c +0 -273
  190. package/deps/liburing/liburing/test/link-timeout.c +0 -1107
  191. package/deps/liburing/liburing/test/link.c +0 -496
  192. package/deps/liburing/liburing/test/link_drain.c +0 -229
  193. package/deps/liburing/liburing/test/madvise.c +0 -195
  194. package/deps/liburing/liburing/test/mkdir.c +0 -108
  195. package/deps/liburing/liburing/test/multicqes_drain.c +0 -383
  196. package/deps/liburing/liburing/test/nop-all-sizes.c +0 -107
  197. package/deps/liburing/liburing/test/nop.c +0 -115
  198. package/deps/liburing/liburing/test/open-close.c +0 -146
  199. package/deps/liburing/liburing/test/openat2.c +0 -240
  200. package/deps/liburing/liburing/test/personality.c +0 -204
  201. package/deps/liburing/liburing/test/pipe-eof.c +0 -81
  202. package/deps/liburing/liburing/test/pipe-reuse.c +0 -105
  203. package/deps/liburing/liburing/test/poll-cancel-ton.c +0 -139
  204. package/deps/liburing/liburing/test/poll-cancel.c +0 -135
  205. package/deps/liburing/liburing/test/poll-link.c +0 -227
  206. package/deps/liburing/liburing/test/poll-many.c +0 -208
  207. package/deps/liburing/liburing/test/poll-mshot-update.c +0 -273
  208. package/deps/liburing/liburing/test/poll-ring.c +0 -48
  209. package/deps/liburing/liburing/test/poll-v-poll.c +0 -353
  210. package/deps/liburing/liburing/test/poll.c +0 -109
  211. package/deps/liburing/liburing/test/probe.c +0 -137
  212. package/deps/liburing/liburing/test/read-write.c +0 -876
  213. package/deps/liburing/liburing/test/register-restrictions.c +0 -633
  214. package/deps/liburing/liburing/test/rename.c +0 -134
  215. package/deps/liburing/liburing/test/ring-leak.c +0 -173
  216. package/deps/liburing/liburing/test/ring-leak2.c +0 -249
  217. package/deps/liburing/liburing/test/rsrc_tags.c +0 -449
  218. package/deps/liburing/liburing/test/runtests-loop.sh +0 -16
  219. package/deps/liburing/liburing/test/runtests.sh +0 -170
  220. package/deps/liburing/liburing/test/rw_merge_test.c +0 -97
  221. package/deps/liburing/liburing/test/self.c +0 -91
  222. package/deps/liburing/liburing/test/send_recv.c +0 -291
  223. package/deps/liburing/liburing/test/send_recvmsg.c +0 -345
  224. package/deps/liburing/liburing/test/sendmsg_fs_cve.c +0 -198
  225. package/deps/liburing/liburing/test/shared-wq.c +0 -84
  226. package/deps/liburing/liburing/test/short-read.c +0 -75
  227. package/deps/liburing/liburing/test/shutdown.c +0 -163
  228. package/deps/liburing/liburing/test/sigfd-deadlock.c +0 -74
  229. package/deps/liburing/liburing/test/socket-rw-eagain.c +0 -156
  230. package/deps/liburing/liburing/test/socket-rw.c +0 -147
  231. package/deps/liburing/liburing/test/splice.c +0 -511
  232. package/deps/liburing/liburing/test/sq-full-cpp.cc +0 -45
  233. package/deps/liburing/liburing/test/sq-full.c +0 -45
  234. package/deps/liburing/liburing/test/sq-poll-dup.c +0 -200
  235. package/deps/liburing/liburing/test/sq-poll-kthread.c +0 -168
  236. package/deps/liburing/liburing/test/sq-poll-share.c +0 -137
  237. package/deps/liburing/liburing/test/sq-space_left.c +0 -159
  238. package/deps/liburing/liburing/test/sqpoll-cancel-hang.c +0 -159
  239. package/deps/liburing/liburing/test/sqpoll-disable-exit.c +0 -195
  240. package/deps/liburing/liburing/test/sqpoll-exit-hang.c +0 -77
  241. package/deps/liburing/liburing/test/sqpoll-sleep.c +0 -68
  242. package/deps/liburing/liburing/test/statx.c +0 -172
  243. package/deps/liburing/liburing/test/stdout.c +0 -232
  244. package/deps/liburing/liburing/test/submit-link-fail.c +0 -154
  245. package/deps/liburing/liburing/test/submit-reuse.c +0 -239
  246. package/deps/liburing/liburing/test/symlink.c +0 -116
  247. package/deps/liburing/liburing/test/teardowns.c +0 -58
  248. package/deps/liburing/liburing/test/thread-exit.c +0 -131
  249. package/deps/liburing/liburing/test/timeout-new.c +0 -246
  250. package/deps/liburing/liburing/test/timeout-overflow.c +0 -204
  251. package/deps/liburing/liburing/test/timeout.c +0 -1354
  252. package/deps/liburing/liburing/test/unlink.c +0 -111
  253. package/deps/liburing/liburing/test/wakeup-hang.c +0 -162
  254. package/deps/rocksdb/rocksdb/README.md +0 -32
  255. package/deps/rocksdb/rocksdb/microbench/README.md +0 -60
  256. package/deps/rocksdb/rocksdb/plugin/README.md +0 -43
  257. package/deps/rocksdb/rocksdb/port/README +0 -10
  258. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.cc +0 -358
  259. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.h +0 -127
  260. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block_test.cc +0 -219
  261. 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
- }