@nxtedition/rocksdb 6.0.1 → 7.0.0-alpha.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 (490) hide show
  1. package/BUILDING.md +12 -4
  2. package/binding.cc +421 -40
  3. package/deps/rocksdb/build_version.cc +4 -10
  4. package/deps/rocksdb/rocksdb/CMakeLists.txt +26 -3
  5. package/deps/rocksdb/rocksdb/Makefile +73 -91
  6. package/deps/rocksdb/rocksdb/TARGETS +27 -2
  7. package/deps/rocksdb/rocksdb/cache/cache_test.cc +29 -17
  8. package/deps/rocksdb/rocksdb/cache/fast_lru_cache.cc +511 -0
  9. package/deps/rocksdb/rocksdb/cache/fast_lru_cache.h +299 -0
  10. package/deps/rocksdb/rocksdb/cache/lru_cache.cc +3 -0
  11. package/deps/rocksdb/rocksdb/cache/lru_cache.h +7 -0
  12. package/deps/rocksdb/rocksdb/cmake/modules/CxxFlags.cmake +7 -0
  13. package/deps/rocksdb/rocksdb/cmake/modules/FindJeMalloc.cmake +29 -0
  14. package/deps/rocksdb/rocksdb/cmake/modules/FindNUMA.cmake +29 -0
  15. package/deps/rocksdb/rocksdb/cmake/modules/FindSnappy.cmake +29 -0
  16. package/deps/rocksdb/rocksdb/cmake/modules/FindTBB.cmake +33 -0
  17. package/deps/rocksdb/rocksdb/cmake/modules/Findgflags.cmake +29 -0
  18. package/deps/rocksdb/rocksdb/cmake/modules/Findlz4.cmake +29 -0
  19. package/deps/rocksdb/rocksdb/cmake/modules/Finduring.cmake +26 -0
  20. package/deps/rocksdb/rocksdb/cmake/modules/Findzstd.cmake +29 -0
  21. package/deps/rocksdb/rocksdb/cmake/modules/ReadVersion.cmake +10 -0
  22. package/deps/rocksdb/rocksdb/common.mk +30 -0
  23. package/deps/rocksdb/rocksdb/crash_test.mk +3 -3
  24. package/deps/rocksdb/rocksdb/db/arena_wrapped_db_iter.cc +1 -1
  25. package/deps/rocksdb/rocksdb/db/blob/blob_index.h +3 -3
  26. package/deps/rocksdb/rocksdb/db/blob/db_blob_index_test.cc +7 -7
  27. package/deps/rocksdb/rocksdb/db/builder.cc +22 -7
  28. package/deps/rocksdb/rocksdb/db/c.cc +71 -0
  29. package/deps/rocksdb/rocksdb/db/c_test.c +28 -2
  30. package/deps/rocksdb/rocksdb/db/column_family.cc +12 -5
  31. package/deps/rocksdb/rocksdb/db/column_family_test.cc +23 -22
  32. package/deps/rocksdb/rocksdb/db/compact_files_test.cc +11 -11
  33. package/deps/rocksdb/rocksdb/db/compaction/compaction.cc +2 -2
  34. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.cc +36 -10
  35. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.h +4 -1
  36. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator_test.cc +3 -2
  37. package/deps/rocksdb/rocksdb/db/compaction/compaction_job.cc +54 -16
  38. package/deps/rocksdb/rocksdb/db/compaction/compaction_job.h +14 -2
  39. package/deps/rocksdb/rocksdb/db/compaction/compaction_job_stats_test.cc +3 -3
  40. package/deps/rocksdb/rocksdb/db/compaction/compaction_job_test.cc +85 -18
  41. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker.cc +7 -7
  42. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.cc +1 -1
  43. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_test.cc +23 -22
  44. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_universal.cc +1 -1
  45. package/deps/rocksdb/rocksdb/db/compaction/compaction_service_test.cc +151 -32
  46. package/deps/rocksdb/rocksdb/db/comparator_db_test.cc +1 -1
  47. package/deps/rocksdb/rocksdb/db/convenience.cc +8 -6
  48. package/deps/rocksdb/rocksdb/db/corruption_test.cc +209 -38
  49. package/deps/rocksdb/rocksdb/db/cuckoo_table_db_test.cc +2 -2
  50. package/deps/rocksdb/rocksdb/db/db_basic_test.cc +404 -32
  51. package/deps/rocksdb/rocksdb/db/db_block_cache_test.cc +28 -25
  52. package/deps/rocksdb/rocksdb/db/db_bloom_filter_test.cc +85 -138
  53. package/deps/rocksdb/rocksdb/db/db_compaction_filter_test.cc +68 -3
  54. package/deps/rocksdb/rocksdb/db/db_compaction_test.cc +38 -13
  55. package/deps/rocksdb/rocksdb/db/db_filesnapshot.cc +1 -1
  56. package/deps/rocksdb/rocksdb/db/db_flush_test.cc +1 -1
  57. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.cc +11 -20
  58. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.h +15 -1
  59. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_compaction_flush.cc +12 -9
  60. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_debug.cc +5 -4
  61. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_experimental.cc +1 -1
  62. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_files.cc +2 -2
  63. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_open.cc +42 -10
  64. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.cc +54 -23
  65. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.h +3 -0
  66. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.cc +14 -4
  67. package/deps/rocksdb/rocksdb/db/db_info_dumper.cc +26 -18
  68. package/deps/rocksdb/rocksdb/db/db_iter_stress_test.cc +8 -7
  69. package/deps/rocksdb/rocksdb/db/db_iter_test.cc +8 -8
  70. package/deps/rocksdb/rocksdb/db/db_iterator_test.cc +6 -3
  71. package/deps/rocksdb/rocksdb/db/db_kv_checksum_test.cc +2 -2
  72. package/deps/rocksdb/rocksdb/db/db_log_iter_test.cc +6 -6
  73. package/deps/rocksdb/rocksdb/db/db_memtable_test.cc +2 -2
  74. package/deps/rocksdb/rocksdb/db/db_options_test.cc +28 -12
  75. package/deps/rocksdb/rocksdb/db/db_properties_test.cc +16 -15
  76. package/deps/rocksdb/rocksdb/db/db_range_del_test.cc +6 -4
  77. package/deps/rocksdb/rocksdb/db/db_readonly_with_timestamp_test.cc +331 -0
  78. package/deps/rocksdb/rocksdb/db/db_secondary_test.cc +11 -6
  79. package/deps/rocksdb/rocksdb/db/db_sst_test.cc +68 -7
  80. package/deps/rocksdb/rocksdb/db/db_table_properties_test.cc +6 -5
  81. package/deps/rocksdb/rocksdb/db/db_test.cc +60 -42
  82. package/deps/rocksdb/rocksdb/db/db_test2.cc +244 -111
  83. package/deps/rocksdb/rocksdb/db/db_test_util.cc +101 -19
  84. package/deps/rocksdb/rocksdb/db/db_test_util.h +52 -2
  85. package/deps/rocksdb/rocksdb/db/db_universal_compaction_test.cc +1 -1
  86. package/deps/rocksdb/rocksdb/db/db_wal_test.cc +7 -7
  87. package/deps/rocksdb/rocksdb/db/db_with_timestamp_basic_test.cc +5 -175
  88. package/deps/rocksdb/rocksdb/db/db_with_timestamp_test_util.cc +96 -0
  89. package/deps/rocksdb/rocksdb/db/db_with_timestamp_test_util.h +126 -0
  90. package/deps/rocksdb/rocksdb/db/db_write_test.cc +6 -6
  91. package/deps/rocksdb/rocksdb/db/dbformat.h +2 -1
  92. package/deps/rocksdb/rocksdb/db/deletefile_test.cc +1 -1
  93. package/deps/rocksdb/rocksdb/db/error_handler_fs_test.cc +8 -8
  94. package/deps/rocksdb/rocksdb/db/experimental.cc +1 -1
  95. package/deps/rocksdb/rocksdb/db/external_sst_file_basic_test.cc +91 -12
  96. package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.cc +16 -2
  97. package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.h +2 -0
  98. package/deps/rocksdb/rocksdb/db/external_sst_file_test.cc +7 -7
  99. package/deps/rocksdb/rocksdb/db/file_indexer.h +1 -4
  100. package/deps/rocksdb/rocksdb/db/flush_job.cc +28 -15
  101. package/deps/rocksdb/rocksdb/db/flush_job.h +4 -0
  102. package/deps/rocksdb/rocksdb/db/flush_job_test.cc +98 -30
  103. package/deps/rocksdb/rocksdb/db/forward_iterator.cc +1 -1
  104. package/deps/rocksdb/rocksdb/db/import_column_family_job.cc +14 -1
  105. package/deps/rocksdb/rocksdb/db/import_column_family_test.cc +6 -0
  106. package/deps/rocksdb/rocksdb/db/internal_stats.cc +12 -12
  107. package/deps/rocksdb/rocksdb/db/listener_test.cc +4 -3
  108. package/deps/rocksdb/rocksdb/db/memtable.cc +2 -2
  109. package/deps/rocksdb/rocksdb/db/memtable_list.h +1 -1
  110. package/deps/rocksdb/rocksdb/db/memtable_list_test.cc +37 -25
  111. package/deps/rocksdb/rocksdb/db/obsolete_files_test.cc +1 -1
  112. package/deps/rocksdb/rocksdb/db/perf_context_test.cc +18 -18
  113. package/deps/rocksdb/rocksdb/db/plain_table_db_test.cc +6 -6
  114. package/deps/rocksdb/rocksdb/db/prefix_test.cc +1 -1
  115. package/deps/rocksdb/rocksdb/db/repair.cc +13 -2
  116. package/deps/rocksdb/rocksdb/db/repair_test.cc +37 -15
  117. package/deps/rocksdb/rocksdb/db/snapshot_checker.h +1 -2
  118. package/deps/rocksdb/rocksdb/db/snapshot_impl.h +3 -1
  119. package/deps/rocksdb/rocksdb/db/table_cache.cc +20 -130
  120. package/deps/rocksdb/rocksdb/db/table_cache.h +3 -2
  121. package/deps/rocksdb/rocksdb/db/table_cache_sync_and_async.h +140 -0
  122. package/deps/rocksdb/rocksdb/db/version_builder.cc +1 -1
  123. package/deps/rocksdb/rocksdb/db/version_builder_test.cc +133 -133
  124. package/deps/rocksdb/rocksdb/db/version_edit.cc +22 -2
  125. package/deps/rocksdb/rocksdb/db/version_edit.h +13 -4
  126. package/deps/rocksdb/rocksdb/db/version_edit_test.cc +14 -14
  127. package/deps/rocksdb/rocksdb/db/version_set.cc +207 -214
  128. package/deps/rocksdb/rocksdb/db/version_set.h +14 -3
  129. package/deps/rocksdb/rocksdb/db/version_set_sync_and_async.h +154 -0
  130. package/deps/rocksdb/rocksdb/db/version_set_test.cc +10 -9
  131. package/deps/rocksdb/rocksdb/db/wal_edit.h +2 -1
  132. package/deps/rocksdb/rocksdb/db/wal_manager.cc +2 -3
  133. package/deps/rocksdb/rocksdb/db/wal_manager_test.cc +1 -1
  134. package/deps/rocksdb/rocksdb/db/write_batch.cc +178 -30
  135. package/deps/rocksdb/rocksdb/db/write_batch_test.cc +6 -6
  136. package/deps/rocksdb/rocksdb/db/write_controller.h +1 -1
  137. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.cc +0 -2
  138. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.h +9 -6
  139. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_compaction_filter.h +2 -1
  140. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_driver.cc +4 -3
  141. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_gflags.cc +44 -6
  142. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_listener.cc +4 -1
  143. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_shared_state.cc +0 -10
  144. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_shared_state.h +45 -42
  145. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.cc +374 -275
  146. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.h +53 -3
  147. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_tool.cc +0 -12
  148. package/deps/rocksdb/rocksdb/db_stress_tool/expected_state.cc +13 -11
  149. package/deps/rocksdb/rocksdb/db_stress_tool/multi_ops_txns_stress.cc +276 -109
  150. package/deps/rocksdb/rocksdb/db_stress_tool/multi_ops_txns_stress.h +63 -0
  151. package/deps/rocksdb/rocksdb/db_stress_tool/no_batched_ops_stress.cc +45 -54
  152. package/deps/rocksdb/rocksdb/env/composite_env.cc +87 -14
  153. package/deps/rocksdb/rocksdb/env/env.cc +0 -60
  154. package/deps/rocksdb/rocksdb/env/env_encryption.cc +9 -0
  155. package/deps/rocksdb/rocksdb/env/env_encryption_ctr.h +1 -1
  156. package/deps/rocksdb/rocksdb/env/env_posix.cc +6 -5
  157. package/deps/rocksdb/rocksdb/env/env_test.cc +18 -5
  158. package/deps/rocksdb/rocksdb/env/fs_posix.cc +17 -12
  159. package/deps/rocksdb/rocksdb/env/io_posix.cc +39 -37
  160. package/deps/rocksdb/rocksdb/file/delete_scheduler_test.cc +9 -9
  161. package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.cc +159 -65
  162. package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.h +44 -22
  163. package/deps/rocksdb/rocksdb/file/file_util.h +2 -0
  164. package/deps/rocksdb/rocksdb/file/prefetch_test.cc +142 -17
  165. package/deps/rocksdb/rocksdb/file/random_access_file_reader.h +5 -2
  166. package/deps/rocksdb/rocksdb/file/sequence_file_reader.cc +7 -0
  167. package/deps/rocksdb/rocksdb/file/writable_file_writer.cc +60 -40
  168. package/deps/rocksdb/rocksdb/file/writable_file_writer.h +1 -0
  169. package/deps/rocksdb/rocksdb/include/rocksdb/advanced_options.h +23 -5
  170. package/deps/rocksdb/rocksdb/include/rocksdb/c.h +49 -1
  171. package/deps/rocksdb/rocksdb/include/rocksdb/cache.h +5 -5
  172. package/deps/rocksdb/rocksdb/include/rocksdb/cleanable.h +59 -2
  173. package/deps/rocksdb/rocksdb/include/rocksdb/compaction_filter.h +1 -0
  174. package/deps/rocksdb/rocksdb/include/rocksdb/convenience.h +2 -1
  175. package/deps/rocksdb/rocksdb/include/rocksdb/db.h +46 -44
  176. package/deps/rocksdb/rocksdb/include/rocksdb/env.h +1 -1
  177. package/deps/rocksdb/rocksdb/include/rocksdb/file_system.h +2 -0
  178. package/deps/rocksdb/rocksdb/include/rocksdb/iostats_context.h +2 -4
  179. package/deps/rocksdb/rocksdb/include/rocksdb/memtablerep.h +3 -0
  180. package/deps/rocksdb/rocksdb/include/rocksdb/options.h +45 -3
  181. package/deps/rocksdb/rocksdb/include/rocksdb/perf_context.h +2 -0
  182. package/deps/rocksdb/rocksdb/include/rocksdb/snapshot.h +4 -1
  183. package/deps/rocksdb/rocksdb/include/rocksdb/statistics.h +3 -0
  184. package/deps/rocksdb/rocksdb/include/rocksdb/table.h +91 -40
  185. package/deps/rocksdb/rocksdb/include/rocksdb/thread_status.h +1 -2
  186. package/deps/rocksdb/rocksdb/include/rocksdb/unique_id.h +22 -13
  187. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/customizable_util.h +9 -0
  188. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/ldb_cmd.h +4 -0
  189. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/object_registry.h +25 -0
  190. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_type.h +378 -103
  191. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction_db.h +14 -0
  192. package/deps/rocksdb/rocksdb/include/rocksdb/version.h +2 -2
  193. package/deps/rocksdb/rocksdb/include/rocksdb/write_batch.h +18 -4
  194. package/deps/rocksdb/rocksdb/memory/arena.h +1 -1
  195. package/deps/rocksdb/rocksdb/memory/concurrent_arena.cc +1 -5
  196. package/deps/rocksdb/rocksdb/memory/concurrent_arena.h +1 -5
  197. package/deps/rocksdb/rocksdb/memory/jemalloc_nodump_allocator.cc +6 -8
  198. package/deps/rocksdb/rocksdb/memtable/skiplistrep.cc +1 -1
  199. package/deps/rocksdb/rocksdb/memtable/write_buffer_manager.cc +1 -1
  200. package/deps/rocksdb/rocksdb/memtable/write_buffer_manager_test.cc +5 -3
  201. package/deps/rocksdb/rocksdb/microbench/db_basic_bench.cc +266 -45
  202. package/deps/rocksdb/rocksdb/monitoring/histogram.cc +2 -1
  203. package/deps/rocksdb/rocksdb/monitoring/iostats_context.cc +1 -4
  204. package/deps/rocksdb/rocksdb/monitoring/iostats_context_imp.h +4 -4
  205. package/deps/rocksdb/rocksdb/monitoring/perf_context.cc +7 -8
  206. package/deps/rocksdb/rocksdb/monitoring/perf_context_imp.h +2 -2
  207. package/deps/rocksdb/rocksdb/monitoring/perf_level.cc +1 -5
  208. package/deps/rocksdb/rocksdb/monitoring/perf_level_imp.h +1 -5
  209. package/deps/rocksdb/rocksdb/monitoring/persistent_stats_history.cc +2 -2
  210. package/deps/rocksdb/rocksdb/monitoring/statistics.cc +1 -1
  211. package/deps/rocksdb/rocksdb/monitoring/thread_status_updater.cc +2 -1
  212. package/deps/rocksdb/rocksdb/monitoring/thread_status_updater.h +1 -1
  213. package/deps/rocksdb/rocksdb/monitoring/thread_status_util.cc +3 -3
  214. package/deps/rocksdb/rocksdb/monitoring/thread_status_util.h +2 -2
  215. package/deps/rocksdb/rocksdb/options/cf_options.cc +47 -38
  216. package/deps/rocksdb/rocksdb/options/configurable.cc +9 -27
  217. package/deps/rocksdb/rocksdb/options/configurable_test.cc +1 -1
  218. package/deps/rocksdb/rocksdb/options/customizable.cc +3 -1
  219. package/deps/rocksdb/rocksdb/options/customizable_test.cc +379 -318
  220. package/deps/rocksdb/rocksdb/options/db_options.cc +46 -17
  221. package/deps/rocksdb/rocksdb/options/db_options.h +2 -0
  222. package/deps/rocksdb/rocksdb/options/options.cc +7 -0
  223. package/deps/rocksdb/rocksdb/options/options_helper.cc +86 -39
  224. package/deps/rocksdb/rocksdb/options/options_parser.cc +10 -10
  225. package/deps/rocksdb/rocksdb/options/options_settable_test.cc +12 -7
  226. package/deps/rocksdb/rocksdb/options/options_test.cc +222 -68
  227. package/deps/rocksdb/rocksdb/port/port_posix.h +0 -15
  228. package/deps/rocksdb/rocksdb/port/win/env_win.cc +5 -4
  229. package/deps/rocksdb/rocksdb/port/win/env_win.h +2 -2
  230. package/deps/rocksdb/rocksdb/port/win/port_win.h +0 -31
  231. package/deps/rocksdb/rocksdb/rocksdb.pc.in +11 -0
  232. package/deps/rocksdb/rocksdb/src.mk +6 -1
  233. package/deps/rocksdb/rocksdb/table/block_based/binary_search_index_reader.cc +2 -1
  234. package/deps/rocksdb/rocksdb/table/block_based/block.cc +4 -2
  235. package/deps/rocksdb/rocksdb/table/block_based/block.h +21 -25
  236. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.cc +3 -4
  237. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.cc +23 -8
  238. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_factory.cc +52 -15
  239. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.cc +81 -7
  240. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.h +8 -2
  241. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.cc +94 -726
  242. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.h +21 -15
  243. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_impl.h +9 -3
  244. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_sync_and_async.h +754 -0
  245. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_test.cc +44 -73
  246. package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.cc +15 -5
  247. package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.h +2 -1
  248. package/deps/rocksdb/rocksdb/table/block_based/filter_block.h +2 -11
  249. package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.cc +59 -1
  250. package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.h +18 -0
  251. package/deps/rocksdb/rocksdb/table/block_based/filter_policy.cc +33 -17
  252. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.cc +0 -61
  253. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.h +0 -13
  254. package/deps/rocksdb/rocksdb/table/block_based/hash_index_reader.cc +2 -1
  255. package/deps/rocksdb/rocksdb/table/block_based/index_builder.h +2 -2
  256. package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.cc +3 -2
  257. package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.h +2 -1
  258. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.cc +3 -2
  259. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.cc +4 -3
  260. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.cc +8 -4
  261. package/deps/rocksdb/rocksdb/table/block_based/reader_common.cc +4 -4
  262. package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.cc +2 -1
  263. package/deps/rocksdb/rocksdb/table/block_fetcher.cc +65 -7
  264. package/deps/rocksdb/rocksdb/table/block_fetcher.h +2 -0
  265. package/deps/rocksdb/rocksdb/table/cleanable_test.cc +113 -0
  266. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.cc +1 -1
  267. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.h +1 -1
  268. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader_test.cc +1 -1
  269. package/deps/rocksdb/rocksdb/table/format.cc +22 -20
  270. package/deps/rocksdb/rocksdb/table/iterator.cc +1 -81
  271. package/deps/rocksdb/rocksdb/table/merging_iterator.cc +39 -0
  272. package/deps/rocksdb/rocksdb/table/meta_blocks.cc +2 -2
  273. package/deps/rocksdb/rocksdb/table/multiget_context.h +60 -13
  274. package/deps/rocksdb/rocksdb/table/persistent_cache_options.h +0 -3
  275. package/deps/rocksdb/rocksdb/table/plain/plain_table_factory.cc +12 -1
  276. package/deps/rocksdb/rocksdb/table/plain/plain_table_reader.cc +4 -4
  277. package/deps/rocksdb/rocksdb/table/sst_file_dumper.cc +2 -1
  278. package/deps/rocksdb/rocksdb/table/sst_file_dumper.h +1 -1
  279. package/deps/rocksdb/rocksdb/table/sst_file_writer_collectors.h +1 -1
  280. package/deps/rocksdb/rocksdb/table/table_properties.cc +3 -5
  281. package/deps/rocksdb/rocksdb/table/table_reader.h +13 -0
  282. package/deps/rocksdb/rocksdb/table/table_test.cc +202 -78
  283. package/deps/rocksdb/rocksdb/table/unique_id.cc +84 -25
  284. package/deps/rocksdb/rocksdb/table/unique_id_impl.h +37 -4
  285. package/deps/rocksdb/rocksdb/test_util/testutil.cc +3 -1
  286. package/deps/rocksdb/rocksdb/test_util/testutil.h +11 -8
  287. package/deps/rocksdb/rocksdb/test_util/transaction_test_util.cc +8 -4
  288. package/deps/rocksdb/rocksdb/test_util/transaction_test_util.h +17 -0
  289. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.cc +11 -9
  290. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_test.cc +3 -3
  291. package/deps/rocksdb/rocksdb/tools/db_bench_tool.cc +277 -105
  292. package/deps/rocksdb/rocksdb/tools/db_sanity_test.cc +4 -4
  293. package/deps/rocksdb/rocksdb/tools/ldb_cmd.cc +186 -42
  294. package/deps/rocksdb/rocksdb/tools/ldb_cmd_impl.h +75 -49
  295. package/deps/rocksdb/rocksdb/tools/ldb_cmd_test.cc +9 -8
  296. package/deps/rocksdb/rocksdb/tools/ldb_tool.cc +4 -1
  297. package/deps/rocksdb/rocksdb/tools/reduce_levels_test.cc +2 -2
  298. package/deps/rocksdb/rocksdb/tools/sst_dump_tool.cc +26 -4
  299. package/deps/rocksdb/rocksdb/tools/trace_analyzer_tool.cc +1 -1
  300. package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer.h +1 -1
  301. package/deps/rocksdb/rocksdb/util/async_file_reader.cc +72 -0
  302. package/deps/rocksdb/rocksdb/util/async_file_reader.h +144 -0
  303. package/deps/rocksdb/rocksdb/util/autovector_test.cc +4 -4
  304. package/deps/rocksdb/rocksdb/util/bloom_test.cc +14 -8
  305. package/deps/rocksdb/rocksdb/util/build_version.cc.in +5 -6
  306. package/deps/rocksdb/rocksdb/util/cleanable.cc +180 -0
  307. package/deps/rocksdb/rocksdb/util/comparator.cc +5 -3
  308. package/deps/rocksdb/rocksdb/util/compression.h +56 -7
  309. package/deps/rocksdb/rocksdb/util/coro_utils.h +111 -0
  310. package/deps/rocksdb/rocksdb/util/file_reader_writer_test.cc +148 -0
  311. package/deps/rocksdb/rocksdb/util/filelock_test.cc +2 -2
  312. package/deps/rocksdb/rocksdb/util/filter_bench.cc +12 -4
  313. package/deps/rocksdb/rocksdb/util/heap.h +5 -3
  314. package/deps/rocksdb/rocksdb/util/random.cc +1 -5
  315. package/deps/rocksdb/rocksdb/util/rate_limiter.cc +12 -9
  316. package/deps/rocksdb/rocksdb/util/rate_limiter_test.cc +1 -1
  317. package/deps/rocksdb/rocksdb/util/ribbon_alg.h +1 -1
  318. package/deps/rocksdb/rocksdb/util/ribbon_test.cc +2 -4
  319. package/deps/rocksdb/rocksdb/util/single_thread_executor.h +55 -0
  320. package/deps/rocksdb/rocksdb/util/slice.cc +8 -9
  321. package/deps/rocksdb/rocksdb/util/string_util.cc +3 -2
  322. package/deps/rocksdb/rocksdb/util/string_util.h +0 -13
  323. package/deps/rocksdb/rocksdb/util/thread_local.cc +4 -23
  324. package/deps/rocksdb/rocksdb/utilities/backup/backup_engine.cc +99 -22
  325. package/deps/rocksdb/rocksdb/utilities/backup/backup_engine_impl.h +7 -0
  326. package/deps/rocksdb/rocksdb/utilities/backup/backup_engine_test.cc +102 -59
  327. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_test.cc +38 -36
  328. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_dump_tool.cc +2 -2
  329. package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.cc +28 -0
  330. package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.h +3 -0
  331. package/deps/rocksdb/rocksdb/utilities/memory/memory_test.cc +1 -1
  332. package/deps/rocksdb/rocksdb/utilities/object_registry.cc +71 -0
  333. package/deps/rocksdb/rocksdb/utilities/object_registry_test.cc +71 -0
  334. package/deps/rocksdb/rocksdb/utilities/options/options_util_test.cc +1 -1
  335. package/deps/rocksdb/rocksdb/utilities/simulator_cache/sim_cache_test.cc +5 -5
  336. package/deps/rocksdb/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.cc +3 -3
  337. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_tracker.cc +0 -13
  338. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_locking_test.cc +40 -0
  339. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.cc +10 -8
  340. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.h +4 -2
  341. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_time.h +17 -0
  342. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.cc +7 -7
  343. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction.cc +8 -1
  344. package/deps/rocksdb/rocksdb/utilities/transactions/snapshot_checker.cc +5 -1
  345. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_test.cc +21 -15
  346. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_util.cc +2 -2
  347. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_transaction_test.cc +69 -11
  348. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn.cc +22 -9
  349. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.cc +26 -5
  350. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.h +17 -4
  351. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_transaction_test.cc +19 -16
  352. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn.cc +7 -3
  353. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index.cc +3 -2
  354. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.cc +2 -2
  355. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.h +2 -2
  356. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_test.cc +6 -6
  357. package/deps/rocksdb/rocksdb.gyp +20 -13
  358. package/index.js +187 -3
  359. package/iterator.js +1 -0
  360. package/package-lock.json +23687 -0
  361. package/package.json +2 -30
  362. package/prebuilds/darwin-arm64/node.napi.node +0 -0
  363. package/snapshot.js +23 -0
  364. package/deps/liburing/liburing/README +0 -46
  365. package/deps/liburing/liburing/test/232c93d07b74-test.c +0 -305
  366. package/deps/liburing/liburing/test/35fa71a030ca-test.c +0 -329
  367. package/deps/liburing/liburing/test/500f9fbadef8-test.c +0 -89
  368. package/deps/liburing/liburing/test/7ad0e4b2f83c-test.c +0 -93
  369. package/deps/liburing/liburing/test/8a9973408177-test.c +0 -106
  370. package/deps/liburing/liburing/test/917257daa0fe-test.c +0 -53
  371. package/deps/liburing/liburing/test/Makefile +0 -312
  372. package/deps/liburing/liburing/test/a0908ae19763-test.c +0 -58
  373. package/deps/liburing/liburing/test/a4c0b3decb33-test.c +0 -180
  374. package/deps/liburing/liburing/test/accept-link.c +0 -251
  375. package/deps/liburing/liburing/test/accept-reuse.c +0 -164
  376. package/deps/liburing/liburing/test/accept-test.c +0 -79
  377. package/deps/liburing/liburing/test/accept.c +0 -476
  378. package/deps/liburing/liburing/test/across-fork.c +0 -283
  379. package/deps/liburing/liburing/test/b19062a56726-test.c +0 -53
  380. package/deps/liburing/liburing/test/b5837bd5311d-test.c +0 -77
  381. package/deps/liburing/liburing/test/ce593a6c480a-test.c +0 -135
  382. package/deps/liburing/liburing/test/close-opath.c +0 -122
  383. package/deps/liburing/liburing/test/config +0 -10
  384. package/deps/liburing/liburing/test/connect.c +0 -398
  385. package/deps/liburing/liburing/test/cq-full.c +0 -96
  386. package/deps/liburing/liburing/test/cq-overflow.c +0 -294
  387. package/deps/liburing/liburing/test/cq-peek-batch.c +0 -102
  388. package/deps/liburing/liburing/test/cq-ready.c +0 -94
  389. package/deps/liburing/liburing/test/cq-size.c +0 -58
  390. package/deps/liburing/liburing/test/d4ae271dfaae-test.c +0 -96
  391. package/deps/liburing/liburing/test/d77a67ed5f27-test.c +0 -65
  392. package/deps/liburing/liburing/test/defer.c +0 -307
  393. package/deps/liburing/liburing/test/double-poll-crash.c +0 -186
  394. package/deps/liburing/liburing/test/eeed8b54e0df-test.c +0 -114
  395. package/deps/liburing/liburing/test/empty-eownerdead.c +0 -42
  396. package/deps/liburing/liburing/test/eventfd-disable.c +0 -151
  397. package/deps/liburing/liburing/test/eventfd-ring.c +0 -97
  398. package/deps/liburing/liburing/test/eventfd.c +0 -112
  399. package/deps/liburing/liburing/test/fadvise.c +0 -202
  400. package/deps/liburing/liburing/test/fallocate.c +0 -249
  401. package/deps/liburing/liburing/test/fc2a85cb02ef-test.c +0 -138
  402. package/deps/liburing/liburing/test/file-register.c +0 -843
  403. package/deps/liburing/liburing/test/file-update.c +0 -173
  404. package/deps/liburing/liburing/test/files-exit-hang-poll.c +0 -128
  405. package/deps/liburing/liburing/test/files-exit-hang-timeout.c +0 -134
  406. package/deps/liburing/liburing/test/fixed-link.c +0 -90
  407. package/deps/liburing/liburing/test/fsync.c +0 -224
  408. package/deps/liburing/liburing/test/hardlink.c +0 -136
  409. package/deps/liburing/liburing/test/helpers.c +0 -135
  410. package/deps/liburing/liburing/test/helpers.h +0 -67
  411. package/deps/liburing/liburing/test/io-cancel.c +0 -537
  412. package/deps/liburing/liburing/test/io_uring_enter.c +0 -296
  413. package/deps/liburing/liburing/test/io_uring_register.c +0 -664
  414. package/deps/liburing/liburing/test/io_uring_setup.c +0 -192
  415. package/deps/liburing/liburing/test/iopoll.c +0 -366
  416. package/deps/liburing/liburing/test/lfs-openat-write.c +0 -117
  417. package/deps/liburing/liburing/test/lfs-openat.c +0 -273
  418. package/deps/liburing/liburing/test/link-timeout.c +0 -1107
  419. package/deps/liburing/liburing/test/link.c +0 -496
  420. package/deps/liburing/liburing/test/link_drain.c +0 -229
  421. package/deps/liburing/liburing/test/madvise.c +0 -195
  422. package/deps/liburing/liburing/test/mkdir.c +0 -108
  423. package/deps/liburing/liburing/test/multicqes_drain.c +0 -383
  424. package/deps/liburing/liburing/test/nop-all-sizes.c +0 -107
  425. package/deps/liburing/liburing/test/nop.c +0 -115
  426. package/deps/liburing/liburing/test/open-close.c +0 -146
  427. package/deps/liburing/liburing/test/openat2.c +0 -240
  428. package/deps/liburing/liburing/test/personality.c +0 -204
  429. package/deps/liburing/liburing/test/pipe-eof.c +0 -81
  430. package/deps/liburing/liburing/test/pipe-reuse.c +0 -105
  431. package/deps/liburing/liburing/test/poll-cancel-ton.c +0 -139
  432. package/deps/liburing/liburing/test/poll-cancel.c +0 -135
  433. package/deps/liburing/liburing/test/poll-link.c +0 -227
  434. package/deps/liburing/liburing/test/poll-many.c +0 -208
  435. package/deps/liburing/liburing/test/poll-mshot-update.c +0 -273
  436. package/deps/liburing/liburing/test/poll-ring.c +0 -48
  437. package/deps/liburing/liburing/test/poll-v-poll.c +0 -353
  438. package/deps/liburing/liburing/test/poll.c +0 -109
  439. package/deps/liburing/liburing/test/probe.c +0 -137
  440. package/deps/liburing/liburing/test/read-write.c +0 -876
  441. package/deps/liburing/liburing/test/register-restrictions.c +0 -633
  442. package/deps/liburing/liburing/test/rename.c +0 -134
  443. package/deps/liburing/liburing/test/ring-leak.c +0 -173
  444. package/deps/liburing/liburing/test/ring-leak2.c +0 -249
  445. package/deps/liburing/liburing/test/rsrc_tags.c +0 -449
  446. package/deps/liburing/liburing/test/runtests-loop.sh +0 -16
  447. package/deps/liburing/liburing/test/runtests.sh +0 -170
  448. package/deps/liburing/liburing/test/rw_merge_test.c +0 -97
  449. package/deps/liburing/liburing/test/self.c +0 -91
  450. package/deps/liburing/liburing/test/send_recv.c +0 -291
  451. package/deps/liburing/liburing/test/send_recvmsg.c +0 -345
  452. package/deps/liburing/liburing/test/sendmsg_fs_cve.c +0 -198
  453. package/deps/liburing/liburing/test/shared-wq.c +0 -84
  454. package/deps/liburing/liburing/test/short-read.c +0 -75
  455. package/deps/liburing/liburing/test/shutdown.c +0 -163
  456. package/deps/liburing/liburing/test/sigfd-deadlock.c +0 -74
  457. package/deps/liburing/liburing/test/socket-rw-eagain.c +0 -156
  458. package/deps/liburing/liburing/test/socket-rw.c +0 -147
  459. package/deps/liburing/liburing/test/splice.c +0 -511
  460. package/deps/liburing/liburing/test/sq-full-cpp.cc +0 -45
  461. package/deps/liburing/liburing/test/sq-full.c +0 -45
  462. package/deps/liburing/liburing/test/sq-poll-dup.c +0 -200
  463. package/deps/liburing/liburing/test/sq-poll-kthread.c +0 -168
  464. package/deps/liburing/liburing/test/sq-poll-share.c +0 -137
  465. package/deps/liburing/liburing/test/sq-space_left.c +0 -159
  466. package/deps/liburing/liburing/test/sqpoll-cancel-hang.c +0 -159
  467. package/deps/liburing/liburing/test/sqpoll-disable-exit.c +0 -195
  468. package/deps/liburing/liburing/test/sqpoll-exit-hang.c +0 -77
  469. package/deps/liburing/liburing/test/sqpoll-sleep.c +0 -68
  470. package/deps/liburing/liburing/test/statx.c +0 -172
  471. package/deps/liburing/liburing/test/stdout.c +0 -232
  472. package/deps/liburing/liburing/test/submit-link-fail.c +0 -154
  473. package/deps/liburing/liburing/test/submit-reuse.c +0 -239
  474. package/deps/liburing/liburing/test/symlink.c +0 -116
  475. package/deps/liburing/liburing/test/teardowns.c +0 -58
  476. package/deps/liburing/liburing/test/thread-exit.c +0 -131
  477. package/deps/liburing/liburing/test/timeout-new.c +0 -246
  478. package/deps/liburing/liburing/test/timeout-overflow.c +0 -204
  479. package/deps/liburing/liburing/test/timeout.c +0 -1354
  480. package/deps/liburing/liburing/test/unlink.c +0 -111
  481. package/deps/liburing/liburing/test/wakeup-hang.c +0 -162
  482. package/deps/rocksdb/rocksdb/README.md +0 -32
  483. package/deps/rocksdb/rocksdb/microbench/README.md +0 -60
  484. package/deps/rocksdb/rocksdb/plugin/README.md +0 -43
  485. package/deps/rocksdb/rocksdb/port/README +0 -10
  486. package/deps/rocksdb/rocksdb/python.mk +0 -9
  487. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/README +0 -13
  488. package/prebuilds/darwin-x64/node.napi.node +0 -0
  489. package/prebuilds/linux-arm64/node.napi.node +0 -0
  490. package/prebuilds/linux-x64/node.napi.node +0 -0
