@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,232 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: check that STDOUT write works
4
- */
5
- #include <errno.h>
6
- #include <stdio.h>
7
- #include <unistd.h>
8
- #include <stdlib.h>
9
- #include <string.h>
10
- #include <fcntl.h>
11
-
12
- #include "helpers.h"
13
- #include "liburing.h"
14
-
15
- static int test_pipe_io_fixed(struct io_uring *ring)
16
- {
17
- const char str[] = "This is a fixed pipe test\n";
18
- struct io_uring_cqe *cqe;
19
- struct io_uring_sqe *sqe;
20
- struct iovec vecs[2];
21
- char buffer[128];
22
- int i, ret, fds[2];
23
-
24
- t_posix_memalign(&vecs[0].iov_base, 4096, 4096);
25
- memcpy(vecs[0].iov_base, str, strlen(str));
26
- vecs[0].iov_len = strlen(str);
27
-
28
- if (pipe(fds) < 0) {
29
- perror("pipe");
30
- return 1;
31
- }
32
-
33
- ret = io_uring_register_buffers(ring, vecs, 1);
34
- if (ret) {
35
- fprintf(stderr, "Failed to register buffers: %d\n", ret);
36
- return 1;
37
- }
38
-
39
- sqe = io_uring_get_sqe(ring);
40
- if (!sqe) {
41
- fprintf(stderr, "get sqe failed\n");
42
- goto err;
43
- }
44
- io_uring_prep_write_fixed(sqe, fds[1], vecs[0].iov_base,
45
- vecs[0].iov_len, 0, 0);
46
- sqe->user_data = 1;
47
-
48
- sqe = io_uring_get_sqe(ring);
49
- if (!sqe) {
50
- fprintf(stderr, "get sqe failed\n");
51
- goto err;
52
- }
53
- vecs[1].iov_base = buffer;
54
- vecs[1].iov_len = sizeof(buffer);
55
- io_uring_prep_readv(sqe, fds[0], &vecs[1], 1, 0);
56
- sqe->user_data = 2;
57
-
58
- ret = io_uring_submit(ring);
59
- if (ret < 0) {
60
- fprintf(stderr, "sqe submit failed: %d\n", ret);
61
- goto err;
62
- } else if (ret != 2) {
63
- fprintf(stderr, "Submitted only %d\n", ret);
64
- goto err;
65
- }
66
-
67
- for (i = 0; i < 2; i++) {
68
- ret = io_uring_wait_cqe(ring, &cqe);
69
- if (ret < 0) {
70
- fprintf(stderr, "wait completion %d\n", ret);
71
- goto err;
72
- }
73
- if (cqe->res < 0) {
74
- fprintf(stderr, "I/O write error on %lu: %s\n",
75
- (unsigned long) cqe->user_data,
76
- strerror(-cqe->res));
77
- goto err;
78
- }
79
- if (cqe->res != strlen(str)) {
80
- fprintf(stderr, "Got %d bytes, wanted %d on %lu\n",
81
- cqe->res, (int)strlen(str),
82
- (unsigned long) cqe->user_data);
83
- goto err;
84
- }
85
- if (cqe->user_data == 2 && memcmp(str, buffer, strlen(str))) {
86
- fprintf(stderr, "read data mismatch\n");
87
- goto err;
88
- }
89
- io_uring_cqe_seen(ring, cqe);
90
- }
91
- io_uring_unregister_buffers(ring);
92
- return 0;
93
- err:
94
- return 1;
95
- }
96
-
97
- static int test_stdout_io_fixed(struct io_uring *ring)
98
- {
99
- const char str[] = "This is a fixed pipe test\n";
100
- struct io_uring_cqe *cqe;
101
- struct io_uring_sqe *sqe;
102
- struct iovec vecs;
103
- int ret;
104
-
105
- t_posix_memalign(&vecs.iov_base, 4096, 4096);
106
- memcpy(vecs.iov_base, str, strlen(str));
107
- vecs.iov_len = strlen(str);
108
-
109
- ret = io_uring_register_buffers(ring, &vecs, 1);
110
- if (ret) {
111
- fprintf(stderr, "Failed to register buffers: %d\n", ret);
112
- return 1;
113
- }
114
-
115
- sqe = io_uring_get_sqe(ring);
116
- if (!sqe) {
117
- fprintf(stderr, "get sqe failed\n");
118
- goto err;
119
- }
120
- io_uring_prep_write_fixed(sqe, STDOUT_FILENO, vecs.iov_base, vecs.iov_len, 0, 0);
121
-
122
- ret = io_uring_submit(ring);
123
- if (ret < 0) {
124
- fprintf(stderr, "sqe submit failed: %d\n", ret);
125
- goto err;
126
- } else if (ret < 1) {
127
- fprintf(stderr, "Submitted only %d\n", ret);
128
- goto err;
129
- }
130
-
131
- ret = io_uring_wait_cqe(ring, &cqe);
132
- if (ret < 0) {
133
- fprintf(stderr, "wait completion %d\n", ret);
134
- goto err;
135
- }
136
- if (cqe->res < 0) {
137
- fprintf(stderr, "STDOUT write error: %s\n", strerror(-cqe->res));
138
- goto err;
139
- }
140
- if (cqe->res != vecs.iov_len) {
141
- fprintf(stderr, "Got %d write, wanted %d\n", cqe->res, (int)vecs.iov_len);
142
- goto err;
143
- }
144
- io_uring_cqe_seen(ring, cqe);
145
- io_uring_unregister_buffers(ring);
146
- return 0;
147
- err:
148
- return 1;
149
- }
150
-
151
- static int test_stdout_io(struct io_uring *ring)
152
- {
153
- struct io_uring_cqe *cqe;
154
- struct io_uring_sqe *sqe;
155
- struct iovec vecs;
156
- int ret;
157
-
158
- vecs.iov_base = "This is a pipe test\n";
159
- vecs.iov_len = strlen(vecs.iov_base);
160
-
161
- sqe = io_uring_get_sqe(ring);
162
- if (!sqe) {
163
- fprintf(stderr, "get sqe failed\n");
164
- goto err;
165
- }
166
- io_uring_prep_writev(sqe, STDOUT_FILENO, &vecs, 1, 0);
167
-
168
- ret = io_uring_submit(ring);
169
- if (ret < 0) {
170
- fprintf(stderr, "sqe submit failed: %d\n", ret);
171
- goto err;
172
- } else if (ret < 1) {
173
- fprintf(stderr, "Submitted only %d\n", ret);
174
- goto err;
175
- }
176
-
177
- ret = io_uring_wait_cqe(ring, &cqe);
178
- if (ret < 0) {
179
- fprintf(stderr, "wait completion %d\n", ret);
180
- goto err;
181
- }
182
- if (cqe->res < 0) {
183
- fprintf(stderr, "STDOUT write error: %s\n",
184
- strerror(-cqe->res));
185
- goto err;
186
- }
187
- if (cqe->res != vecs.iov_len) {
188
- fprintf(stderr, "Got %d write, wanted %d\n", cqe->res,
189
- (int)vecs.iov_len);
190
- goto err;
191
- }
192
- io_uring_cqe_seen(ring, cqe);
193
-
194
- return 0;
195
- err:
196
- return 1;
197
- }
198
-
199
- int main(int argc, char *argv[])
200
- {
201
- struct io_uring ring;
202
- int ret;
203
-
204
- if (argc > 1)
205
- return 0;
206
-
207
- ret = io_uring_queue_init(8, &ring, 0);
208
- if (ret) {
209
- fprintf(stderr, "ring setup failed\n");
210
- return 1;
211
- }
212
-
213
- ret = test_stdout_io(&ring);
214
- if (ret) {
215
- fprintf(stderr, "test_pipe_io failed\n");
216
- return ret;
217
- }
218
-
219
- ret = test_stdout_io_fixed(&ring);
220
- if (ret) {
221
- fprintf(stderr, "test_pipe_io_fixed failed\n");
222
- return ret;
223
- }
224
-
225
- ret = test_pipe_io_fixed(&ring);
226
- if (ret) {
227
- fprintf(stderr, "test_pipe_io_fixed failed\n");
228
- return ret;
229
- }
230
-
231
- return 0;
232
- }
@@ -1,154 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: tests linked requests failing during submission
4
- */
5
- #include <errno.h>
6
- #include <stdio.h>
7
- #include <unistd.h>
8
- #include <stdlib.h>
9
- #include <string.h>
10
- #include <fcntl.h>
11
- #include <assert.h>
12
-
13
- #include "liburing.h"
14
-
15
- #define DRAIN_USER_DATA 42
16
-
17
- static int test_underprep_fail(bool hardlink, bool drain, bool link_last,
18
- int link_size, int fail_idx)
19
- {
20
- const int invalid_fd = 42;
21
- int link_flags = IOSQE_IO_LINK;
22
- int total_submit = link_size;
23
- struct io_uring ring;
24
- struct io_uring_sqe *sqe;
25
- struct io_uring_cqe *cqe;
26
- char buffer[1];
27
- int i, ret, fds[2];
28
-
29
- if (drain)
30
- link_flags |= IOSQE_IO_DRAIN;
31
- if (hardlink)
32
- link_flags |= IOSQE_IO_HARDLINK;
33
-
34
- assert(fail_idx < link_size);
35
- assert(link_size < 40);
36
-
37
- /* create a new ring as it leaves it dirty */
38
- ret = io_uring_queue_init(8, &ring, 0);
39
- if (ret) {
40
- printf("ring setup failed\n");
41
- return -1;
42
- }
43
- if (pipe(fds)) {
44
- perror("pipe");
45
- return -1;
46
- }
47
-
48
- if (drain) {
49
- /* clog drain, so following reqs sent to draining */
50
- sqe = io_uring_get_sqe(&ring);
51
- io_uring_prep_read(sqe, fds[0], buffer, sizeof(buffer), 0);
52
- sqe->user_data = DRAIN_USER_DATA;
53
- sqe->flags |= IOSQE_IO_DRAIN;
54
- total_submit++;
55
- }
56
-
57
- for (i = 0; i < link_size; i++) {
58
- sqe = io_uring_get_sqe(&ring);
59
- if (i == fail_idx)
60
- io_uring_prep_read(sqe, invalid_fd, buffer, 1, 0);
61
- else
62
- io_uring_prep_nop(sqe);
63
-
64
- if (i != link_size - 1 || !link_last)
65
- sqe->flags |= link_flags;
66
- sqe->user_data = i;
67
- }
68
-
69
- ret = io_uring_submit(&ring);
70
- if (ret != total_submit) {
71
- /* Old behaviour, failed early and under-submitted */
72
- if (ret == fail_idx + 1 + drain)
73
- goto out;
74
- fprintf(stderr, "submit failed: %d\n", ret);
75
- return -1;
76
- }
77
-
78
- if (drain) {
79
- /* unclog drain */
80
- ret = write(fds[1], buffer, sizeof(buffer));
81
- if (ret < 0) {
82
- perror("write");
83
- return 1;
84
- }
85
- }
86
-
87
- for (i = 0; i < total_submit; i++) {
88
- ret = io_uring_wait_cqe(&ring, &cqe);
89
- if (ret) {
90
- fprintf(stderr, "wait_cqe=%d\n", ret);
91
- return 1;
92
- }
93
-
94
- ret = cqe->res;
95
- if (cqe->user_data == DRAIN_USER_DATA) {
96
- if (ret != 1) {
97
- fprintf(stderr, "drain failed %d\n", ret);
98
- return 1;
99
- }
100
- } else if (cqe->user_data == fail_idx) {
101
- if (ret == 0 || ret == -ECANCELED) {
102
- fprintf(stderr, "half-prep req unexpected return %d\n", ret);
103
- return 1;
104
- }
105
- } else {
106
- if (ret != -ECANCELED) {
107
- fprintf(stderr, "cancel failed %d, ud %d\n", ret, (int)cqe->user_data);
108
- return 1;
109
- }
110
- }
111
- io_uring_cqe_seen(&ring, cqe);
112
- }
113
- out:
114
- close(fds[0]);
115
- close(fds[1]);
116
- io_uring_queue_exit(&ring);
117
- return 0;
118
- }
119
-
120
- int main(int argc, char *argv[])
121
- {
122
- int ret, link_size, fail_idx, i;
123
-
124
- if (argc > 1)
125
- return 0;
126
-
127
- /*
128
- * hardlink, size=3, fail_idx=1, drain=false -- kernel fault
129
- * link, size=3, fail_idx=0, drain=true -- kernel fault
130
- * link, size=3, fail_idx=1, drain=true -- invalid cqe->res
131
- */
132
- for (link_size = 0; link_size < 3; link_size++) {
133
- for (fail_idx = 0; fail_idx < link_size; fail_idx++) {
134
- for (i = 0; i < 8; i++) {
135
- bool hardlink = (i & 1) != 0;
136
- bool drain = (i & 2) != 0;
137
- bool link_last = (i & 4) != 0;
138
-
139
- ret = test_underprep_fail(hardlink, drain, link_last,
140
- link_size, fail_idx);
141
- if (!ret)
142
- continue;
143
-
144
- fprintf(stderr, "failed %d, hard %d, drain %d,"
145
- "link_last %d, size %d, idx %d\n",
146
- ret, hardlink, drain, link_last,
147
- link_size, fail_idx);
148
- return 1;
149
- }
150
- }
151
- }
152
-
153
- return 0;
154
- }
@@ -1,239 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Test reads that will punt to blocking context, with immediate overwrite
4
- * of iovec->iov_base to NULL. If the kernel doesn't properly handle
5
- * reuse of the iovec, we should get -EFAULT.
6
- */
7
- #include <unistd.h>
8
- #include <fcntl.h>
9
- #include <stdio.h>
10
- #include <string.h>
11
- #include <stdlib.h>
12
- #include <pthread.h>
13
- #include <sys/time.h>
14
-
15
- #include "helpers.h"
16
- #include "liburing.h"
17
-
18
- #define STR_SIZE 32768
19
- #define FILE_SIZE 65536
20
-
21
- struct thread_data {
22
- int fd1, fd2;
23
- volatile int do_exit;
24
- };
25
-
26
- static void *flusher(void *__data)
27
- {
28
- struct thread_data *data = __data;
29
- int i = 0;
30
-
31
- while (!data->do_exit) {
32
- posix_fadvise(data->fd1, 0, FILE_SIZE, POSIX_FADV_DONTNEED);
33
- posix_fadvise(data->fd2, 0, FILE_SIZE, POSIX_FADV_DONTNEED);
34
- usleep(10);
35
- i++;
36
- }
37
-
38
- return NULL;
39
- }
40
-
41
- static char str1[STR_SIZE];
42
- static char str2[STR_SIZE];
43
-
44
- static struct io_uring ring;
45
-
46
- static int no_stable;
47
-
48
- static int prep(int fd, char *str, int split, int async)
49
- {
50
- struct io_uring_sqe *sqe;
51
- struct iovec iovs[16];
52
- int ret, i;
53
-
54
- if (split) {
55
- int vsize = STR_SIZE / 16;
56
- void *ptr = str;
57
-
58
- for (i = 0; i < 16; i++) {
59
- iovs[i].iov_base = ptr;
60
- iovs[i].iov_len = vsize;
61
- ptr += vsize;
62
- }
63
- } else {
64
- iovs[0].iov_base = str;
65
- iovs[0].iov_len = STR_SIZE;
66
- }
67
-
68
- sqe = io_uring_get_sqe(&ring);
69
- io_uring_prep_readv(sqe, fd, iovs, split ? 16 : 1, 0);
70
- sqe->user_data = fd;
71
- if (async)
72
- sqe->flags = IOSQE_ASYNC;
73
- ret = io_uring_submit(&ring);
74
- if (ret != 1) {
75
- fprintf(stderr, "submit got %d\n", ret);
76
- return 1;
77
- }
78
- if (split) {
79
- for (i = 0; i < 16; i++)
80
- iovs[i].iov_base = NULL;
81
- } else {
82
- iovs[0].iov_base = NULL;
83
- }
84
- return 0;
85
- }
86
-
87
- static int wait_nr(int nr)
88
- {
89
- int i, ret;
90
-
91
- for (i = 0; i < nr; i++) {
92
- struct io_uring_cqe *cqe;
93
-
94
- ret = io_uring_wait_cqe(&ring, &cqe);
95
- if (ret)
96
- return ret;
97
- if (cqe->res < 0) {
98
- fprintf(stderr, "cqe->res=%d\n", cqe->res);
99
- return 1;
100
- }
101
- io_uring_cqe_seen(&ring, cqe);
102
- }
103
-
104
- return 0;
105
- }
106
-
107
- static unsigned long long mtime_since(const struct timeval *s,
108
- const struct timeval *e)
109
- {
110
- long long sec, usec;
111
-
112
- sec = e->tv_sec - s->tv_sec;
113
- usec = (e->tv_usec - s->tv_usec);
114
- if (sec > 0 && usec < 0) {
115
- sec--;
116
- usec += 1000000;
117
- }
118
-
119
- sec *= 1000;
120
- usec /= 1000;
121
- return sec + usec;
122
- }
123
-
124
- static unsigned long long mtime_since_now(struct timeval *tv)
125
- {
126
- struct timeval end;
127
-
128
- gettimeofday(&end, NULL);
129
- return mtime_since(tv, &end);
130
- }
131
-
132
- static int test_reuse(int argc, char *argv[], int split, int async)
133
- {
134
- struct thread_data data;
135
- struct io_uring_params p = { };
136
- int fd1, fd2, ret, i;
137
- struct timeval tv;
138
- pthread_t thread;
139
- char *fname1 = ".reuse.1";
140
- int do_unlink = 1;
141
- void *tret;
142
-
143
- ret = io_uring_queue_init_params(32, &ring, &p);
144
- if (ret) {
145
- fprintf(stderr, "io_uring_queue_init: %d\n", ret);
146
- return 1;
147
- }
148
-
149
- if (!(p.features & IORING_FEAT_SUBMIT_STABLE)) {
150
- fprintf(stdout, "FEAT_SUBMIT_STABLE not there, skipping\n");
151
- io_uring_queue_exit(&ring);
152
- no_stable = 1;
153
- return 0;
154
- }
155
-
156
- if (argc > 1) {
157
- fname1 = argv[1];
158
- do_unlink = 0;
159
- } else {
160
- t_create_file(fname1, FILE_SIZE);
161
- }
162
-
163
- fd1 = open(fname1, O_RDONLY);
164
- if (do_unlink)
165
- unlink(fname1);
166
- if (fd1 < 0) {
167
- perror("open fname1");
168
- goto err;
169
- }
170
-
171
- t_create_file(".reuse.2", FILE_SIZE);
172
- fd2 = open(".reuse.2", O_RDONLY);
173
- unlink(".reuse.2");
174
- if (fd2 < 0) {
175
- perror("open .reuse.2");
176
- goto err;
177
- }
178
-
179
- data.fd1 = fd1;
180
- data.fd2 = fd2;
181
- data.do_exit = 0;
182
- pthread_create(&thread, NULL, flusher, &data);
183
- usleep(10000);
184
-
185
- gettimeofday(&tv, NULL);
186
- for (i = 0; i < 1000; i++) {
187
- ret = prep(fd1, str1, split, async);
188
- if (ret) {
189
- fprintf(stderr, "prep1 failed: %d\n", ret);
190
- goto err;
191
- }
192
- ret = prep(fd2, str2, split, async);
193
- if (ret) {
194
- fprintf(stderr, "prep1 failed: %d\n", ret);
195
- goto err;
196
- }
197
- ret = wait_nr(2);
198
- if (ret) {
199
- fprintf(stderr, "wait_nr: %d\n", ret);
200
- goto err;
201
- }
202
- if (mtime_since_now(&tv) > 5000)
203
- break;
204
- }
205
-
206
- data.do_exit = 1;
207
- pthread_join(thread, &tret);
208
-
209
- close(fd2);
210
- close(fd1);
211
- io_uring_queue_exit(&ring);
212
- return 0;
213
- err:
214
- io_uring_queue_exit(&ring);
215
- return 1;
216
-
217
- }
218
-
219
- int main(int argc, char *argv[])
220
- {
221
- int ret, i;
222
-
223
- for (i = 0; i < 4; i++) {
224
- int split, async;
225
-
226
- split = (i & 1) != 0;
227
- async = (i & 2) != 0;
228
-
229
- ret = test_reuse(argc, argv, split, async);
230
- if (ret) {
231
- fprintf(stderr, "test_reuse %d %d failed\n", split, async);
232
- return ret;
233
- }
234
- if (no_stable)
235
- break;
236
- }
237
-
238
- return 0;
239
- }