@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,227 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- #include <errno.h>
3
- #include <stdio.h>
4
- #include <unistd.h>
5
- #include <stdlib.h>
6
- #include <string.h>
7
- #include <fcntl.h>
8
- #include <assert.h>
9
- #include <pthread.h>
10
- #include <sys/socket.h>
11
- #include <netinet/tcp.h>
12
- #include <netinet/in.h>
13
- #include <poll.h>
14
-
15
- #include "liburing.h"
16
-
17
- pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
18
- pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
19
-
20
- static int recv_thread_ready = 0;
21
- static int recv_thread_done = 0;
22
-
23
- static void signal_var(int *var)
24
- {
25
- pthread_mutex_lock(&mutex);
26
- *var = 1;
27
- pthread_cond_signal(&cond);
28
- pthread_mutex_unlock(&mutex);
29
- }
30
-
31
- static void wait_for_var(int *var)
32
- {
33
- pthread_mutex_lock(&mutex);
34
-
35
- while (!*var)
36
- pthread_cond_wait(&cond, &mutex);
37
-
38
- pthread_mutex_unlock(&mutex);
39
- }
40
-
41
- struct data {
42
- unsigned expected[2];
43
- unsigned is_mask[2];
44
- unsigned long timeout;
45
- int port;
46
- int stop;
47
- };
48
-
49
- static void *send_thread(void *arg)
50
- {
51
- struct data *data = arg;
52
-
53
- wait_for_var(&recv_thread_ready);
54
-
55
- int s0 = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
56
- assert(s0 != -1);
57
-
58
- struct sockaddr_in addr;
59
-
60
- addr.sin_family = AF_INET;
61
- addr.sin_port = data->port;
62
- addr.sin_addr.s_addr = 0x0100007fU;
63
-
64
- if (connect(s0, (struct sockaddr*)&addr, sizeof(addr)) != -1)
65
- wait_for_var(&recv_thread_done);
66
-
67
- close(s0);
68
- return 0;
69
- }
70
-
71
- void *recv_thread(void *arg)
72
- {
73
- struct data *data = arg;
74
- struct io_uring_sqe *sqe;
75
- struct io_uring ring;
76
- int i, ret;
77
-
78
- ret = io_uring_queue_init(8, &ring, 0);
79
- assert(ret == 0);
80
-
81
- int s0 = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
82
- assert(s0 != -1);
83
-
84
- int32_t val = 1;
85
- ret = setsockopt(s0, SOL_SOCKET, SO_REUSEPORT, &val, sizeof(val));
86
- assert(ret != -1);
87
- ret = setsockopt(s0, SOL_SOCKET, SO_REUSEADDR, &val, sizeof(val));
88
- assert(ret != -1);
89
-
90
- struct sockaddr_in addr;
91
-
92
- addr.sin_family = AF_INET;
93
- addr.sin_addr.s_addr = 0x0100007fU;
94
-
95
- i = 0;
96
- do {
97
- data->port = 1025 + (rand() % 64510);
98
- addr.sin_port = data->port;
99
-
100
- if (bind(s0, (struct sockaddr*)&addr, sizeof(addr)) != -1)
101
- break;
102
- } while (++i < 100);
103
-
104
- if (i >= 100) {
105
- fprintf(stderr, "Can't find good port, skipped\n");
106
- data->stop = 1;
107
- signal_var(&recv_thread_ready);
108
- goto out;
109
- }
110
-
111
- ret = listen(s0, 128);
112
- assert(ret != -1);
113
-
114
- signal_var(&recv_thread_ready);
115
-
116
- sqe = io_uring_get_sqe(&ring);
117
- assert(sqe != NULL);
118
-
119
- io_uring_prep_poll_add(sqe, s0, POLLIN | POLLHUP | POLLERR);
120
- sqe->flags |= IOSQE_IO_LINK;
121
- sqe->user_data = 1;
122
-
123
- sqe = io_uring_get_sqe(&ring);
124
- assert(sqe != NULL);
125
-
126
- struct __kernel_timespec ts;
127
- ts.tv_sec = data->timeout / 1000000000;
128
- ts.tv_nsec = data->timeout % 1000000000;
129
- io_uring_prep_link_timeout(sqe, &ts, 0);
130
- sqe->user_data = 2;
131
-
132
- ret = io_uring_submit(&ring);
133
- assert(ret == 2);
134
-
135
- for (i = 0; i < 2; i++) {
136
- struct io_uring_cqe *cqe;
137
- int idx;
138
-
139
- if (io_uring_wait_cqe(&ring, &cqe)) {
140
- fprintf(stderr, "wait cqe failed\n");
141
- goto err;
142
- }
143
- idx = cqe->user_data - 1;
144
- if (data->is_mask[idx] && !(data->expected[idx] & cqe->res)) {
145
- fprintf(stderr, "cqe %" PRIu64 " got %x, wanted mask %x\n",
146
- (uint64_t) cqe->user_data, cqe->res,
147
- data->expected[idx]);
148
- goto err;
149
- } else if (!data->is_mask[idx] && cqe->res != data->expected[idx]) {
150
- fprintf(stderr, "cqe %" PRIu64 " got %d, wanted %d\n",
151
- (uint64_t) cqe->user_data, cqe->res,
152
- data->expected[idx]);
153
- goto err;
154
- }
155
- io_uring_cqe_seen(&ring, cqe);
156
- }
157
-
158
- out:
159
- signal_var(&recv_thread_done);
160
- close(s0);
161
- io_uring_queue_exit(&ring);
162
- return NULL;
163
- err:
164
- signal_var(&recv_thread_done);
165
- close(s0);
166
- io_uring_queue_exit(&ring);
167
- return (void *) 1;
168
- }
169
-
170
- static int test_poll_timeout(int do_connect, unsigned long timeout)
171
- {
172
- pthread_t t1, t2;
173
- struct data d;
174
- void *tret;
175
- int ret = 0;
176
-
177
- recv_thread_ready = 0;
178
- recv_thread_done = 0;
179
-
180
- memset(&d, 0, sizeof(d));
181
- d.timeout = timeout;
182
- if (!do_connect) {
183
- d.expected[0] = -ECANCELED;
184
- d.expected[1] = -ETIME;
185
- } else {
186
- d.expected[0] = POLLIN;
187
- d.is_mask[0] = 1;
188
- d.expected[1] = -ECANCELED;
189
- }
190
-
191
- pthread_create(&t1, NULL, recv_thread, &d);
192
-
193
- if (do_connect)
194
- pthread_create(&t2, NULL, send_thread, &d);
195
-
196
- pthread_join(t1, &tret);
197
- if (tret)
198
- ret++;
199
-
200
- if (do_connect) {
201
- pthread_join(t2, &tret);
202
- if (tret)
203
- ret++;
204
- }
205
-
206
- return ret;
207
- }
208
-
209
- int main(int argc, char *argv[])
210
- {
211
- if (argc > 1)
212
- return 0;
213
-
214
- srand(getpid());
215
-
216
- if (test_poll_timeout(0, 200000000)) {
217
- fprintf(stderr, "poll timeout 0 failed\n");
218
- return 1;
219
- }
220
-
221
- if (test_poll_timeout(1, 1000000000)) {
222
- fprintf(stderr, "poll timeout 1 failed\n");
223
- return 1;
224
- }
225
-
226
- return 0;
227
- }
@@ -1,208 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: test many files being polled for
4
- *
5
- */
6
- #include <errno.h>
7
- #include <stdio.h>
8
- #include <unistd.h>
9
- #include <stdlib.h>
10
- #include <string.h>
11
- #include <signal.h>
12
- #include <sys/poll.h>
13
- #include <sys/resource.h>
14
- #include <fcntl.h>
15
-
16
- #include "liburing.h"
17
-
18
- #define NFILES 5000
19
- #define BATCH 500
20
- #define NLOOPS 1000
21
-
22
- #define RING_SIZE 512
23
-
24
- struct p {
25
- int fd[2];
26
- int triggered;
27
- };
28
-
29
- static struct p p[NFILES];
30
-
31
- static int arm_poll(struct io_uring *ring, int off)
32
- {
33
- struct io_uring_sqe *sqe;
34
-
35
- sqe = io_uring_get_sqe(ring);
36
- if (!sqe) {
37
- fprintf(stderr, "failed getting sqe\n");
38
- return 1;
39
- }
40
-
41
- io_uring_prep_poll_add(sqe, p[off].fd[0], POLLIN);
42
- sqe->user_data = off;
43
- return 0;
44
- }
45
-
46
- static int reap_polls(struct io_uring *ring)
47
- {
48
- struct io_uring_cqe *cqe;
49
- int i, ret, off;
50
- char c;
51
-
52
- for (i = 0; i < BATCH; i++) {
53
- ret = io_uring_wait_cqe(ring, &cqe);
54
- if (ret) {
55
- fprintf(stderr, "wait cqe %d\n", ret);
56
- return ret;
57
- }
58
- off = cqe->user_data;
59
- p[off].triggered = 0;
60
- ret = read(p[off].fd[0], &c, 1);
61
- if (ret != 1) {
62
- fprintf(stderr, "read got %d/%d\n", ret, errno);
63
- break;
64
- }
65
- if (arm_poll(ring, off))
66
- break;
67
- io_uring_cqe_seen(ring, cqe);
68
- }
69
-
70
- if (i != BATCH) {
71
- fprintf(stderr, "gave up at %d\n", i);
72
- return 1;
73
- }
74
-
75
- ret = io_uring_submit(ring);
76
- if (ret != BATCH) {
77
- fprintf(stderr, "submitted %d, %d\n", ret, BATCH);
78
- return 1;
79
- }
80
-
81
- return 0;
82
- }
83
-
84
- static int trigger_polls(void)
85
- {
86
- char c = 89;
87
- int i, ret;
88
-
89
- for (i = 0; i < BATCH; i++) {
90
- int off;
91
-
92
- do {
93
- off = rand() % NFILES;
94
- if (!p[off].triggered)
95
- break;
96
- } while (1);
97
-
98
- p[off].triggered = 1;
99
- ret = write(p[off].fd[1], &c, 1);
100
- if (ret != 1) {
101
- fprintf(stderr, "write got %d/%d\n", ret, errno);
102
- return 1;
103
- }
104
- }
105
-
106
- return 0;
107
- }
108
-
109
- static int arm_polls(struct io_uring *ring)
110
- {
111
- int ret, to_arm = NFILES, i, off;
112
-
113
- off = 0;
114
- while (to_arm) {
115
- int this_arm;
116
-
117
- this_arm = to_arm;
118
- if (this_arm > RING_SIZE)
119
- this_arm = RING_SIZE;
120
-
121
- for (i = 0; i < this_arm; i++) {
122
- if (arm_poll(ring, off)) {
123
- fprintf(stderr, "arm failed at %d\n", off);
124
- return 1;
125
- }
126
- off++;
127
- }
128
-
129
- ret = io_uring_submit(ring);
130
- if (ret != this_arm) {
131
- fprintf(stderr, "submitted %d, %d\n", ret, this_arm);
132
- return 1;
133
- }
134
- to_arm -= this_arm;
135
- }
136
-
137
- return 0;
138
- }
139
-
140
- int main(int argc, char *argv[])
141
- {
142
- struct io_uring ring;
143
- struct io_uring_params params = { };
144
- struct rlimit rlim;
145
- int i, ret;
146
-
147
- if (argc > 1)
148
- return 0;
149
-
150
- if (getrlimit(RLIMIT_NOFILE, &rlim) < 0) {
151
- perror("getrlimit");
152
- goto err_noring;
153
- }
154
-
155
- if (rlim.rlim_cur < (2 * NFILES + 5)) {
156
- rlim.rlim_cur = (2 * NFILES + 5);
157
- rlim.rlim_max = rlim.rlim_cur;
158
- if (setrlimit(RLIMIT_NOFILE, &rlim) < 0) {
159
- if (errno == EPERM)
160
- goto err_nofail;
161
- perror("setrlimit");
162
- goto err_noring;
163
- }
164
- }
165
-
166
- for (i = 0; i < NFILES; i++) {
167
- if (pipe(p[i].fd) < 0) {
168
- perror("pipe");
169
- goto err_noring;
170
- }
171
- }
172
-
173
- params.flags = IORING_SETUP_CQSIZE;
174
- params.cq_entries = 4096;
175
- ret = io_uring_queue_init_params(RING_SIZE, &ring, &params);
176
- if (ret) {
177
- if (ret == -EINVAL) {
178
- fprintf(stdout, "No CQSIZE, trying without\n");
179
- ret = io_uring_queue_init(RING_SIZE, &ring, 0);
180
- if (ret) {
181
- fprintf(stderr, "ring setup failed: %d\n", ret);
182
- return 1;
183
- }
184
- }
185
- }
186
-
187
- if (arm_polls(&ring))
188
- goto err;
189
-
190
- for (i = 0; i < NLOOPS; i++) {
191
- trigger_polls();
192
- ret = reap_polls(&ring);
193
- if (ret)
194
- goto err;
195
- }
196
-
197
- io_uring_queue_exit(&ring);
198
- return 0;
199
- err:
200
- io_uring_queue_exit(&ring);
201
- err_noring:
202
- fprintf(stderr, "poll-many failed\n");
203
- return 1;
204
- err_nofail:
205
- fprintf(stderr, "poll-many: not enough files available (and not root), "
206
- "skipped\n");
207
- return 0;
208
- }
@@ -1,273 +0,0 @@
1
- /* SPDX-License-Identifier: MIT */
2
- /*
3
- * Description: test many files being polled for and updated
4
- *
5
- */
6
- #include <errno.h>
7
- #include <stdio.h>
8
- #include <unistd.h>
9
- #include <stdlib.h>
10
- #include <string.h>
11
- #include <signal.h>
12
- #include <sys/poll.h>
13
- #include <sys/resource.h>
14
- #include <fcntl.h>
15
- #include <pthread.h>
16
-
17
- #include "liburing.h"
18
-
19
- #define NFILES 5000
20
- #define BATCH 500
21
- #define NLOOPS 1000
22
-
23
- #define RING_SIZE 512
24
-
25
- struct p {
26
- int fd[2];
27
- int triggered;
28
- };
29
-
30
- static struct p p[NFILES];
31
-
32
- static int has_poll_update(void)
33
- {
34
- struct io_uring ring;
35
- struct io_uring_cqe *cqe;
36
- struct io_uring_sqe *sqe;
37
- bool has_update = false;
38
- int ret;
39
-
40
- ret = io_uring_queue_init(8, &ring, 0);
41
- if (ret)
42
- return -1;
43
-
44
- sqe = io_uring_get_sqe(&ring);
45
- io_uring_prep_poll_update(sqe, NULL, NULL, POLLIN, IORING_TIMEOUT_UPDATE);
46
-
47
- ret = io_uring_submit(&ring);
48
- if (ret != 1)
49
- return -1;
50
-
51
- ret = io_uring_wait_cqe(&ring, &cqe);
52
- if (!ret) {
53
- if (cqe->res == -ENOENT)
54
- has_update = true;
55
- else if (cqe->res != -EINVAL)
56
- return -1;
57
- io_uring_cqe_seen(&ring, cqe);
58
- }
59
- io_uring_queue_exit(&ring);
60
- return has_update;
61
- }
62
-
63
- static int arm_poll(struct io_uring *ring, int off)
64
- {
65
- struct io_uring_sqe *sqe;
66
-
67
- sqe = io_uring_get_sqe(ring);
68
- if (!sqe) {
69
- fprintf(stderr, "failed getting sqe\n");
70
- return 1;
71
- }
72
-
73
- io_uring_prep_poll_multishot(sqe, p[off].fd[0], POLLIN);
74
- sqe->user_data = off;
75
- return 0;
76
- }
77
-
78
- static int reap_polls(struct io_uring *ring)
79
- {
80
- struct io_uring_cqe *cqe;
81
- int i, ret, off;
82
- char c;
83
-
84
- for (i = 0; i < BATCH; i++) {
85
- struct io_uring_sqe *sqe;
86
-
87
- sqe = io_uring_get_sqe(ring);
88
- /* update event */
89
- io_uring_prep_poll_update(sqe, (void *)(unsigned long)i, NULL,
90
- POLLIN, IORING_POLL_UPDATE_EVENTS);
91
- sqe->user_data = 0x12345678;
92
- }
93
-
94
- ret = io_uring_submit(ring);
95
- if (ret != BATCH) {
96
- fprintf(stderr, "submitted %d, %d\n", ret, BATCH);
97
- return 1;
98
- }
99
-
100
- for (i = 0; i < 2 * BATCH; i++) {
101
- ret = io_uring_wait_cqe(ring, &cqe);
102
- if (ret) {
103
- fprintf(stderr, "wait cqe %d\n", ret);
104
- return ret;
105
- }
106
- off = cqe->user_data;
107
- if (off == 0x12345678)
108
- goto seen;
109
- ret = read(p[off].fd[0], &c, 1);
110
- if (ret != 1) {
111
- if (ret == -1 && errno == EAGAIN)
112
- goto seen;
113
- fprintf(stderr, "read got %d/%d\n", ret, errno);
114
- break;
115
- }
116
- seen:
117
- io_uring_cqe_seen(ring, cqe);
118
- }
119
-
120
- if (i != 2 * BATCH) {
121
- fprintf(stderr, "gave up at %d\n", i);
122
- return 1;
123
- }
124
-
125
- return 0;
126
- }
127
-
128
- static int trigger_polls(void)
129
- {
130
- char c = 89;
131
- int i, ret;
132
-
133
- for (i = 0; i < BATCH; i++) {
134
- int off;
135
-
136
- do {
137
- off = rand() % NFILES;
138
- if (!p[off].triggered)
139
- break;
140
- } while (1);
141
-
142
- p[off].triggered = 1;
143
- ret = write(p[off].fd[1], &c, 1);
144
- if (ret != 1) {
145
- fprintf(stderr, "write got %d/%d\n", ret, errno);
146
- return 1;
147
- }
148
- }
149
-
150
- return 0;
151
- }
152
-
153
- static void *trigger_polls_fn(void *data)
154
- {
155
- trigger_polls();
156
- return NULL;
157
- }
158
-
159
- static int arm_polls(struct io_uring *ring)
160
- {
161
- int ret, to_arm = NFILES, i, off;
162
-
163
- off = 0;
164
- while (to_arm) {
165
- int this_arm;
166
-
167
- this_arm = to_arm;
168
- if (this_arm > RING_SIZE)
169
- this_arm = RING_SIZE;
170
-
171
- for (i = 0; i < this_arm; i++) {
172
- if (arm_poll(ring, off)) {
173
- fprintf(stderr, "arm failed at %d\n", off);
174
- return 1;
175
- }
176
- off++;
177
- }
178
-
179
- ret = io_uring_submit(ring);
180
- if (ret != this_arm) {
181
- fprintf(stderr, "submitted %d, %d\n", ret, this_arm);
182
- return 1;
183
- }
184
- to_arm -= this_arm;
185
- }
186
-
187
- return 0;
188
- }
189
-
190
- int main(int argc, char *argv[])
191
- {
192
- struct io_uring ring;
193
- struct io_uring_params params = { };
194
- struct rlimit rlim;
195
- pthread_t thread;
196
- int i, j, ret;
197
-
198
- if (argc > 1)
199
- return 0;
200
-
201
- ret = has_poll_update();
202
- if (ret < 0) {
203
- fprintf(stderr, "poll update check failed %i\n", ret);
204
- return -1;
205
- } else if (!ret) {
206
- fprintf(stderr, "no poll update, skip\n");
207
- return 0;
208
- }
209
-
210
- if (getrlimit(RLIMIT_NOFILE, &rlim) < 0) {
211
- perror("getrlimit");
212
- goto err_noring;
213
- }
214
-
215
- if (rlim.rlim_cur < (2 * NFILES + 5)) {
216
- rlim.rlim_cur = (2 * NFILES + 5);
217
- rlim.rlim_max = rlim.rlim_cur;
218
- if (setrlimit(RLIMIT_NOFILE, &rlim) < 0) {
219
- if (errno == EPERM)
220
- goto err_nofail;
221
- perror("setrlimit");
222
- goto err_noring;
223
- }
224
- }
225
-
226
- for (i = 0; i < NFILES; i++) {
227
- if (pipe(p[i].fd) < 0) {
228
- perror("pipe");
229
- goto err_noring;
230
- }
231
- fcntl(p[i].fd[0], F_SETFL, O_NONBLOCK);
232
- }
233
-
234
- params.flags = IORING_SETUP_CQSIZE;
235
- params.cq_entries = 4096;
236
- ret = io_uring_queue_init_params(RING_SIZE, &ring, &params);
237
- if (ret) {
238
- if (ret == -EINVAL) {
239
- fprintf(stdout, "No CQSIZE, trying without\n");
240
- ret = io_uring_queue_init(RING_SIZE, &ring, 0);
241
- if (ret) {
242
- fprintf(stderr, "ring setup failed: %d\n", ret);
243
- return 1;
244
- }
245
- }
246
- }
247
-
248
- if (arm_polls(&ring))
249
- goto err;
250
-
251
- for (i = 0; i < NLOOPS; i++) {
252
- pthread_create(&thread, NULL, trigger_polls_fn, NULL);
253
- ret = reap_polls(&ring);
254
- if (ret)
255
- goto err;
256
- pthread_join(thread, NULL);
257
-
258
- for (j = 0; j < NFILES; j++)
259
- p[j].triggered = 0;
260
- }
261
-
262
- io_uring_queue_exit(&ring);
263
- return 0;
264
- err:
265
- io_uring_queue_exit(&ring);
266
- err_noring:
267
- fprintf(stderr, "poll-many failed\n");
268
- return 1;
269
- err_nofail:
270
- fprintf(stderr, "poll-many: not enough files available (and not root), "
271
- "skipped\n");
272
- return 0;
273
- }