@@ -1,496 +0,0 @@
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
-
15
- static int no_hardlink;
16
-
17
- /*
18
- * Timer with single nop
19
- */
20
- static int test_single_hardlink(struct io_uring *ring)
21
- {
22
- struct __kernel_timespec ts;
23
- struct io_uring_cqe *cqe;
24
- struct io_uring_sqe *sqe;
25
- int ret, i;
26
-
27
- sqe = io_uring_get_sqe(ring);
28
- if (!sqe) {
29
- fprintf(stderr, "get sqe failed\n");
30
- goto err;
31
- }
32
- ts.tv_sec = 0;
33
- ts.tv_nsec = 10000000ULL;
34
- io_uring_prep_timeout(sqe, &ts, 0, 0);
35
- sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
36
- sqe->user_data = 1;
37
-
38
- sqe = io_uring_get_sqe(ring);
39
- if (!sqe) {
40
- fprintf(stderr, "get sqe failed\n");
41
- goto err;
42
- }
43
- io_uring_prep_nop(sqe);
44
- sqe->user_data = 2;
45
-
46
- ret = io_uring_submit(ring);
47
- if (ret <= 0) {
48
- fprintf(stderr, "sqe submit failed: %d\n", ret);
49
- goto err;
50
- }
51
-
52
- for (i = 0; i < 2; i++) {
53
- ret = io_uring_wait_cqe(ring, &cqe);
54
- if (ret < 0) {
55
- fprintf(stderr, "wait completion %d\n", ret);
56
- goto err;
57
- }
58
- if (!cqe) {
59
- fprintf(stderr, "failed to get cqe\n");
60
- goto err;
61
- }
62
- if (no_hardlink)
63
- goto next;
64
- if (cqe->user_data == 1 && cqe->res == -EINVAL) {
65
- fprintf(stdout, "Hard links not supported, skipping\n");
66
- no_hardlink = 1;
67
- goto next;
68
- }
69
- if (cqe->user_data == 1 && cqe->res != -ETIME) {
70
- fprintf(stderr, "timeout failed with %d\n", cqe->res);
71
- goto err;
72
- }
73
- if (cqe->user_data == 2 && cqe->res) {
74
- fprintf(stderr, "nop failed with %d\n", cqe->res);
75
- goto err;
76
- }
77
- next:
78
- io_uring_cqe_seen(ring, cqe);
79
- }
80
-
81
- return 0;
82
- err:
83
- return 1;
84
- }
85
-
86
- /*
87
- * Timer -> timer -> nop
88
- */
89
- static int test_double_hardlink(struct io_uring *ring)
90
- {
91
- struct __kernel_timespec ts1, ts2;
92
- struct io_uring_cqe *cqe;
93
- struct io_uring_sqe *sqe;
94
- int ret, i;
95
-
96
- if (no_hardlink)
97
- return 0;
98
-
99
- sqe = io_uring_get_sqe(ring);
100
- if (!sqe) {
101
- fprintf(stderr, "get sqe failed\n");
102
- goto err;
103
- }
104
- ts1.tv_sec = 0;
105
- ts1.tv_nsec = 10000000ULL;
106
- io_uring_prep_timeout(sqe, &ts1, 0, 0);
107
- sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
108
- sqe->user_data = 1;
109
-
110
- sqe = io_uring_get_sqe(ring);
111
- if (!sqe) {
112
- fprintf(stderr, "get sqe failed\n");
113
- goto err;
114
- }
115
- ts2.tv_sec = 0;
116
- ts2.tv_nsec = 15000000ULL;
117
- io_uring_prep_timeout(sqe, &ts2, 0, 0);
118
- sqe->flags |= IOSQE_IO_LINK | IOSQE_IO_HARDLINK;
119
- sqe->user_data = 2;
120
-
121
- sqe = io_uring_get_sqe(ring);
122
- if (!sqe) {
123
- fprintf(stderr, "get sqe failed\n");
124
- goto err;
125
- }
126
- io_uring_prep_nop(sqe);
127
- sqe->user_data = 3;
128
-
129
- ret = io_uring_submit(ring);
130
- if (ret <= 0) {
131
- fprintf(stderr, "sqe submit failed: %d\n", ret);
132
- goto err;
133
- }
134
-
135
- for (i = 0; i < 3; i++) {
136
- ret = io_uring_wait_cqe(ring, &cqe);
137
- if (ret < 0) {
138
- fprintf(stderr, "wait completion %d\n", ret);
139
- goto err;
140
- }
141
- if (!cqe) {
142
- fprintf(stderr, "failed to get cqe\n");
143
- goto err;
144
- }
145
- if (cqe->user_data == 1 && cqe->res != -ETIME) {
146
- fprintf(stderr, "timeout failed with %d\n", cqe->res);
147
- goto err;
148
- }
149
- if (cqe->user_data == 2 && cqe->res != -ETIME) {
150
- fprintf(stderr, "timeout failed with %d\n", cqe->res);
151
- goto err;
152
- }
153
- if (cqe->user_data == 3 && cqe->res) {
154
- fprintf(stderr, "nop failed with %d\n", cqe->res);
155
- goto err;
156
- }
157
- io_uring_cqe_seen(ring, cqe);
158
- }
159
-
160
- return 0;
161
- err:
162
- return 1;
163
-
164
- }
165
-
166
- /*
167
- * Test failing head of chain, and dependent getting -ECANCELED
168
- */
169
- static int test_single_link_fail(struct io_uring *ring)
170
- {
171
- struct io_uring_cqe *cqe;
172
- struct io_uring_sqe *sqe;
173
- int ret, i;
174
-
175
- sqe = io_uring_get_sqe(ring);
176
- if (!sqe) {
177
- printf("get sqe failed\n");
178
- goto err;
179
- }
180
-
181
- io_uring_prep_nop(sqe);
182
- sqe->flags |= IOSQE_IO_LINK;
183
-
184
- sqe = io_uring_get_sqe(ring);
185
- if (!sqe) {
186
- printf("get sqe failed\n");
187
- goto err;
188
- }
189
-
190
- io_uring_prep_nop(sqe);
191
-
192
- ret = io_uring_submit(ring);
193
- if (ret <= 0) {
194
- printf("sqe submit failed: %d\n", ret);
195
- goto err;
196
- }
197
-
198
- for (i = 0; i < 2; i++) {
199
- ret = io_uring_peek_cqe(ring, &cqe);
200
- if (ret < 0) {
201
- printf("wait completion %d\n", ret);
202
- goto err;
203
- }
204
- if (!cqe) {
205
- printf("failed to get cqe\n");
206
- goto err;
207
- }
208
- if (i == 0 && cqe->res != -EINVAL) {
209
- printf("sqe0 failed with %d, wanted -EINVAL\n", cqe->res);
210
- goto err;
211
- }
212
- if (i == 1 && cqe->res != -ECANCELED) {
213
- printf("sqe1 failed with %d, wanted -ECANCELED\n", cqe->res);
214
- goto err;
215
- }
216
- io_uring_cqe_seen(ring, cqe);
217
- }
218
-
219
- return 0;
220
- err:
221
- return 1;
222
- }
223
-
224
- /*
225
- * Test two independent chains
226
- */
227
- static int test_double_chain(struct io_uring *ring)
228
- {
229
- struct io_uring_cqe *cqe;
230
- struct io_uring_sqe *sqe;
231
- int ret, i;
232
-
233
- sqe = io_uring_get_sqe(ring);
234
- if (!sqe) {
235
- printf("get sqe failed\n");
236
- goto err;
237
- }
238
-
239
- io_uring_prep_nop(sqe);
240
- sqe->flags |= IOSQE_IO_LINK;
241
-
242
- sqe = io_uring_get_sqe(ring);
243
- if (!sqe) {
244
- printf("get sqe failed\n");
245
- goto err;
246
- }
247
-
248
- io_uring_prep_nop(sqe);
249
-
250
- sqe = io_uring_get_sqe(ring);
251
- if (!sqe) {
252
- printf("get sqe failed\n");
253
- goto err;
254
- }
255
-
256
- io_uring_prep_nop(sqe);
257
- sqe->flags |= IOSQE_IO_LINK;
258
-
259
- sqe = io_uring_get_sqe(ring);
260
- if (!sqe) {
261
- printf("get sqe failed\n");
262
- goto err;
263
- }
264
-
265
- io_uring_prep_nop(sqe);
266
-
267
- ret = io_uring_submit(ring);
268
- if (ret <= 0) {
269
- printf("sqe submit failed: %d\n", ret);
270
- goto err;
271
- }
272
-
273
- for (i = 0; i < 4; i++) {
274
- ret = io_uring_wait_cqe(ring, &cqe);
275
- if (ret < 0) {
276
- printf("wait completion %d\n", ret);
277
- goto err;
278
- }
279
- io_uring_cqe_seen(ring, cqe);
280
- }
281
-
282
- return 0;
283
- err:
284
- return 1;
285
- }
286
-
287
- /*
288
- * Test multiple dependents
289
- */
290
- static int test_double_link(struct io_uring *ring)
291
- {
292
- struct io_uring_cqe *cqe;
293
- struct io_uring_sqe *sqe;
294
- int ret, i;
295
-
296
- sqe = io_uring_get_sqe(ring);
297
- if (!sqe) {
298
- printf("get sqe failed\n");
299
- goto err;
300
- }
301
-
302
- io_uring_prep_nop(sqe);
303
- sqe->flags |= IOSQE_IO_LINK;
304
-
305
- sqe = io_uring_get_sqe(ring);
306
- if (!sqe) {
307
- printf("get sqe failed\n");
308
- goto err;
309
- }
310
-
311
- io_uring_prep_nop(sqe);
312
- sqe->flags |= IOSQE_IO_LINK;
313
-
314
- sqe = io_uring_get_sqe(ring);
315
- if (!sqe) {
316
- printf("get sqe failed\n");
317
- goto err;
318
- }
319
-
320
- io_uring_prep_nop(sqe);
321
-
322
- ret = io_uring_submit(ring);
323
- if (ret <= 0) {
324
- printf("sqe submit failed: %d\n", ret);
325
- goto err;
326
- }
327
-
328
- for (i = 0; i < 3; i++) {
329
- ret = io_uring_wait_cqe(ring, &cqe);
330
- if (ret < 0) {
331
- printf("wait completion %d\n", ret);
332
- goto err;
333
- }
334
- io_uring_cqe_seen(ring, cqe);
335
- }
336
-
337
- return 0;
338
- err:
339
- return 1;
340
- }
341
-
342
- /*
343
- * Test single dependency
344
- */
345
- static int test_single_link(struct io_uring *ring)
346
- {
347
- struct io_uring_cqe *cqe;
348
- struct io_uring_sqe *sqe;
349
- int ret, i;
350
-
351
- sqe = io_uring_get_sqe(ring);
352
- if (!sqe) {
353
- printf("get sqe failed\n");
354
- goto err;
355
- }
356
-
357
- io_uring_prep_nop(sqe);
358
- sqe->flags |= IOSQE_IO_LINK;
359
-
360
- sqe = io_uring_get_sqe(ring);
361
- if (!sqe) {
362
- printf("get sqe failed\n");
363
- goto err;
364
- }
365
-
366
- io_uring_prep_nop(sqe);
367
-
368
- ret = io_uring_submit(ring);
369
- if (ret <= 0) {
370
- printf("sqe submit failed: %d\n", ret);
371
- goto err;
372
- }
373
-
374
- for (i = 0; i < 2; i++) {
375
- ret = io_uring_wait_cqe(ring, &cqe);
376
- if (ret < 0) {
377
- printf("wait completion %d\n", ret);
378
- goto err;
379
- }
380
- io_uring_cqe_seen(ring, cqe);
381
- }
382
-
383
- return 0;
384
- err:
385
- return 1;
386
- }
387
-
388
- static int test_early_fail_and_wait(void)
389
- {
390
- struct io_uring ring;
391
- struct io_uring_sqe *sqe;
392
- int ret, invalid_fd = 42;
393
- struct iovec iov = { .iov_base = NULL, .iov_len = 0 };
394
-
395
- /* create a new ring as it leaves it dirty */
396
- ret = io_uring_queue_init(8, &ring, 0);
397
- if (ret) {
398
- printf("ring setup failed\n");
399
- return 1;
400
- }
401
-
402
- sqe = io_uring_get_sqe(&ring);
403
- if (!sqe) {
404
- printf("get sqe failed\n");
405
- goto err;
406
- }
407
-
408
- io_uring_prep_readv(sqe, invalid_fd, &iov, 1, 0);
409
- sqe->flags |= IOSQE_IO_LINK;
410
-
411
- sqe = io_uring_get_sqe(&ring);
412
- if (!sqe) {
413
- printf("get sqe failed\n");
414
- goto err;
415
- }
416
-
417
- io_uring_prep_nop(sqe);
418
-
419
- ret = io_uring_submit_and_wait(&ring, 2);
420
- if (ret <= 0 && ret != -EAGAIN) {
421
- printf("sqe submit failed: %d\n", ret);
422
- goto err;
423
- }
424
-
425
- io_uring_queue_exit(&ring);
426
- return 0;
427
- err:
428
- io_uring_queue_exit(&ring);
429
- return 1;
430
- }
431
-
432
- int main(int argc, char *argv[])
433
- {
434
- struct io_uring ring, poll_ring;
435
- int ret;
436
-
437
- if (argc > 1)
438
- return 0;
439
-
440
- ret = io_uring_queue_init(8, &ring, 0);
441
- if (ret) {
442
- printf("ring setup failed\n");
443
- return 1;
444
-
445
- }
446
-
447
- ret = io_uring_queue_init(8, &poll_ring, IORING_SETUP_IOPOLL);
448
- if (ret) {
449
- printf("poll_ring setup failed\n");
450
- return 1;
451
- }
452
-
453
- ret = test_single_link(&ring);
454
- if (ret) {
455
- printf("test_single_link failed\n");
456
- return ret;
457
- }
458
-
459
- ret = test_double_link(&ring);
460
- if (ret) {
461
- printf("test_double_link failed\n");
462
- return ret;
463
- }
464
-
465
- ret = test_double_chain(&ring);
466
- if (ret) {
467
- printf("test_double_chain failed\n");
468
- return ret;
469
- }
470
-
471
- ret = test_single_link_fail(&poll_ring);
472
- if (ret) {
473
- printf("test_single_link_fail failed\n");
474
- return ret;
475
- }
476
-
477
- ret = test_single_hardlink(&ring);
478
- if (ret) {
479
- fprintf(stderr, "test_single_hardlink\n");
480
- return ret;
481
- }
482
-
483
- ret = test_double_hardlink(&ring);
484
- if (ret) {
485
- fprintf(stderr, "test_double_hardlink\n");
486
- return ret;
487
- }
488
-
489
- ret = test_early_fail_and_wait();
490
- if (ret) {
491
- fprintf(stderr, "test_early_fail_and_wait\n");
492
- return ret;
493
- }
494
-
495
- return 0;
496
- }
@@ -1,229 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: test io_uring link io with drain io
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 "helpers.h"
14
- #include "liburing.h"
15
-
16
- static int test_link_drain_one(struct io_uring *ring)
17
- {
18
- struct io_uring_cqe *cqe;
19
- struct io_uring_sqe *sqe[5];
20
- struct iovec iovecs;
21
- int i, fd, ret;
22
- off_t off = 0;
23
- char data[5] = {0};
24
- char expect[5] = {0, 1, 2, 3, 4};
25
-
26
- fd = open("testfile", O_WRONLY | O_CREAT, 0644);
27
- if (fd < 0) {
28
- perror("open");
29
- return 1;
30
- }
31
-
32
- iovecs.iov_base = t_malloc(4096);
33
- iovecs.iov_len = 4096;
34
-
35
- for (i = 0; i < 5; i++) {
36
- sqe[i] = io_uring_get_sqe(ring);
37
- if (!sqe[i]) {
38
- printf("get sqe failed\n");
39
- goto err;
40
- }
41
- }
42
-
43
- /* normal heavy io */
44
- io_uring_prep_writev(sqe[0], fd, &iovecs, 1, off);
45
- sqe[0]->user_data = 0;
46
-
47
- /* link io */
48
- io_uring_prep_nop(sqe[1]);
49
- sqe[1]->flags |= IOSQE_IO_LINK;
50
- sqe[1]->user_data = 1;
51
-
52
- /* link drain io */
53
- io_uring_prep_nop(sqe[2]);
54
- sqe[2]->flags |= (IOSQE_IO_LINK | IOSQE_IO_DRAIN);
55
- sqe[2]->user_data = 2;
56
-
57
- /* link io */
58
- io_uring_prep_nop(sqe[3]);
59
- sqe[3]->user_data = 3;
60
-
61
- /* normal nop io */
62
- io_uring_prep_nop(sqe[4]);
63
- sqe[4]->user_data = 4;
64
-
65
- ret = io_uring_submit(ring);
66
- if (ret < 0) {
67
- printf("sqe submit failed\n");
68
- goto err;
69
- } else if (ret < 5) {
70
- printf("Submitted only %d\n", ret);
71
- goto err;
72
- }
73
-
74
- for (i = 0; i < 5; i++) {
75
- ret = io_uring_wait_cqe(ring, &cqe);
76
- if (ret < 0) {
77
- printf("child: wait completion %d\n", ret);
78
- goto err;
79
- }
80
-
81
- data[i] = cqe->user_data;
82
- io_uring_cqe_seen(ring, cqe);
83
- }
84
-
85
- if (memcmp(data, expect, 5) != 0)
86
- goto err;
87
-
88
- free(iovecs.iov_base);
89
- close(fd);
90
- unlink("testfile");
91
- return 0;
92
- err:
93
- free(iovecs.iov_base);
94
- close(fd);
95
- unlink("testfile");
96
- return 1;
97
- }
98
-
99
- int test_link_drain_multi(struct io_uring *ring)
100
- {
101
- struct io_uring_cqe *cqe;
102
- struct io_uring_sqe *sqe[9];
103
- struct iovec iovecs;
104
- int i, fd, ret;
105
- off_t off = 0;
106
- char data[9] = {0};
107
- char expect[9] = {0, 1, 2, 3, 4, 5, 6, 7, 8};
108
-
109
- fd = open("testfile", O_WRONLY | O_CREAT, 0644);
110
- if (fd < 0) {
111
- perror("open");
112
- return 1;
113
- }
114
- unlink("testfile");
115
-
116
- iovecs.iov_base = t_malloc(4096);
117
- iovecs.iov_len = 4096;
118
-
119
- for (i = 0; i < 9; i++) {
120
- sqe[i] = io_uring_get_sqe(ring);
121
- if (!sqe[i]) {
122
- printf("get sqe failed\n");
123
- goto err;
124
- }
125
- }
126
-
127
- /* normal heavy io */
128
- io_uring_prep_writev(sqe[0], fd, &iovecs, 1, off);
129
- sqe[0]->user_data = 0;
130
-
131
- /* link1 io head */
132
- io_uring_prep_nop(sqe[1]);
133
- sqe[1]->flags |= IOSQE_IO_LINK;
134
- sqe[1]->user_data = 1;
135
-
136
- /* link1 drain io */
137
- io_uring_prep_nop(sqe[2]);
138
- sqe[2]->flags |= (IOSQE_IO_LINK | IOSQE_IO_DRAIN);
139
- sqe[2]->user_data = 2;
140
-
141
- /* link1 io end*/
142
- io_uring_prep_nop(sqe[3]);
143
- sqe[3]->user_data = 3;
144
-
145
- /* link2 io head */
146
- io_uring_prep_nop(sqe[4]);
147
- sqe[4]->flags |= IOSQE_IO_LINK;
148
- sqe[4]->user_data = 4;
149
-
150
- /* link2 io */
151
- io_uring_prep_nop(sqe[5]);
152
- sqe[5]->flags |= IOSQE_IO_LINK;
153
- sqe[5]->user_data = 5;
154
-
155
- /* link2 drain io */
156
- io_uring_prep_writev(sqe[6], fd, &iovecs, 1, off);
157
- sqe[6]->flags |= (IOSQE_IO_LINK | IOSQE_IO_DRAIN);
158
- sqe[6]->user_data = 6;
159
-
160
- /* link2 io end */
161
- io_uring_prep_nop(sqe[7]);
162
- sqe[7]->user_data = 7;
163
-
164
- /* normal io */
165
- io_uring_prep_nop(sqe[8]);
166
- sqe[8]->user_data = 8;
167
-
168
- ret = io_uring_submit(ring);
169
- if (ret < 0) {
170
- printf("sqe submit failed\n");
171
- goto err;
172
- } else if (ret < 9) {
173
- printf("Submitted only %d\n", ret);
174
- goto err;
175
- }
176
-
177
- for (i = 0; i < 9; i++) {
178
- ret = io_uring_wait_cqe(ring, &cqe);
179
- if (ret < 0) {
180
- printf("child: wait completion %d\n", ret);
181
- goto err;
182
- }
183
-
184
- data[i] = cqe->user_data;
185
- io_uring_cqe_seen(ring, cqe);
186
- }
187
-
188
- if (memcmp(data, expect, 9) != 0)
189
- goto err;
190
-
191
- free(iovecs.iov_base);
192
- close(fd);
193
- return 0;
194
- err:
195
- free(iovecs.iov_base);
196
- close(fd);
197
- return 1;
198
-
199
- }
200
-
201
- int main(int argc, char *argv[])
202
- {
203
- struct io_uring ring;
204
- int i, ret;
205
-
206
- if (argc > 1)
207
- return 0;
208
-
209
- ret = io_uring_queue_init(100, &ring, 0);
210
- if (ret) {
211
- printf("ring setup failed\n");
212
- return 1;
213
- }
214
-
215
- for (i = 0; i < 1000; i++) {
216
- ret = test_link_drain_one(&ring);
217
- if (ret) {
218
- fprintf(stderr, "test_link_drain_one failed\n");
219
- break;
220
- }
221
- ret = test_link_drain_multi(&ring);
222
- if (ret) {
223
- fprintf(stderr, "test_link_drain_multi failed\n");
224
- break;
225
- }
226
- }
227
-
228
- return ret;
229
- }