@nxtedition/rocksdb 5.2.21 → 5.2.28
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.
- package/binding.cc +510 -967
- package/binding.gyp +78 -72
- package/chained-batch.js +1 -2
- package/deps/rocksdb/build_version.cc +70 -4
- package/deps/rocksdb/rocksdb/CMakeLists.txt +281 -149
- package/deps/rocksdb/rocksdb/Makefile +459 -469
- package/deps/rocksdb/rocksdb/TARGETS +5244 -1500
- package/deps/rocksdb/rocksdb/cache/cache.cc +12 -3
- package/deps/rocksdb/rocksdb/cache/cache_bench.cc +7 -368
- package/deps/rocksdb/rocksdb/cache/cache_bench_tool.cc +924 -0
- package/deps/rocksdb/rocksdb/cache/cache_entry_roles.cc +128 -0
- package/deps/rocksdb/rocksdb/cache/cache_entry_roles.h +103 -0
- package/deps/rocksdb/rocksdb/cache/cache_entry_stats.h +183 -0
- package/deps/rocksdb/rocksdb/cache/cache_helpers.h +11 -0
- package/deps/rocksdb/rocksdb/cache/cache_key.cc +344 -0
- package/deps/rocksdb/rocksdb/cache/cache_key.h +132 -0
- package/deps/rocksdb/rocksdb/cache/cache_reservation_manager.cc +183 -0
- package/deps/rocksdb/rocksdb/cache/cache_reservation_manager.h +288 -0
- package/deps/rocksdb/rocksdb/cache/cache_reservation_manager_test.cc +468 -0
- package/deps/rocksdb/rocksdb/cache/cache_test.cc +85 -8
- package/deps/rocksdb/rocksdb/cache/clock_cache.cc +121 -51
- package/deps/rocksdb/rocksdb/cache/compressed_secondary_cache.cc +171 -0
- package/deps/rocksdb/rocksdb/cache/compressed_secondary_cache.h +86 -0
- package/deps/rocksdb/rocksdb/cache/compressed_secondary_cache_test.cc +607 -0
- package/deps/rocksdb/rocksdb/cache/lru_cache.cc +381 -154
- package/deps/rocksdb/rocksdb/cache/lru_cache.h +176 -33
- package/deps/rocksdb/rocksdb/cache/lru_cache_test.cc +1659 -3
- package/deps/rocksdb/rocksdb/cache/sharded_cache.cc +94 -23
- package/deps/rocksdb/rocksdb/cache/sharded_cache.h +49 -28
- package/deps/rocksdb/rocksdb/cmake/modules/CxxFlags.cmake +7 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindJeMalloc.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindNUMA.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindSnappy.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindTBB.cmake +33 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findgflags.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findlz4.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Finduring.cmake +26 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findzstd.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/ReadVersion.cmake +10 -0
- package/deps/rocksdb/rocksdb/crash_test.mk +93 -0
- package/deps/rocksdb/rocksdb/db/arena_wrapped_db_iter.cc +54 -31
- package/deps/rocksdb/rocksdb/db/arena_wrapped_db_iter.h +10 -6
- package/deps/rocksdb/rocksdb/db/blob/blob_counting_iterator.h +146 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_counting_iterator_test.cc +326 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_fetcher.cc +34 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_fetcher.h +37 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_file_addition.cc +4 -2
- package/deps/rocksdb/rocksdb/db/blob/blob_file_addition_test.cc +8 -4
- package/deps/rocksdb/rocksdb/db/blob/blob_file_builder.cc +99 -40
- package/deps/rocksdb/rocksdb/db/blob/blob_file_builder.h +20 -8
- package/deps/rocksdb/rocksdb/db/blob/blob_file_builder_test.cc +95 -83
- package/deps/rocksdb/rocksdb/db/blob/blob_file_cache.cc +13 -10
- package/deps/rocksdb/rocksdb/db/blob/blob_file_cache.h +7 -4
- package/deps/rocksdb/rocksdb/db/blob/blob_file_cache_test.cc +37 -37
- package/deps/rocksdb/rocksdb/db/blob/blob_file_completion_callback.h +101 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_file_meta.cc +8 -1
- package/deps/rocksdb/rocksdb/db/blob/blob_file_meta.h +6 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_file_reader.cc +209 -44
- package/deps/rocksdb/rocksdb/db/blob/blob_file_reader.h +37 -11
- package/deps/rocksdb/rocksdb/db/blob/blob_file_reader_test.cc +382 -179
- package/deps/rocksdb/rocksdb/db/blob/blob_garbage_meter.cc +100 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_garbage_meter.h +102 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_garbage_meter_test.cc +196 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_index.h +3 -0
- package/deps/rocksdb/rocksdb/db/blob/blob_log_format.h +2 -1
- package/deps/rocksdb/rocksdb/db/blob/blob_log_sequential_reader.cc +7 -5
- package/deps/rocksdb/rocksdb/db/blob/blob_log_sequential_reader.h +10 -3
- package/deps/rocksdb/rocksdb/db/blob/blob_log_writer.cc +12 -8
- package/deps/rocksdb/rocksdb/db/blob/blob_log_writer.h +5 -5
- package/deps/rocksdb/rocksdb/db/blob/db_blob_basic_test.cc +772 -9
- package/deps/rocksdb/rocksdb/db/blob/db_blob_compaction_test.cc +730 -0
- package/deps/rocksdb/rocksdb/db/blob/db_blob_corruption_test.cc +82 -0
- package/deps/rocksdb/rocksdb/db/blob/db_blob_index_test.cc +155 -17
- package/deps/rocksdb/rocksdb/db/blob/prefetch_buffer_collection.cc +21 -0
- package/deps/rocksdb/rocksdb/db/blob/prefetch_buffer_collection.h +38 -0
- package/deps/rocksdb/rocksdb/db/builder.cc +137 -89
- package/deps/rocksdb/rocksdb/db/builder.h +16 -37
- package/deps/rocksdb/rocksdb/db/c.cc +413 -208
- package/deps/rocksdb/rocksdb/db/c_test.c +227 -138
- package/deps/rocksdb/rocksdb/db/column_family.cc +118 -103
- package/deps/rocksdb/rocksdb/db/column_family.h +86 -44
- package/deps/rocksdb/rocksdb/db/column_family_test.cc +38 -24
- package/deps/rocksdb/rocksdb/db/compact_files_test.cc +81 -0
- package/deps/rocksdb/rocksdb/db/compaction/clipping_iterator.h +275 -0
- package/deps/rocksdb/rocksdb/db/compaction/clipping_iterator_test.cc +258 -0
- package/deps/rocksdb/rocksdb/db/compaction/compaction.cc +81 -28
- package/deps/rocksdb/rocksdb/db/compaction/compaction.h +43 -12
- package/deps/rocksdb/rocksdb/db/compaction/compaction_iteration_stats.h +12 -0
- package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.cc +406 -215
- package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.h +147 -50
- package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator_test.cc +167 -61
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job.cc +1321 -156
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job.h +197 -28
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job_stats_test.cc +2 -3
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job_test.cc +246 -43
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker.cc +65 -26
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker.h +7 -7
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_fifo.cc +122 -9
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_fifo.h +8 -2
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.cc +18 -6
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.h +1 -1
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_test.cc +536 -44
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_universal.cc +311 -30
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_universal.h +1 -1
- package/deps/rocksdb/rocksdb/db/compaction/compaction_service_test.cc +849 -0
- package/deps/rocksdb/rocksdb/db/compaction/file_pri.h +92 -0
- package/deps/rocksdb/rocksdb/db/compaction/sst_partitioner.cc +46 -0
- package/deps/rocksdb/rocksdb/db/comparator_db_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/convenience.cc +6 -3
- package/deps/rocksdb/rocksdb/db/corruption_test.cc +383 -28
- package/deps/rocksdb/rocksdb/db/cuckoo_table_db_test.cc +7 -2
- package/deps/rocksdb/rocksdb/db/db_basic_test.cc +154 -45
- package/deps/rocksdb/rocksdb/db/db_block_cache_test.cc +1095 -33
- package/deps/rocksdb/rocksdb/db/db_bloom_filter_test.cc +1249 -203
- package/deps/rocksdb/rocksdb/db/db_compaction_filter_test.cc +135 -9
- package/deps/rocksdb/rocksdb/db/db_compaction_test.cc +1348 -166
- package/deps/rocksdb/rocksdb/db/db_dynamic_level_test.cc +3 -5
- package/deps/rocksdb/rocksdb/db/db_encryption_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/db_filesnapshot.cc +312 -45
- package/deps/rocksdb/rocksdb/db/db_flush_test.cc +1734 -48
- package/deps/rocksdb/rocksdb/db/{compacted_db_impl.cc → db_impl/compacted_db_impl.cc} +24 -7
- package/deps/rocksdb/rocksdb/db/{compacted_db_impl.h → db_impl/compacted_db_impl.h} +1 -1
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl.cc +644 -333
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl.h +365 -92
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_compaction_flush.cc +578 -210
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_debug.cc +38 -16
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_experimental.cc +17 -10
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_files.cc +75 -74
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_open.cc +450 -183
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.cc +42 -9
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.cc +232 -15
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.h +42 -4
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_write.cc +297 -100
- package/deps/rocksdb/rocksdb/db/db_info_dumper.cc +16 -15
- package/deps/rocksdb/rocksdb/db/db_inplace_update_test.cc +31 -1
- package/deps/rocksdb/rocksdb/db/db_io_failure_test.cc +6 -5
- package/deps/rocksdb/rocksdb/db/db_iter.cc +218 -153
- package/deps/rocksdb/rocksdb/db/db_iter.h +14 -12
- package/deps/rocksdb/rocksdb/db/db_iter_stress_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/db_iter_test.cc +84 -160
- package/deps/rocksdb/rocksdb/db/db_iterator_test.cc +47 -6
- package/deps/rocksdb/rocksdb/db/db_kv_checksum_test.cc +204 -0
- package/deps/rocksdb/rocksdb/db/db_log_iter_test.cc +21 -13
- package/deps/rocksdb/rocksdb/db/db_logical_block_size_cache_test.cc +17 -10
- package/deps/rocksdb/rocksdb/db/db_memtable_test.cc +38 -24
- package/deps/rocksdb/rocksdb/db/db_merge_operand_test.cc +184 -19
- package/deps/rocksdb/rocksdb/db/db_merge_operator_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/db_options_test.cc +183 -3
- package/deps/rocksdb/rocksdb/db/db_properties_test.cc +409 -9
- package/deps/rocksdb/rocksdb/db/db_range_del_test.cc +92 -23
- package/deps/rocksdb/rocksdb/db/db_rate_limiter_test.cc +446 -0
- package/deps/rocksdb/rocksdb/db/{db_impl/db_secondary_test.cc → db_secondary_test.cc} +363 -35
- package/deps/rocksdb/rocksdb/db/db_sst_test.cc +520 -15
- package/deps/rocksdb/rocksdb/db/db_statistics_test.cc +50 -1
- package/deps/rocksdb/rocksdb/db/db_table_properties_test.cc +139 -4
- package/deps/rocksdb/rocksdb/db/db_tailing_iter_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/db_test.cc +669 -359
- package/deps/rocksdb/rocksdb/db/db_test2.cc +2110 -304
- package/deps/rocksdb/rocksdb/db/db_test_util.cc +76 -43
- package/deps/rocksdb/rocksdb/db/db_test_util.h +231 -103
- package/deps/rocksdb/rocksdb/db/db_universal_compaction_test.cc +19 -11
- package/deps/rocksdb/rocksdb/db/db_wal_test.cc +490 -71
- package/deps/rocksdb/rocksdb/db/db_with_timestamp_basic_test.cc +980 -349
- package/deps/rocksdb/rocksdb/db/db_with_timestamp_compaction_test.cc +11 -12
- package/deps/rocksdb/rocksdb/db/db_write_buffer_manager_test.cc +793 -0
- package/deps/rocksdb/rocksdb/db/db_write_test.cc +2 -1
- package/deps/rocksdb/rocksdb/db/dbformat.cc +4 -12
- package/deps/rocksdb/rocksdb/db/dbformat.h +28 -18
- package/deps/rocksdb/rocksdb/db/dbformat_test.cc +3 -0
- package/deps/rocksdb/rocksdb/db/deletefile_test.cc +50 -15
- package/deps/rocksdb/rocksdb/db/error_handler.cc +127 -41
- package/deps/rocksdb/rocksdb/db/error_handler.h +12 -5
- package/deps/rocksdb/rocksdb/db/error_handler_fs_test.cc +524 -255
- package/deps/rocksdb/rocksdb/db/event_helpers.cc +136 -11
- package/deps/rocksdb/rocksdb/db/event_helpers.h +27 -2
- package/deps/rocksdb/rocksdb/db/experimental.cc +100 -0
- package/deps/rocksdb/rocksdb/db/external_sst_file_basic_test.cc +307 -4
- package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.cc +137 -60
- package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.h +12 -8
- package/deps/rocksdb/rocksdb/db/external_sst_file_test.cc +86 -55
- package/deps/rocksdb/rocksdb/db/fault_injection_test.cc +86 -5
- package/deps/rocksdb/rocksdb/db/filename_test.cc +63 -0
- package/deps/rocksdb/rocksdb/db/flush_job.cc +619 -64
- package/deps/rocksdb/rocksdb/db/flush_job.h +30 -7
- package/deps/rocksdb/rocksdb/db/flush_job_test.cc +33 -16
- package/deps/rocksdb/rocksdb/db/flush_scheduler.h +2 -1
- package/deps/rocksdb/rocksdb/db/forward_iterator.cc +18 -17
- package/deps/rocksdb/rocksdb/db/forward_iterator.h +5 -4
- package/deps/rocksdb/rocksdb/db/forward_iterator_bench.cc +0 -1
- package/deps/rocksdb/rocksdb/db/history_trimming_iterator.h +91 -0
- package/deps/rocksdb/rocksdb/db/import_column_family_job.cc +25 -14
- package/deps/rocksdb/rocksdb/db/import_column_family_job.h +6 -5
- package/deps/rocksdb/rocksdb/db/import_column_family_test.cc +1 -1
- package/deps/rocksdb/rocksdb/db/internal_stats.cc +471 -50
- package/deps/rocksdb/rocksdb/db/internal_stats.h +129 -25
- package/deps/rocksdb/rocksdb/db/job_context.h +22 -9
- package/deps/rocksdb/rocksdb/db/kv_checksum.h +394 -0
- package/deps/rocksdb/rocksdb/db/listener_test.cc +518 -41
- package/deps/rocksdb/rocksdb/db/log_format.h +4 -1
- package/deps/rocksdb/rocksdb/db/log_reader.cc +129 -6
- package/deps/rocksdb/rocksdb/db/log_reader.h +17 -1
- package/deps/rocksdb/rocksdb/db/log_test.cc +161 -11
- package/deps/rocksdb/rocksdb/db/log_writer.cc +92 -13
- package/deps/rocksdb/rocksdb/db/log_writer.h +18 -5
- package/deps/rocksdb/rocksdb/db/logs_with_prep_tracker.h +1 -1
- package/deps/rocksdb/rocksdb/db/lookup_key.h +0 -1
- package/deps/rocksdb/rocksdb/db/malloc_stats.cc +2 -2
- package/deps/rocksdb/rocksdb/db/manual_compaction_test.cc +21 -8
- package/deps/rocksdb/rocksdb/db/memtable.cc +144 -54
- package/deps/rocksdb/rocksdb/db/memtable.h +72 -15
- package/deps/rocksdb/rocksdb/db/memtable_list.cc +95 -47
- package/deps/rocksdb/rocksdb/db/memtable_list.h +33 -13
- package/deps/rocksdb/rocksdb/db/memtable_list_test.cc +61 -31
- package/deps/rocksdb/rocksdb/db/merge_context.h +20 -8
- package/deps/rocksdb/rocksdb/db/merge_helper.cc +54 -11
- package/deps/rocksdb/rocksdb/db/merge_helper.h +17 -6
- package/deps/rocksdb/rocksdb/db/merge_helper_test.cc +13 -7
- package/deps/rocksdb/rocksdb/db/merge_test.cc +40 -19
- package/deps/rocksdb/rocksdb/db/obsolete_files_test.cc +14 -25
- package/deps/rocksdb/rocksdb/db/output_validator.cc +3 -0
- package/deps/rocksdb/rocksdb/db/output_validator.h +5 -4
- package/deps/rocksdb/rocksdb/db/perf_context_test.cc +32 -28
- package/deps/rocksdb/rocksdb/db/periodic_work_scheduler.cc +43 -29
- package/deps/rocksdb/rocksdb/db/periodic_work_scheduler.h +9 -7
- package/deps/rocksdb/rocksdb/db/periodic_work_scheduler_test.cc +21 -16
- package/deps/rocksdb/rocksdb/db/pinned_iterators_manager.h +1 -1
- package/deps/rocksdb/rocksdb/db/plain_table_db_test.cc +29 -36
- package/deps/rocksdb/rocksdb/db/pre_release_callback.h +1 -2
- package/deps/rocksdb/rocksdb/db/prefix_test.cc +4 -4
- package/deps/rocksdb/rocksdb/db/range_del_aggregator.h +2 -2
- package/deps/rocksdb/rocksdb/db/range_del_aggregator_bench.cc +11 -11
- package/deps/rocksdb/rocksdb/db/range_del_aggregator_test.cc +3 -2
- package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter.cc +14 -8
- package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter.h +17 -0
- package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter_test.cc +4 -2
- package/deps/rocksdb/rocksdb/db/read_callback.h +1 -0
- package/deps/rocksdb/rocksdb/db/repair.cc +87 -58
- package/deps/rocksdb/rocksdb/db/repair_test.cc +35 -5
- package/deps/rocksdb/rocksdb/db/snapshot_impl.h +2 -1
- package/deps/rocksdb/rocksdb/db/table_cache.cc +95 -69
- package/deps/rocksdb/rocksdb/db/table_cache.h +63 -53
- package/deps/rocksdb/rocksdb/db/table_properties_collector.cc +4 -4
- package/deps/rocksdb/rocksdb/db/table_properties_collector.h +78 -10
- package/deps/rocksdb/rocksdb/db/table_properties_collector_test.cc +28 -33
- package/deps/rocksdb/rocksdb/db/transaction_log_impl.cc +30 -51
- package/deps/rocksdb/rocksdb/db/transaction_log_impl.h +12 -8
- package/deps/rocksdb/rocksdb/db/version_builder.cc +564 -341
- package/deps/rocksdb/rocksdb/db/version_builder.h +8 -8
- package/deps/rocksdb/rocksdb/db/version_builder_test.cc +327 -155
- package/deps/rocksdb/rocksdb/db/version_edit.cc +89 -27
- package/deps/rocksdb/rocksdb/db/version_edit.h +42 -17
- package/deps/rocksdb/rocksdb/db/version_edit_handler.cc +324 -43
- package/deps/rocksdb/rocksdb/db/version_edit_handler.h +79 -22
- package/deps/rocksdb/rocksdb/db/version_edit_test.cc +165 -20
- package/deps/rocksdb/rocksdb/db/version_set.cc +935 -1034
- package/deps/rocksdb/rocksdb/db/version_set.h +183 -122
- package/deps/rocksdb/rocksdb/db/version_set_test.cc +556 -138
- package/deps/rocksdb/rocksdb/db/version_util.h +68 -0
- package/deps/rocksdb/rocksdb/db/wal_manager.cc +23 -21
- package/deps/rocksdb/rocksdb/db/wal_manager.h +5 -2
- package/deps/rocksdb/rocksdb/db/wal_manager_test.cc +30 -27
- package/deps/rocksdb/rocksdb/db/write_batch.cc +704 -209
- package/deps/rocksdb/rocksdb/db/write_batch_internal.h +135 -2
- package/deps/rocksdb/rocksdb/db/write_batch_test.cc +209 -5
- package/deps/rocksdb/rocksdb/db/write_callback_test.cc +2 -0
- package/deps/rocksdb/rocksdb/db/write_controller.cc +47 -54
- package/deps/rocksdb/rocksdb/db/write_controller.h +12 -9
- package/deps/rocksdb/rocksdb/db/write_controller_test.cc +215 -103
- package/deps/rocksdb/rocksdb/db/write_thread.cc +11 -0
- package/deps/rocksdb/rocksdb/db/write_thread.h +14 -8
- package/deps/rocksdb/rocksdb/db_stress_tool/CMakeLists.txt +7 -4
- package/deps/rocksdb/rocksdb/db_stress_tool/batched_ops_stress.cc +10 -3
- package/deps/rocksdb/rocksdb/db_stress_tool/cf_consistency_stress.cc +6 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress.cc +1 -1
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.cc +19 -2
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.h +78 -25
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_compaction_filter.h +13 -2
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_driver.cc +29 -12
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_env_wrapper.h +5 -1
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_gflags.cc +199 -32
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_listener.cc +188 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_listener.h +59 -10
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_shared_state.h +77 -109
- package/deps/rocksdb/rocksdb/{third-party/folly/folly/synchronization/WaitOptions.cpp → db_stress_tool/db_stress_stat.cc} +9 -4
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_stat.h +7 -6
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_table_properties_collector.h +1 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.cc +699 -143
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.h +20 -2
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_tool.cc +49 -39
- package/deps/rocksdb/rocksdb/db_stress_tool/expected_state.cc +631 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/expected_state.h +287 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/multi_ops_txns_stress.cc +1565 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/multi_ops_txns_stress.h +374 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/no_batched_ops_stress.cc +149 -18
- package/deps/rocksdb/rocksdb/env/composite_env.cc +464 -0
- package/deps/rocksdb/rocksdb/env/composite_env_wrapper.h +98 -646
- package/deps/rocksdb/rocksdb/env/emulated_clock.h +114 -0
- package/deps/rocksdb/rocksdb/env/env.cc +632 -42
- package/deps/rocksdb/rocksdb/env/env_basic_test.cc +84 -36
- package/deps/rocksdb/rocksdb/env/env_chroot.cc +88 -286
- package/deps/rocksdb/rocksdb/env/env_chroot.h +34 -1
- package/deps/rocksdb/rocksdb/env/env_encryption.cc +469 -277
- package/deps/rocksdb/rocksdb/env/env_encryption_ctr.h +9 -30
- package/deps/rocksdb/rocksdb/env/env_posix.cc +110 -119
- package/deps/rocksdb/rocksdb/env/env_test.cc +1128 -39
- package/deps/rocksdb/rocksdb/env/file_system.cc +147 -8
- package/deps/rocksdb/rocksdb/env/file_system_tracer.cc +207 -136
- package/deps/rocksdb/rocksdb/env/file_system_tracer.h +86 -54
- package/deps/rocksdb/rocksdb/env/fs_posix.cc +192 -64
- package/deps/rocksdb/rocksdb/env/fs_readonly.h +107 -0
- package/deps/rocksdb/rocksdb/env/fs_remap.cc +339 -0
- package/deps/rocksdb/rocksdb/env/fs_remap.h +139 -0
- package/deps/rocksdb/rocksdb/env/io_posix.cc +245 -41
- package/deps/rocksdb/rocksdb/env/io_posix.h +66 -1
- package/deps/rocksdb/rocksdb/env/mock_env.cc +147 -149
- package/deps/rocksdb/rocksdb/env/mock_env.h +113 -11
- package/deps/rocksdb/rocksdb/env/mock_env_test.cc +2 -4
- package/deps/rocksdb/rocksdb/env/unique_id_gen.cc +164 -0
- package/deps/rocksdb/rocksdb/env/unique_id_gen.h +71 -0
- package/deps/rocksdb/rocksdb/file/delete_scheduler.cc +9 -5
- package/deps/rocksdb/rocksdb/file/delete_scheduler.h +6 -4
- package/deps/rocksdb/rocksdb/file/delete_scheduler_test.cc +19 -12
- package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.cc +459 -70
- package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.h +205 -28
- package/deps/rocksdb/rocksdb/file/file_util.cc +39 -28
- package/deps/rocksdb/rocksdb/file/file_util.h +18 -27
- package/deps/rocksdb/rocksdb/file/filename.cc +59 -22
- package/deps/rocksdb/rocksdb/file/filename.h +13 -8
- package/deps/rocksdb/rocksdb/file/line_file_reader.cc +68 -0
- package/deps/rocksdb/rocksdb/file/line_file_reader.h +59 -0
- package/deps/rocksdb/rocksdb/file/prefetch_test.cc +1130 -6
- package/deps/rocksdb/rocksdb/file/random_access_file_reader.cc +220 -36
- package/deps/rocksdb/rocksdb/file/random_access_file_reader.h +69 -17
- package/deps/rocksdb/rocksdb/file/random_access_file_reader_test.cc +13 -12
- package/deps/rocksdb/rocksdb/file/read_write_util.cc +3 -38
- package/deps/rocksdb/rocksdb/file/read_write_util.h +0 -4
- package/deps/rocksdb/rocksdb/file/readahead_file_info.h +33 -0
- package/deps/rocksdb/rocksdb/file/sequence_file_reader.cc +57 -9
- package/deps/rocksdb/rocksdb/file/sequence_file_reader.h +58 -6
- package/deps/rocksdb/rocksdb/file/sst_file_manager_impl.cc +29 -54
- package/deps/rocksdb/rocksdb/file/sst_file_manager_impl.h +22 -29
- package/deps/rocksdb/rocksdb/file/writable_file_writer.cc +424 -50
- package/deps/rocksdb/rocksdb/file/writable_file_writer.h +66 -19
- package/deps/rocksdb/rocksdb/include/rocksdb/advanced_options.h +157 -66
- package/deps/rocksdb/rocksdb/include/rocksdb/c.h +224 -121
- package/deps/rocksdb/rocksdb/include/rocksdb/cache.h +333 -30
- package/deps/rocksdb/rocksdb/include/rocksdb/cache_bench_tool.h +14 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/cleanable.h +1 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/compaction_filter.h +90 -50
- package/deps/rocksdb/rocksdb/include/rocksdb/compaction_job_stats.h +13 -5
- package/deps/rocksdb/rocksdb/include/rocksdb/comparator.h +20 -4
- package/deps/rocksdb/rocksdb/include/rocksdb/concurrent_task_limiter.h +8 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/configurable.h +53 -12
- package/deps/rocksdb/rocksdb/include/rocksdb/convenience.h +31 -6
- package/deps/rocksdb/rocksdb/include/rocksdb/customizable.h +102 -7
- package/deps/rocksdb/rocksdb/include/rocksdb/data_structure.h +51 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/db.h +370 -262
- package/deps/rocksdb/rocksdb/include/rocksdb/env.h +286 -87
- package/deps/rocksdb/rocksdb/include/rocksdb/env_encryption.h +124 -64
- package/deps/rocksdb/rocksdb/include/rocksdb/experimental.h +27 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/file_checksum.h +21 -4
- package/deps/rocksdb/rocksdb/include/rocksdb/file_system.h +384 -41
- package/deps/rocksdb/rocksdb/include/rocksdb/filter_policy.h +111 -143
- package/deps/rocksdb/rocksdb/include/rocksdb/flush_block_policy.h +20 -6
- package/deps/rocksdb/rocksdb/include/rocksdb/functor_wrapper.h +56 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/io_status.h +15 -33
- package/deps/rocksdb/rocksdb/include/rocksdb/iostats_context.h +37 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/iterator.h +1 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/listener.h +314 -26
- package/deps/rocksdb/rocksdb/include/rocksdb/memory_allocator.h +11 -7
- package/deps/rocksdb/rocksdb/include/rocksdb/memtablerep.h +50 -15
- package/deps/rocksdb/rocksdb/include/rocksdb/merge_operator.h +10 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/metadata.h +186 -96
- package/deps/rocksdb/rocksdb/include/rocksdb/options.h +373 -103
- package/deps/rocksdb/rocksdb/include/rocksdb/perf_context.h +13 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/persistent_cache.h +2 -2
- package/deps/rocksdb/rocksdb/include/rocksdb/rate_limiter.h +37 -7
- package/deps/rocksdb/rocksdb/include/rocksdb/rocksdb_namespace.h +6 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/secondary_cache.h +87 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/slice.h +5 -12
- package/deps/rocksdb/rocksdb/include/rocksdb/slice_transform.h +59 -30
- package/deps/rocksdb/rocksdb/include/rocksdb/sst_file_manager.h +11 -11
- package/deps/rocksdb/rocksdb/include/rocksdb/sst_file_writer.h +22 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/sst_partitioner.h +17 -10
- package/deps/rocksdb/rocksdb/include/rocksdb/statistics.h +121 -41
- package/deps/rocksdb/rocksdb/include/rocksdb/stats_history.h +1 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/status.h +114 -136
- package/deps/rocksdb/rocksdb/include/rocksdb/system_clock.h +116 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/table.h +160 -18
- package/deps/rocksdb/rocksdb/include/rocksdb/table_properties.h +57 -15
- package/deps/rocksdb/rocksdb/include/rocksdb/thread_status.h +3 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/trace_reader_writer.h +10 -6
- package/deps/rocksdb/rocksdb/include/rocksdb/trace_record.h +247 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/trace_record_result.h +187 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/transaction_log.h +1 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/types.h +14 -24
- package/deps/rocksdb/rocksdb/include/rocksdb/unique_id.h +46 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/universal_compaction.h +14 -4
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/agg_merge.h +138 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/backup_engine.h +631 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/cache_dump_load.h +142 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/checkpoint.h +12 -9
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/customizable_util.h +368 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/ldb_cmd.h +24 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/ldb_cmd_execute_result.h +4 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/object_registry.h +418 -63
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_type.h +143 -73
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_util.h +2 -2
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/replayer.h +87 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/sim_cache.h +2 -2
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/stackable_db.h +43 -5
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/table_properties_collectors.h +18 -23
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction.h +26 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction_db.h +32 -6
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction_db_mutex.h +1 -2
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/write_batch_with_index.h +20 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/version.h +30 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/wal_filter.h +11 -2
- package/deps/rocksdb/rocksdb/include/rocksdb/write_batch.h +89 -11
- package/deps/rocksdb/rocksdb/include/rocksdb/write_batch_base.h +11 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/write_buffer_manager.h +108 -38
- package/deps/rocksdb/rocksdb/logging/auto_roll_logger.cc +40 -23
- package/deps/rocksdb/rocksdb/logging/auto_roll_logger.h +12 -5
- package/deps/rocksdb/rocksdb/logging/auto_roll_logger_test.cc +100 -49
- package/deps/rocksdb/rocksdb/logging/env_logger.h +7 -5
- package/deps/rocksdb/rocksdb/logging/env_logger_test.cc +0 -1
- package/deps/rocksdb/rocksdb/logging/posix_logger.h +3 -9
- package/deps/rocksdb/rocksdb/memory/arena.cc +3 -1
- package/deps/rocksdb/rocksdb/memory/arena.h +1 -1
- package/deps/rocksdb/rocksdb/memory/jemalloc_nodump_allocator.cc +171 -106
- package/deps/rocksdb/rocksdb/memory/jemalloc_nodump_allocator.h +31 -15
- package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator.cc +15 -4
- package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator.h +24 -8
- package/deps/rocksdb/rocksdb/memory/memory_allocator.cc +91 -0
- package/deps/rocksdb/rocksdb/memory/memory_allocator_test.cc +239 -0
- package/deps/rocksdb/rocksdb/memory/memory_usage.h +14 -1
- package/deps/rocksdb/rocksdb/memtable/hash_linklist_rep.cc +72 -9
- package/deps/rocksdb/rocksdb/memtable/hash_skiplist_rep.cc +52 -6
- package/deps/rocksdb/rocksdb/memtable/inlineskiplist.h +53 -0
- package/deps/rocksdb/rocksdb/memtable/inlineskiplist_test.cc +5 -5
- package/deps/rocksdb/rocksdb/memtable/memtablerep_bench.cc +17 -5
- package/deps/rocksdb/rocksdb/memtable/skiplist_test.cc +1 -1
- package/deps/rocksdb/rocksdb/memtable/skiplistrep.cc +87 -0
- package/deps/rocksdb/rocksdb/memtable/vectorrep.cc +20 -10
- package/deps/rocksdb/rocksdb/memtable/write_buffer_manager.cc +148 -94
- package/deps/rocksdb/rocksdb/memtable/write_buffer_manager_test.cc +160 -62
- package/deps/rocksdb/rocksdb/microbench/CMakeLists.txt +17 -0
- package/deps/rocksdb/rocksdb/microbench/db_basic_bench.cc +1360 -0
- package/deps/rocksdb/rocksdb/microbench/ribbon_bench.cc +153 -0
- package/deps/rocksdb/rocksdb/monitoring/histogram.cc +8 -15
- package/deps/rocksdb/rocksdb/monitoring/histogram.h +0 -1
- package/deps/rocksdb/rocksdb/monitoring/histogram_test.cc +18 -16
- package/deps/rocksdb/rocksdb/monitoring/histogram_windowing.cc +9 -7
- package/deps/rocksdb/rocksdb/monitoring/histogram_windowing.h +5 -3
- package/deps/rocksdb/rocksdb/monitoring/instrumented_mutex.cc +7 -5
- package/deps/rocksdb/rocksdb/monitoring/instrumented_mutex.h +37 -12
- package/deps/rocksdb/rocksdb/monitoring/iostats_context.cc +26 -6
- package/deps/rocksdb/rocksdb/monitoring/iostats_context_imp.h +6 -10
- package/deps/rocksdb/rocksdb/monitoring/perf_context.cc +14 -13
- package/deps/rocksdb/rocksdb/monitoring/perf_context_imp.h +19 -20
- package/deps/rocksdb/rocksdb/monitoring/perf_step_timer.h +18 -18
- package/deps/rocksdb/rocksdb/monitoring/statistics.cc +84 -2
- package/deps/rocksdb/rocksdb/monitoring/statistics.h +6 -0
- package/deps/rocksdb/rocksdb/monitoring/statistics_test.cc +47 -2
- package/deps/rocksdb/rocksdb/monitoring/stats_history_test.cc +67 -54
- package/deps/rocksdb/rocksdb/monitoring/thread_status_updater.cc +4 -1
- package/deps/rocksdb/rocksdb/monitoring/thread_status_util.cc +2 -1
- package/deps/rocksdb/rocksdb/monitoring/thread_status_util_debug.cc +2 -2
- package/deps/rocksdb/rocksdb/options/cf_options.cc +280 -212
- package/deps/rocksdb/rocksdb/options/cf_options.h +51 -57
- package/deps/rocksdb/rocksdb/options/configurable.cc +242 -138
- package/deps/rocksdb/rocksdb/options/configurable_helper.h +4 -68
- package/deps/rocksdb/rocksdb/options/configurable_test.cc +144 -21
- package/deps/rocksdb/rocksdb/options/configurable_test.h +2 -3
- package/deps/rocksdb/rocksdb/options/customizable.cc +67 -7
- package/deps/rocksdb/rocksdb/options/customizable_test.cc +1773 -151
- package/deps/rocksdb/rocksdb/options/db_options.cc +275 -47
- package/deps/rocksdb/rocksdb/options/db_options.h +36 -7
- package/deps/rocksdb/rocksdb/options/options.cc +49 -17
- package/deps/rocksdb/rocksdb/options/options_helper.cc +369 -352
- package/deps/rocksdb/rocksdb/options/options_helper.h +23 -23
- package/deps/rocksdb/rocksdb/options/options_parser.cc +18 -13
- package/deps/rocksdb/rocksdb/options/options_settable_test.cc +67 -54
- package/deps/rocksdb/rocksdb/options/options_test.cc +1162 -187
- package/deps/rocksdb/rocksdb/port/jemalloc_helper.h +1 -1
- package/deps/rocksdb/rocksdb/port/lang.h +52 -0
- package/deps/rocksdb/rocksdb/port/port_example.h +1 -1
- package/deps/rocksdb/rocksdb/port/port_posix.cc +31 -2
- package/deps/rocksdb/rocksdb/port/port_posix.h +20 -2
- package/deps/rocksdb/rocksdb/port/stack_trace.cc +20 -4
- package/deps/rocksdb/rocksdb/port/sys_time.h +2 -2
- package/deps/rocksdb/rocksdb/port/win/env_default.cc +7 -7
- package/deps/rocksdb/rocksdb/port/win/env_win.cc +44 -74
- package/deps/rocksdb/rocksdb/port/win/env_win.h +25 -23
- package/deps/rocksdb/rocksdb/port/win/io_win.cc +32 -34
- package/deps/rocksdb/rocksdb/port/win/io_win.h +12 -6
- package/deps/rocksdb/rocksdb/port/win/port_win.cc +55 -35
- package/deps/rocksdb/rocksdb/port/win/port_win.h +22 -5
- package/deps/rocksdb/rocksdb/port/win/win_logger.cc +3 -3
- package/deps/rocksdb/rocksdb/port/win/win_logger.h +3 -5
- package/deps/rocksdb/rocksdb/port/win/win_thread.cc +7 -1
- package/deps/rocksdb/rocksdb/port/win/win_thread.h +12 -17
- package/deps/rocksdb/rocksdb/python.mk +9 -0
- package/deps/rocksdb/rocksdb/src.mk +82 -34
- package/deps/rocksdb/rocksdb/table/adaptive/adaptive_table_factory.cc +3 -4
- package/deps/rocksdb/rocksdb/table/adaptive/adaptive_table_factory.h +1 -1
- package/deps/rocksdb/rocksdb/table/block_based/block.cc +158 -80
- package/deps/rocksdb/rocksdb/table/block_based/block.h +64 -36
- package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.cc +23 -14
- package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.h +13 -5
- package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block_test.cc +3 -218
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.cc +603 -328
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.h +28 -22
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_factory.cc +220 -82
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_factory.h +8 -2
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.cc +3 -4
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.h +28 -4
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.cc +598 -492
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.h +151 -96
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_impl.h +31 -58
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_test.cc +330 -92
- package/deps/rocksdb/rocksdb/table/block_based/block_builder.cc +50 -19
- package/deps/rocksdb/rocksdb/table/block_based/block_builder.h +23 -0
- package/deps/rocksdb/rocksdb/table/block_based/block_like_traits.h +226 -0
- package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.cc +56 -22
- package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.h +42 -4
- package/deps/rocksdb/rocksdb/table/block_based/block_test.cc +5 -2
- package/deps/rocksdb/rocksdb/table/block_based/block_type.h +2 -0
- package/deps/rocksdb/rocksdb/table/block_based/cachable_entry.h +34 -20
- package/deps/rocksdb/rocksdb/table/block_based/data_block_hash_index_test.cc +9 -10
- package/deps/rocksdb/rocksdb/table/block_based/filter_block.h +26 -3
- package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_based/filter_policy.cc +844 -202
- package/deps/rocksdb/rocksdb/table/block_based/filter_policy_internal.h +281 -81
- package/deps/rocksdb/rocksdb/table/block_based/flush_block_policy.cc +62 -2
- package/deps/rocksdb/rocksdb/table/block_based/flush_block_policy.h +2 -3
- package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.cc +28 -7
- package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.h +22 -6
- package/deps/rocksdb/rocksdb/table/block_based/full_filter_block_test.cc +28 -26
- package/deps/rocksdb/rocksdb/table/block_based/hash_index_reader.cc +1 -1
- package/deps/rocksdb/rocksdb/table/block_based/index_builder.cc +1 -2
- package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_based/mock_block_based_table.h +11 -4
- package/deps/rocksdb/rocksdb/table/block_based/parsed_full_filter_block.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_based/parsed_full_filter_block.h +2 -0
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.cc +68 -26
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.h +44 -9
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block_test.cc +12 -10
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.cc +3 -4
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.h +23 -4
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.cc +44 -19
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.h +5 -1
- package/deps/rocksdb/rocksdb/table/block_based/reader_common.cc +16 -28
- package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.cc +7 -4
- package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.h +2 -2
- package/deps/rocksdb/rocksdb/table/block_fetcher.cc +77 -57
- package/deps/rocksdb/rocksdb/table/block_fetcher.h +23 -12
- package/deps/rocksdb/rocksdb/table/block_fetcher_test.cc +43 -56
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.cc +8 -8
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.h +2 -1
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder_test.cc +52 -70
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_factory.cc +5 -8
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_factory.h +1 -1
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader.cc +17 -11
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader.h +2 -3
- package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader_test.cc +42 -51
- package/deps/rocksdb/rocksdb/table/format.cc +258 -104
- package/deps/rocksdb/rocksdb/table/format.h +120 -109
- package/deps/rocksdb/rocksdb/table/get_context.cc +97 -65
- package/deps/rocksdb/rocksdb/table/get_context.h +19 -12
- package/deps/rocksdb/rocksdb/table/internal_iterator.h +14 -0
- package/deps/rocksdb/rocksdb/table/iterator_wrapper.h +8 -0
- package/deps/rocksdb/rocksdb/table/merger_test.cc +3 -2
- package/deps/rocksdb/rocksdb/table/merging_iterator.cc +11 -21
- package/deps/rocksdb/rocksdb/table/merging_iterator.h +3 -3
- package/deps/rocksdb/rocksdb/table/meta_blocks.cc +176 -171
- package/deps/rocksdb/rocksdb/table/meta_blocks.h +47 -33
- package/deps/rocksdb/rocksdb/table/mock_table.cc +7 -9
- package/deps/rocksdb/rocksdb/table/mock_table.h +3 -2
- package/deps/rocksdb/rocksdb/table/multiget_context.h +15 -8
- package/deps/rocksdb/rocksdb/table/persistent_cache_helper.cc +22 -29
- package/deps/rocksdb/rocksdb/table/persistent_cache_options.h +6 -3
- package/deps/rocksdb/rocksdb/table/plain/plain_table_bloom.h +5 -8
- package/deps/rocksdb/rocksdb/table/plain/plain_table_builder.cc +29 -26
- package/deps/rocksdb/rocksdb/table/plain/plain_table_builder.h +12 -16
- package/deps/rocksdb/rocksdb/table/plain/plain_table_factory.cc +145 -69
- package/deps/rocksdb/rocksdb/table/plain/plain_table_factory.h +1 -1
- package/deps/rocksdb/rocksdb/table/plain/plain_table_index.cc +7 -6
- package/deps/rocksdb/rocksdb/table/plain/plain_table_index.h +3 -4
- package/deps/rocksdb/rocksdb/table/plain/plain_table_key_coding.cc +3 -1
- package/deps/rocksdb/rocksdb/table/plain/plain_table_key_coding.h +1 -1
- package/deps/rocksdb/rocksdb/table/plain/plain_table_reader.cc +13 -18
- package/deps/rocksdb/rocksdb/table/plain/plain_table_reader.h +4 -9
- package/deps/rocksdb/rocksdb/table/sst_file_dumper.cc +55 -37
- package/deps/rocksdb/rocksdb/table/sst_file_dumper.h +10 -5
- package/deps/rocksdb/rocksdb/table/sst_file_reader.cc +11 -8
- package/deps/rocksdb/rocksdb/table/sst_file_reader_test.cc +222 -16
- package/deps/rocksdb/rocksdb/table/sst_file_writer.cc +106 -58
- package/deps/rocksdb/rocksdb/table/sst_file_writer_collectors.h +6 -5
- package/deps/rocksdb/rocksdb/table/table_builder.h +68 -44
- package/deps/rocksdb/rocksdb/table/table_factory.cc +37 -10
- package/deps/rocksdb/rocksdb/table/table_properties.cc +109 -54
- package/deps/rocksdb/rocksdb/table/table_properties_internal.h +4 -20
- package/deps/rocksdb/rocksdb/table/table_reader_bench.cc +33 -32
- package/deps/rocksdb/rocksdb/table/table_reader_caller.h +2 -0
- package/deps/rocksdb/rocksdb/table/table_test.cc +989 -326
- package/deps/rocksdb/rocksdb/table/two_level_iterator.cc +4 -0
- package/deps/rocksdb/rocksdb/table/unique_id.cc +166 -0
- package/deps/rocksdb/rocksdb/table/unique_id_impl.h +59 -0
- package/deps/rocksdb/rocksdb/test_util/mock_time_env.cc +1 -1
- package/deps/rocksdb/rocksdb/test_util/mock_time_env.h +13 -10
- package/deps/rocksdb/rocksdb/test_util/sync_point.cc +1 -2
- package/deps/rocksdb/rocksdb/test_util/sync_point.h +35 -16
- package/deps/rocksdb/rocksdb/test_util/sync_point_impl.cc +32 -10
- package/deps/rocksdb/rocksdb/test_util/sync_point_impl.h +31 -4
- package/deps/rocksdb/rocksdb/test_util/testharness.cc +53 -1
- package/deps/rocksdb/rocksdb/test_util/testharness.h +67 -3
- package/deps/rocksdb/rocksdb/test_util/testutil.cc +236 -66
- package/deps/rocksdb/rocksdb/test_util/testutil.h +63 -100
- package/deps/rocksdb/rocksdb/test_util/transaction_test_util.cc +12 -1
- package/deps/rocksdb/rocksdb/tools/blob_dump.cc +2 -2
- package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.cc +6 -3
- package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.h +1 -0
- package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_test.cc +9 -3
- package/deps/rocksdb/rocksdb/tools/db_bench.cc +1 -1
- package/deps/rocksdb/rocksdb/tools/db_bench_tool.cc +1420 -611
- package/deps/rocksdb/rocksdb/tools/db_bench_tool_test.cc +11 -8
- package/deps/rocksdb/rocksdb/tools/db_repl_stress.cc +11 -1
- package/deps/rocksdb/rocksdb/tools/io_tracer_parser_test.cc +4 -2
- package/deps/rocksdb/rocksdb/tools/io_tracer_parser_tool.cc +46 -22
- package/deps/rocksdb/rocksdb/tools/ldb_cmd.cc +655 -179
- package/deps/rocksdb/rocksdb/tools/ldb_cmd_impl.h +58 -6
- package/deps/rocksdb/rocksdb/tools/ldb_cmd_test.cc +472 -29
- package/deps/rocksdb/rocksdb/tools/ldb_tool.cc +23 -2
- package/deps/rocksdb/rocksdb/tools/reduce_levels_test.cc +2 -2
- package/deps/rocksdb/rocksdb/tools/simulated_hybrid_file_system.cc +246 -0
- package/deps/rocksdb/rocksdb/tools/simulated_hybrid_file_system.h +126 -0
- package/deps/rocksdb/rocksdb/tools/sst_dump_test.cc +83 -29
- package/deps/rocksdb/rocksdb/tools/sst_dump_tool.cc +38 -17
- package/deps/rocksdb/rocksdb/tools/trace_analyzer_test.cc +191 -55
- package/deps/rocksdb/rocksdb/tools/trace_analyzer_tool.cc +219 -296
- package/deps/rocksdb/rocksdb/tools/trace_analyzer_tool.h +87 -53
- package/deps/rocksdb/rocksdb/tools/write_stress.cc +8 -7
- package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer.cc +6 -5
- package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer.h +5 -4
- package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer_test.cc +14 -9
- package/deps/rocksdb/rocksdb/trace_replay/io_tracer.cc +134 -60
- package/deps/rocksdb/rocksdb/trace_replay/io_tracer.h +49 -38
- package/deps/rocksdb/rocksdb/trace_replay/io_tracer_test.cc +152 -15
- package/deps/rocksdb/rocksdb/trace_replay/trace_record.cc +206 -0
- package/deps/rocksdb/rocksdb/trace_replay/trace_record_handler.cc +190 -0
- package/deps/rocksdb/rocksdb/trace_replay/trace_record_handler.h +46 -0
- package/deps/rocksdb/rocksdb/trace_replay/trace_record_result.cc +146 -0
- package/deps/rocksdb/rocksdb/trace_replay/trace_replay.cc +475 -344
- package/deps/rocksdb/rocksdb/trace_replay/trace_replay.h +83 -95
- package/deps/rocksdb/rocksdb/util/autovector.h +38 -18
- package/deps/rocksdb/rocksdb/util/autovector_test.cc +1 -1
- package/deps/rocksdb/rocksdb/util/bloom_impl.h +4 -0
- package/deps/rocksdb/rocksdb/util/bloom_test.cc +276 -94
- package/deps/rocksdb/rocksdb/util/build_version.cc.in +81 -4
- package/deps/rocksdb/rocksdb/util/cast_util.h +22 -0
- package/deps/rocksdb/rocksdb/util/channel.h +2 -0
- package/deps/rocksdb/rocksdb/util/coding.h +1 -33
- package/deps/rocksdb/rocksdb/util/compaction_job_stats_impl.cc +8 -0
- package/deps/rocksdb/rocksdb/util/comparator.cc +163 -3
- package/deps/rocksdb/rocksdb/util/compression.cc +122 -0
- package/deps/rocksdb/rocksdb/util/compression.h +212 -7
- package/deps/rocksdb/rocksdb/util/compression_context_cache.cc +1 -3
- package/deps/rocksdb/rocksdb/util/crc32c.cc +165 -2
- package/deps/rocksdb/rocksdb/util/crc32c.h +6 -0
- package/deps/rocksdb/rocksdb/util/crc32c_arm64.cc +14 -0
- package/deps/rocksdb/rocksdb/util/crc32c_ppc.h +3 -0
- package/deps/rocksdb/rocksdb/util/crc32c_test.cc +47 -0
- package/deps/rocksdb/rocksdb/util/defer.h +30 -1
- package/deps/rocksdb/rocksdb/util/defer_test.cc +11 -0
- package/deps/rocksdb/rocksdb/util/duplicate_detector.h +3 -1
- package/deps/rocksdb/rocksdb/util/dynamic_bloom.h +3 -3
- package/deps/rocksdb/rocksdb/util/dynamic_bloom_test.cc +5 -4
- package/deps/rocksdb/rocksdb/util/fastrange.h +2 -0
- package/deps/rocksdb/rocksdb/util/file_checksum_helper.cc +36 -0
- package/deps/rocksdb/rocksdb/util/file_checksum_helper.h +3 -1
- package/deps/rocksdb/rocksdb/util/file_reader_writer_test.cc +512 -52
- package/deps/rocksdb/rocksdb/util/filter_bench.cc +65 -10
- package/deps/rocksdb/rocksdb/util/gflags_compat.h +6 -1
- package/deps/rocksdb/rocksdb/util/hash.cc +121 -3
- package/deps/rocksdb/rocksdb/util/hash.h +31 -1
- package/deps/rocksdb/rocksdb/util/hash128.h +26 -0
- package/deps/rocksdb/rocksdb/util/hash_containers.h +51 -0
- package/deps/rocksdb/rocksdb/util/hash_test.cc +194 -2
- package/deps/rocksdb/rocksdb/util/heap.h +6 -1
- package/deps/rocksdb/rocksdb/util/kv_map.h +1 -1
- package/deps/rocksdb/rocksdb/util/log_write_bench.cc +8 -6
- package/deps/rocksdb/rocksdb/util/math.h +74 -7
- package/deps/rocksdb/rocksdb/util/math128.h +13 -1
- package/deps/rocksdb/rocksdb/util/murmurhash.h +3 -3
- package/deps/rocksdb/rocksdb/util/random.cc +9 -0
- package/deps/rocksdb/rocksdb/util/random.h +6 -0
- package/deps/rocksdb/rocksdb/util/rate_limiter.cc +298 -144
- package/deps/rocksdb/rocksdb/util/rate_limiter.h +68 -19
- package/deps/rocksdb/rocksdb/util/rate_limiter_test.cc +335 -23
- package/deps/rocksdb/rocksdb/util/repeatable_thread.h +10 -12
- package/deps/rocksdb/rocksdb/util/repeatable_thread_test.cc +18 -15
- package/deps/rocksdb/rocksdb/util/ribbon_alg.h +98 -74
- package/deps/rocksdb/rocksdb/util/ribbon_config.cc +506 -0
- package/deps/rocksdb/rocksdb/util/ribbon_config.h +182 -0
- package/deps/rocksdb/rocksdb/util/ribbon_impl.h +154 -79
- package/deps/rocksdb/rocksdb/util/ribbon_test.cc +742 -365
- package/deps/rocksdb/rocksdb/util/set_comparator.h +2 -0
- package/deps/rocksdb/rocksdb/util/slice.cc +198 -35
- package/deps/rocksdb/rocksdb/util/slice_test.cc +30 -1
- package/deps/rocksdb/rocksdb/util/status.cc +32 -29
- package/deps/rocksdb/rocksdb/util/stop_watch.h +18 -18
- package/deps/rocksdb/rocksdb/util/string_util.cc +85 -6
- package/deps/rocksdb/rocksdb/util/string_util.h +47 -2
- package/deps/rocksdb/rocksdb/util/thread_guard.h +41 -0
- package/deps/rocksdb/rocksdb/util/thread_local.h +2 -2
- package/deps/rocksdb/rocksdb/util/thread_local_test.cc +22 -24
- package/deps/rocksdb/rocksdb/util/threadpool_imp.cc +7 -6
- package/deps/rocksdb/rocksdb/util/timer.h +55 -46
- package/deps/rocksdb/rocksdb/util/timer_test.cc +50 -48
- package/deps/rocksdb/rocksdb/util/user_comparator_wrapper.h +4 -0
- package/deps/rocksdb/rocksdb/util/vector_iterator.h +31 -15
- package/deps/rocksdb/rocksdb/util/work_queue.h +2 -0
- package/deps/rocksdb/rocksdb/util/xxhash.cc +35 -1144
- package/deps/rocksdb/rocksdb/util/xxhash.h +5117 -373
- package/deps/rocksdb/rocksdb/util/xxph3.h +1762 -0
- package/deps/rocksdb/rocksdb/utilities/agg_merge/agg_merge.cc +238 -0
- package/deps/rocksdb/rocksdb/utilities/agg_merge/agg_merge.h +49 -0
- package/deps/rocksdb/rocksdb/utilities/agg_merge/agg_merge_test.cc +134 -0
- package/deps/rocksdb/rocksdb/utilities/agg_merge/test_agg_merge.cc +104 -0
- package/deps/rocksdb/rocksdb/utilities/agg_merge/test_agg_merge.h +47 -0
- package/deps/rocksdb/rocksdb/utilities/backup/backup_engine.cc +3164 -0
- package/deps/rocksdb/rocksdb/utilities/backup/backup_engine_impl.h +29 -0
- package/deps/rocksdb/rocksdb/utilities/{backupable/backupable_db_test.cc → backup/backup_engine_test.cc} +1679 -485
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_compaction_filter.cc +6 -4
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_compaction_filter.h +14 -9
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db.cc +2 -0
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db.h +1 -0
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_gc_stats.h +4 -0
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl.cc +37 -27
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl.h +8 -4
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl_filesnapshot.cc +1 -1
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_iterator.h +13 -10
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_listener.h +5 -0
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_test.cc +44 -25
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_dump_tool.cc +3 -4
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_file.cc +27 -19
- package/deps/rocksdb/rocksdb/utilities/blob_db/blob_file.h +4 -2
- package/deps/rocksdb/rocksdb/utilities/cache_dump_load.cc +69 -0
- package/deps/rocksdb/rocksdb/utilities/cache_dump_load_impl.cc +489 -0
- package/deps/rocksdb/rocksdb/utilities/cache_dump_load_impl.h +366 -0
- package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_compaction_filter.cc +67 -4
- package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_compaction_filter.h +21 -6
- package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_functional_test.cc +107 -7
- package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_options.h +43 -0
- package/deps/rocksdb/rocksdb/utilities/cassandra/format.h +1 -1
- package/deps/rocksdb/rocksdb/utilities/cassandra/merge_operator.cc +24 -8
- package/deps/rocksdb/rocksdb/utilities/cassandra/merge_operator.h +7 -7
- package/deps/rocksdb/rocksdb/utilities/cassandra/serialize.h +5 -0
- package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_impl.cc +99 -218
- package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_impl.h +8 -24
- package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_test.cc +114 -1
- package/deps/rocksdb/rocksdb/utilities/compaction_filters/layered_compaction_filter_base.h +6 -2
- package/deps/rocksdb/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.cc +0 -4
- package/deps/rocksdb/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.h +7 -6
- package/deps/rocksdb/rocksdb/utilities/compaction_filters.cc +56 -0
- package/deps/rocksdb/rocksdb/utilities/convenience/info_log_finder.cc +2 -2
- package/deps/rocksdb/rocksdb/utilities/counted_fs.cc +355 -0
- package/deps/rocksdb/rocksdb/utilities/counted_fs.h +152 -0
- package/deps/rocksdb/rocksdb/utilities/env_mirror.cc +13 -0
- package/deps/rocksdb/rocksdb/utilities/env_timed.cc +164 -122
- package/deps/rocksdb/rocksdb/utilities/env_timed.h +97 -0
- package/deps/rocksdb/rocksdb/utilities/fault_injection_env.cc +75 -17
- package/deps/rocksdb/rocksdb/utilities/fault_injection_env.h +19 -3
- package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.cc +539 -126
- package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.h +162 -17
- package/deps/rocksdb/rocksdb/utilities/fault_injection_secondary_cache.cc +110 -0
- package/deps/rocksdb/rocksdb/utilities/fault_injection_secondary_cache.h +94 -0
- package/deps/rocksdb/rocksdb/utilities/memory/memory_test.cc +5 -2
- package/deps/rocksdb/rocksdb/utilities/memory_allocators.h +104 -0
- package/deps/rocksdb/rocksdb/utilities/merge_operators/bytesxor.h +5 -3
- package/deps/rocksdb/rocksdb/utilities/merge_operators/max.cc +4 -1
- package/deps/rocksdb/rocksdb/utilities/merge_operators/put.cc +11 -3
- package/deps/rocksdb/rocksdb/utilities/merge_operators/sortlist.cc +0 -2
- package/deps/rocksdb/rocksdb/utilities/merge_operators/sortlist.h +5 -1
- package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend.cc +29 -10
- package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend.h +6 -3
- package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend2.cc +29 -14
- package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend2.h +6 -3
- package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend_test.cc +71 -18
- package/deps/rocksdb/rocksdb/utilities/merge_operators/uint64add.cc +15 -9
- package/deps/rocksdb/rocksdb/utilities/merge_operators.cc +120 -0
- package/deps/rocksdb/rocksdb/utilities/merge_operators.h +3 -23
- package/deps/rocksdb/rocksdb/utilities/object_registry.cc +267 -42
- package/deps/rocksdb/rocksdb/utilities/object_registry_test.cc +702 -76
- package/deps/rocksdb/rocksdb/utilities/option_change_migration/option_change_migration.cc +1 -1
- package/deps/rocksdb/rocksdb/utilities/option_change_migration/option_change_migration_test.cc +26 -5
- package/deps/rocksdb/rocksdb/utilities/options/options_util.cc +1 -1
- package/deps/rocksdb/rocksdb/utilities/options/options_util_test.cc +124 -1
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier.cc +2 -3
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier.h +8 -9
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_file.cc +15 -13
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_file.h +1 -1
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_metadata.h +4 -4
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/hash_table_evictable.h +2 -2
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_bench.cc +8 -9
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_test.cc +1 -1
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_tier.h +6 -3
- package/deps/rocksdb/rocksdb/utilities/persistent_cache/volatile_tier_impl.h +2 -2
- package/deps/rocksdb/rocksdb/utilities/simulator_cache/cache_simulator.cc +3 -0
- package/deps/rocksdb/rocksdb/utilities/simulator_cache/cache_simulator_test.cc +2 -0
- package/deps/rocksdb/rocksdb/utilities/simulator_cache/sim_cache.cc +43 -35
- package/deps/rocksdb/rocksdb/utilities/simulator_cache/sim_cache_test.cc +20 -18
- package/deps/rocksdb/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.cc +107 -2
- package/deps/rocksdb/rocksdb/utilities/trace/file_trace_reader_writer.cc +23 -15
- package/deps/rocksdb/rocksdb/utilities/trace/file_trace_reader_writer.h +2 -2
- package/deps/rocksdb/rocksdb/utilities/trace/replayer_impl.cc +316 -0
- package/deps/rocksdb/rocksdb/utilities/trace/replayer_impl.h +86 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager.cc +4 -5
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager.h +4 -3
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager_test.h +1 -1
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_locking_test.cc +119 -3
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.cc +20 -3
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.h +20 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_external_pthread.h +3 -2
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_time.h +4 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.cc +38 -14
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.h +17 -10
- package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction_db_impl.h +1 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction_test.cc +1 -2
- package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction.cc +423 -34
- package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction.h +82 -2
- package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction_db.cc +72 -40
- package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction_db.h +32 -1
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_base.cc +13 -5
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_base.h +7 -3
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_test.cc +207 -43
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_test.h +50 -7
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_util.cc +28 -10
- package/deps/rocksdb/rocksdb/utilities/transactions/transaction_util.h +11 -6
- package/deps/rocksdb/rocksdb/utilities/transactions/write_committed_transaction_ts_test.cc +516 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_transaction_test.cc +506 -15
- package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn.cc +27 -13
- package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.cc +14 -14
- package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.h +3 -0
- package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_transaction_test.cc +2 -2
- package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn.cc +14 -5
- package/deps/rocksdb/rocksdb/utilities/ttl/db_ttl_impl.cc +305 -27
- package/deps/rocksdb/rocksdb/utilities/ttl/db_ttl_impl.h +55 -159
- package/deps/rocksdb/rocksdb/utilities/ttl/ttl_test.cc +209 -2
- package/deps/rocksdb/rocksdb/utilities/wal_filter.cc +23 -0
- package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index.cc +157 -88
- package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.cc +501 -114
- package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.h +91 -316
- package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_test.cc +1212 -672
- package/deps/rocksdb/rocksdb.gyp +425 -446
- package/index.js +5 -87
- package/package-lock.json +23687 -0
- package/package.json +8 -9
- package/prebuilds/darwin-arm64/node.napi.node +0 -0
- package/prebuilds/darwin-x64/node.napi.node +0 -0
- package/prebuilds/{darwin-x64+arm64 → linux-x64}/node.napi.node +0 -0
- package/deps/rocksdb/rocksdb/README.md +0 -32
- package/deps/rocksdb/rocksdb/env/env_hdfs.cc +0 -648
- package/deps/rocksdb/rocksdb/hdfs/README +0 -23
- package/deps/rocksdb/rocksdb/hdfs/env_hdfs.h +0 -386
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/backupable_db.h +0 -535
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/env_librados.h +0 -175
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/utility_db.h +0 -34
- package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator_test.cc +0 -102
- package/deps/rocksdb/rocksdb/memtable/hash_linklist_rep.h +0 -49
- package/deps/rocksdb/rocksdb/memtable/hash_skiplist_rep.h +0 -44
- package/deps/rocksdb/rocksdb/options/customizable_helper.h +0 -216
- package/deps/rocksdb/rocksdb/port/README +0 -10
- package/deps/rocksdb/rocksdb/third-party/folly/folly/CPortability.h +0 -27
- package/deps/rocksdb/rocksdb/third-party/folly/folly/ConstexprMath.h +0 -45
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Indestructible.h +0 -166
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Optional.h +0 -570
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Portability.h +0 -92
- package/deps/rocksdb/rocksdb/third-party/folly/folly/ScopeGuard.h +0 -54
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Traits.h +0 -152
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Unit.h +0 -59
- package/deps/rocksdb/rocksdb/third-party/folly/folly/Utility.h +0 -141
- package/deps/rocksdb/rocksdb/third-party/folly/folly/chrono/Hardware.h +0 -33
- package/deps/rocksdb/rocksdb/third-party/folly/folly/container/Array.h +0 -74
- package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex-inl.h +0 -117
- package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex.cpp +0 -263
- package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex.h +0 -96
- package/deps/rocksdb/rocksdb/third-party/folly/folly/functional/Invoke.h +0 -40
- package/deps/rocksdb/rocksdb/third-party/folly/folly/hash/Hash.h +0 -29
- package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Align.h +0 -144
- package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Bits.h +0 -30
- package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Launder.h +0 -51
- package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/Asm.h +0 -28
- package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/SysSyscall.h +0 -10
- package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/SysTypes.h +0 -26
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification-inl.h +0 -138
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification.cpp +0 -23
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification.h +0 -57
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicUtil-inl.h +0 -260
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicUtil.h +0 -52
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/Baton.h +0 -328
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex-inl.h +0 -1703
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex.cpp +0 -16
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex.h +0 -304
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutexSpecializations.h +0 -39
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/ParkingLot.cpp +0 -26
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/ParkingLot.h +0 -318
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/WaitOptions.h +0 -57
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/InlineFunctionRef.h +0 -219
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/ProxyLockable-inl.h +0 -207
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/ProxyLockable.h +0 -164
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/Sleeper.h +0 -57
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/Spin.h +0 -77
- package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/test/DistributedMutexTest.cpp +0 -1145
- package/deps/rocksdb/rocksdb/util/build_version.h +0 -15
- package/deps/rocksdb/rocksdb/util/xxh3p.h +0 -1392
- package/deps/rocksdb/rocksdb/utilities/backupable/backupable_db.cc +0 -2354
- package/deps/rocksdb/rocksdb/utilities/env_librados.cc +0 -1497
- package/deps/rocksdb/rocksdb/utilities/env_librados_test.cc +0 -1146
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/README +0 -13
- package/deps/snappy/snappy-1.1.7/README.md +0 -149
- package/prebuilds/linux-x64/node.napi.glibc.node +0 -0
|
@@ -3,1156 +3,47 @@
|
|
|
3
3
|
// COPYING file in the root directory) and Apache 2.0 License
|
|
4
4
|
// (found in the LICENSE.Apache file in the root directory).
|
|
5
5
|
/*
|
|
6
|
-
*
|
|
7
|
-
*
|
|
8
|
-
*
|
|
9
|
-
* BSD 2-Clause License (http://www.opensource.org/licenses/bsd-license.php)
|
|
10
|
-
*
|
|
11
|
-
* Redistribution and use in source and binary forms, with or without
|
|
12
|
-
* modification, are permitted provided that the following conditions are
|
|
13
|
-
* met:
|
|
14
|
-
*
|
|
15
|
-
* * Redistributions of source code must retain the above copyright
|
|
16
|
-
* notice, this list of conditions and the following disclaimer.
|
|
17
|
-
* * Redistributions in binary form must reproduce the above
|
|
18
|
-
* copyright notice, this list of conditions and the following disclaimer
|
|
19
|
-
* in the documentation and/or other materials provided with the
|
|
20
|
-
* distribution.
|
|
21
|
-
*
|
|
22
|
-
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
23
|
-
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
24
|
-
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
25
|
-
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
26
|
-
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
27
|
-
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
28
|
-
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
29
|
-
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
30
|
-
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
31
|
-
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
32
|
-
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
33
|
-
*
|
|
34
|
-
* You can contact the author at :
|
|
35
|
-
* - xxHash homepage: http://www.xxhash.com
|
|
36
|
-
* - xxHash source repository : https://github.com/Cyan4973/xxHash
|
|
37
|
-
*/
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
/* since xxhash.c can be included (via XXH_INLINE_ALL),
|
|
41
|
-
* it's good practice to protect it with guard
|
|
42
|
-
* in case of multiples inclusions */
|
|
43
|
-
#ifndef XXHASH_C_01393879
|
|
44
|
-
#define XXHASH_C_01393879
|
|
45
|
-
|
|
46
|
-
/* *************************************
|
|
47
|
-
* Tuning parameters
|
|
48
|
-
***************************************/
|
|
49
|
-
/*!XXH_FORCE_MEMORY_ACCESS :
|
|
50
|
-
* By default, access to unaligned memory is controlled by `memcpy()`, which is safe and portable.
|
|
51
|
-
* Unfortunately, on some target/compiler combinations, the generated assembly is sub-optimal.
|
|
52
|
-
* The below switch allow to select different access method for improved performance.
|
|
53
|
-
* Method 0 (default) : use `memcpy()`. Safe and portable.
|
|
54
|
-
* Method 1 : `__packed` statement. It depends on compiler extension (ie, not portable).
|
|
55
|
-
* This method is safe if your compiler supports it, and *generally* as fast or faster than `memcpy`.
|
|
56
|
-
* Method 2 : direct access. This method doesn't depend on compiler but violate C standard.
|
|
57
|
-
* It can generate buggy code on targets which do not support unaligned memory accesses.
|
|
58
|
-
* But in some circumstances, it's the only known way to get the most performance (ie GCC + ARMv6)
|
|
59
|
-
* See http://stackoverflow.com/a/32095106/646947 for details.
|
|
60
|
-
* Prefer these methods in priority order (0 > 1 > 2)
|
|
61
|
-
*/
|
|
62
|
-
#ifndef XXH_FORCE_MEMORY_ACCESS /* can be defined externally, on command line for example */
|
|
63
|
-
# if !defined(__clang__) && defined(__GNUC__) && defined(__ARM_FEATURE_UNALIGNED) && defined(__ARM_ARCH) && (__ARM_ARCH == 6)
|
|
64
|
-
# define XXH_FORCE_MEMORY_ACCESS 2
|
|
65
|
-
# elif !defined(__clang__) && ((defined(__INTEL_COMPILER) && !defined(_WIN32)) || \
|
|
66
|
-
(defined(__GNUC__) && (defined(__ARM_ARCH) && __ARM_ARCH >= 7)))
|
|
67
|
-
# define XXH_FORCE_MEMORY_ACCESS 1
|
|
68
|
-
# endif
|
|
69
|
-
#endif
|
|
70
|
-
|
|
71
|
-
/*!XXH_ACCEPT_NULL_INPUT_POINTER :
|
|
72
|
-
* If input pointer is NULL, xxHash default behavior is to dereference it, triggering a segfault.
|
|
73
|
-
* When this macro is enabled, xxHash actively checks input for null pointer.
|
|
74
|
-
* It it is, result for null input pointers is the same as a null-length input.
|
|
75
|
-
*/
|
|
76
|
-
#ifndef XXH_ACCEPT_NULL_INPUT_POINTER /* can be defined externally */
|
|
77
|
-
# define XXH_ACCEPT_NULL_INPUT_POINTER 0
|
|
78
|
-
#endif
|
|
79
|
-
|
|
80
|
-
/*!XXH_FORCE_ALIGN_CHECK :
|
|
81
|
-
* This is a minor performance trick, only useful with lots of very small keys.
|
|
82
|
-
* It means : check for aligned/unaligned input.
|
|
83
|
-
* The check costs one initial branch per hash;
|
|
84
|
-
* set it to 0 when the input is guaranteed to be aligned,
|
|
85
|
-
* or when alignment doesn't matter for performance.
|
|
86
|
-
*/
|
|
87
|
-
#ifndef XXH_FORCE_ALIGN_CHECK /* can be defined externally */
|
|
88
|
-
# if defined(__i386) || defined(_M_IX86) || defined(__x86_64__) || defined(_M_X64)
|
|
89
|
-
# define XXH_FORCE_ALIGN_CHECK 0
|
|
90
|
-
# else
|
|
91
|
-
# define XXH_FORCE_ALIGN_CHECK 1
|
|
92
|
-
# endif
|
|
93
|
-
#endif
|
|
94
|
-
|
|
95
|
-
/*!XXH_REROLL:
|
|
96
|
-
* Whether to reroll XXH32_finalize, and XXH64_finalize,
|
|
97
|
-
* instead of using an unrolled jump table/if statement loop.
|
|
6
|
+
* xxHash - Extremely Fast Hash algorithm
|
|
7
|
+
* Copyright (C) 2012-2020 Yann Collet
|
|
98
8
|
*
|
|
99
|
-
*
|
|
100
|
-
#ifndef XXH_REROLL
|
|
101
|
-
# if defined(__OPTIMIZE_SIZE__)
|
|
102
|
-
# define XXH_REROLL 1
|
|
103
|
-
# else
|
|
104
|
-
# define XXH_REROLL 0
|
|
105
|
-
# endif
|
|
106
|
-
#endif
|
|
107
|
-
|
|
108
|
-
/* *************************************
|
|
109
|
-
* Includes & Memory related functions
|
|
110
|
-
***************************************/
|
|
111
|
-
/*! Modify the local functions below should you wish to use some other memory routines
|
|
112
|
-
* for malloc(), free() */
|
|
113
|
-
#include <stdlib.h>
|
|
114
|
-
static void* XXH_malloc(size_t s) { return malloc(s); }
|
|
115
|
-
static void XXH_free (void* p) { free(p); }
|
|
116
|
-
/*! and for memcpy() */
|
|
117
|
-
#include <string.h>
|
|
118
|
-
static void* XXH_memcpy(void* dest, const void* src, size_t size) { return memcpy(dest,src,size); }
|
|
119
|
-
|
|
120
|
-
#include <limits.h> /* ULLONG_MAX */
|
|
121
|
-
|
|
122
|
-
#ifndef XXH_STATIC_LINKING_ONLY
|
|
123
|
-
#define XXH_STATIC_LINKING_ONLY
|
|
124
|
-
#endif
|
|
125
|
-
|
|
126
|
-
#include "xxhash.h"
|
|
127
|
-
|
|
128
|
-
/* BEGIN RocksDB customizations */
|
|
129
|
-
#include "port/lang.h" /* for FALLTHROUGH_INTENDED, inserted as appropriate */
|
|
130
|
-
/* END RocksDB customizations */
|
|
131
|
-
|
|
132
|
-
/* *************************************
|
|
133
|
-
* Compiler Specific Options
|
|
134
|
-
***************************************/
|
|
135
|
-
#ifdef _MSC_VER /* Visual Studio */
|
|
136
|
-
# pragma warning(disable : 4127) /* disable: C4127: conditional expression is constant */
|
|
137
|
-
# define XXH_FORCE_INLINE static __forceinline
|
|
138
|
-
# define XXH_NO_INLINE static __declspec(noinline)
|
|
139
|
-
#else
|
|
140
|
-
# if defined (__cplusplus) || defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L /* C99 */
|
|
141
|
-
# ifdef __GNUC__
|
|
142
|
-
# define XXH_FORCE_INLINE static inline __attribute__((always_inline))
|
|
143
|
-
# define XXH_NO_INLINE static __attribute__((noinline))
|
|
144
|
-
# else
|
|
145
|
-
# define XXH_FORCE_INLINE static inline
|
|
146
|
-
# define XXH_NO_INLINE static
|
|
147
|
-
# endif
|
|
148
|
-
# else
|
|
149
|
-
# define XXH_FORCE_INLINE static
|
|
150
|
-
# define XXH_NO_INLINE static
|
|
151
|
-
# endif /* __STDC_VERSION__ */
|
|
152
|
-
#endif
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
/* *************************************
|
|
157
|
-
* Debug
|
|
158
|
-
***************************************/
|
|
159
|
-
/* DEBUGLEVEL is expected to be defined externally,
|
|
160
|
-
* typically through compiler command line.
|
|
161
|
-
* Value must be a number. */
|
|
162
|
-
#ifndef DEBUGLEVEL
|
|
163
|
-
# define DEBUGLEVEL 0
|
|
164
|
-
#endif
|
|
165
|
-
|
|
166
|
-
#if (DEBUGLEVEL>=1)
|
|
167
|
-
# include <assert.h> /* note : can still be disabled with NDEBUG */
|
|
168
|
-
# define XXH_ASSERT(c) assert(c)
|
|
169
|
-
#else
|
|
170
|
-
# define XXH_ASSERT(c) ((void)0)
|
|
171
|
-
#endif
|
|
172
|
-
|
|
173
|
-
/* note : use after variable declarations */
|
|
174
|
-
#define XXH_STATIC_ASSERT(c) { enum { XXH_sa = 1/(int)(!!(c)) }; }
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
/* *************************************
|
|
178
|
-
* Basic Types
|
|
179
|
-
***************************************/
|
|
180
|
-
#if !defined (__VMS) \
|
|
181
|
-
&& (defined (__cplusplus) \
|
|
182
|
-
|| (defined (__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) /* C99 */) )
|
|
183
|
-
# include <stdint.h>
|
|
184
|
-
typedef uint8_t xxh_u8;
|
|
185
|
-
#else
|
|
186
|
-
typedef unsigned char xxh_u8;
|
|
187
|
-
#endif
|
|
188
|
-
typedef XXH32_hash_t xxh_u32;
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
/* === Memory access === */
|
|
192
|
-
|
|
193
|
-
#if (defined(XXH_FORCE_MEMORY_ACCESS) && (XXH_FORCE_MEMORY_ACCESS==2))
|
|
194
|
-
|
|
195
|
-
/* Force direct memory access. Only works on CPU which support unaligned memory access in hardware */
|
|
196
|
-
static xxh_u32 XXH_read32(const void* memPtr) { return *(const xxh_u32*) memPtr; }
|
|
197
|
-
|
|
198
|
-
#elif (defined(XXH_FORCE_MEMORY_ACCESS) && (XXH_FORCE_MEMORY_ACCESS==1))
|
|
199
|
-
|
|
200
|
-
/* __pack instructions are safer, but compiler specific, hence potentially problematic for some compilers */
|
|
201
|
-
/* currently only defined for gcc and icc */
|
|
202
|
-
typedef union { xxh_u32 u32; } __attribute__((packed)) unalign;
|
|
203
|
-
static xxh_u32 XXH_read32(const void* ptr) { return ((const unalign*)ptr)->u32; }
|
|
204
|
-
|
|
205
|
-
#else
|
|
206
|
-
|
|
207
|
-
/* portable and safe solution. Generally efficient.
|
|
208
|
-
* see : http://stackoverflow.com/a/32095106/646947
|
|
209
|
-
*/
|
|
210
|
-
static xxh_u32 XXH_read32(const void* memPtr)
|
|
211
|
-
{
|
|
212
|
-
xxh_u32 val;
|
|
213
|
-
memcpy(&val, memPtr, sizeof(val));
|
|
214
|
-
return val;
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
#endif /* XXH_FORCE_DIRECT_MEMORY_ACCESS */
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
/* === Endianess === */
|
|
221
|
-
|
|
222
|
-
/* XXH_CPU_LITTLE_ENDIAN can be defined externally, for example on the compiler command line */
|
|
223
|
-
#ifndef XXH_CPU_LITTLE_ENDIAN
|
|
224
|
-
# if defined(_WIN32) /* Windows is always little endian */ \
|
|
225
|
-
|| defined(__LITTLE_ENDIAN__) \
|
|
226
|
-
|| (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__)
|
|
227
|
-
# define XXH_CPU_LITTLE_ENDIAN 1
|
|
228
|
-
# elif defined(__BIG_ENDIAN__) \
|
|
229
|
-
|| (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__)
|
|
230
|
-
# define XXH_CPU_LITTLE_ENDIAN 0
|
|
231
|
-
# else
|
|
232
|
-
static int XXH_isLittleEndian(void)
|
|
233
|
-
{
|
|
234
|
-
const union { xxh_u32 u; xxh_u8 c[4]; } one = { 1 }; /* don't use static : performance detrimental */
|
|
235
|
-
return one.c[0];
|
|
236
|
-
}
|
|
237
|
-
# define XXH_CPU_LITTLE_ENDIAN XXH_isLittleEndian()
|
|
238
|
-
# endif
|
|
239
|
-
#endif
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
/* ****************************************
|
|
245
|
-
* Compiler-specific Functions and Macros
|
|
246
|
-
******************************************/
|
|
247
|
-
#define XXH_GCC_VERSION (__GNUC__ * 100 + __GNUC_MINOR__)
|
|
248
|
-
|
|
249
|
-
#ifndef __has_builtin
|
|
250
|
-
# define __has_builtin(x) 0
|
|
251
|
-
#endif
|
|
252
|
-
|
|
253
|
-
#if !defined(NO_CLANG_BUILTIN) && __has_builtin(__builtin_rotateleft32) && __has_builtin(__builtin_rotateleft64)
|
|
254
|
-
# define XXH_rotl32 __builtin_rotateleft32
|
|
255
|
-
# define XXH_rotl64 __builtin_rotateleft64
|
|
256
|
-
/* Note : although _rotl exists for minGW (GCC under windows), performance seems poor */
|
|
257
|
-
#elif defined(_MSC_VER)
|
|
258
|
-
# define XXH_rotl32(x,r) _rotl(x,r)
|
|
259
|
-
# define XXH_rotl64(x,r) _rotl64(x,r)
|
|
260
|
-
#else
|
|
261
|
-
# define XXH_rotl32(x,r) (((x) << (r)) | ((x) >> (32 - (r))))
|
|
262
|
-
# define XXH_rotl64(x,r) (((x) << (r)) | ((x) >> (64 - (r))))
|
|
263
|
-
#endif
|
|
264
|
-
|
|
265
|
-
#if defined(_MSC_VER) /* Visual Studio */
|
|
266
|
-
# define XXH_swap32 _byteswap_ulong
|
|
267
|
-
#elif XXH_GCC_VERSION >= 403
|
|
268
|
-
# define XXH_swap32 __builtin_bswap32
|
|
269
|
-
#else
|
|
270
|
-
static xxh_u32 XXH_swap32 (xxh_u32 x)
|
|
271
|
-
{
|
|
272
|
-
return ((x << 24) & 0xff000000 ) |
|
|
273
|
-
((x << 8) & 0x00ff0000 ) |
|
|
274
|
-
((x >> 8) & 0x0000ff00 ) |
|
|
275
|
-
((x >> 24) & 0x000000ff );
|
|
276
|
-
}
|
|
277
|
-
#endif
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
/* ***************************
|
|
281
|
-
* Memory reads
|
|
282
|
-
*****************************/
|
|
283
|
-
typedef enum { XXH_aligned, XXH_unaligned } XXH_alignment;
|
|
284
|
-
|
|
285
|
-
XXH_FORCE_INLINE xxh_u32 XXH_readLE32(const void* ptr)
|
|
286
|
-
{
|
|
287
|
-
return XXH_CPU_LITTLE_ENDIAN ? XXH_read32(ptr) : XXH_swap32(XXH_read32(ptr));
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
static xxh_u32 XXH_readBE32(const void* ptr)
|
|
291
|
-
{
|
|
292
|
-
return XXH_CPU_LITTLE_ENDIAN ? XXH_swap32(XXH_read32(ptr)) : XXH_read32(ptr);
|
|
293
|
-
}
|
|
294
|
-
|
|
295
|
-
XXH_FORCE_INLINE xxh_u32
|
|
296
|
-
XXH_readLE32_align(const void* ptr, XXH_alignment align)
|
|
297
|
-
{
|
|
298
|
-
if (align==XXH_unaligned) {
|
|
299
|
-
return XXH_readLE32(ptr);
|
|
300
|
-
} else {
|
|
301
|
-
return XXH_CPU_LITTLE_ENDIAN ? *(const xxh_u32*)ptr : XXH_swap32(*(const xxh_u32*)ptr);
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
/* *************************************
|
|
307
|
-
* Misc
|
|
308
|
-
***************************************/
|
|
309
|
-
XXH_PUBLIC_API unsigned XXH_versionNumber (void) { return XXH_VERSION_NUMBER; }
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
/* *******************************************************************
|
|
313
|
-
* 32-bit hash functions
|
|
314
|
-
*********************************************************************/
|
|
315
|
-
static const xxh_u32 PRIME32_1 = 0x9E3779B1U; /* 0b10011110001101110111100110110001 */
|
|
316
|
-
static const xxh_u32 PRIME32_2 = 0x85EBCA77U; /* 0b10000101111010111100101001110111 */
|
|
317
|
-
static const xxh_u32 PRIME32_3 = 0xC2B2AE3DU; /* 0b11000010101100101010111000111101 */
|
|
318
|
-
static const xxh_u32 PRIME32_4 = 0x27D4EB2FU; /* 0b00100111110101001110101100101111 */
|
|
319
|
-
static const xxh_u32 PRIME32_5 = 0x165667B1U; /* 0b00010110010101100110011110110001 */
|
|
320
|
-
|
|
321
|
-
static xxh_u32 XXH32_round(xxh_u32 acc, xxh_u32 input)
|
|
322
|
-
{
|
|
323
|
-
acc += input * PRIME32_2;
|
|
324
|
-
acc = XXH_rotl32(acc, 13);
|
|
325
|
-
acc *= PRIME32_1;
|
|
326
|
-
#if defined(__GNUC__) && defined(__SSE4_1__) && !defined(XXH_ENABLE_AUTOVECTORIZE)
|
|
327
|
-
/* UGLY HACK:
|
|
328
|
-
* This inline assembly hack forces acc into a normal register. This is the
|
|
329
|
-
* only thing that prevents GCC and Clang from autovectorizing the XXH32 loop
|
|
330
|
-
* (pragmas and attributes don't work for some resason) without globally
|
|
331
|
-
* disabling SSE4.1.
|
|
332
|
-
*
|
|
333
|
-
* The reason we want to avoid vectorization is because despite working on
|
|
334
|
-
* 4 integers at a time, there are multiple factors slowing XXH32 down on
|
|
335
|
-
* SSE4:
|
|
336
|
-
* - There's a ridiculous amount of lag from pmulld (10 cycles of latency on newer chips!)
|
|
337
|
-
* making it slightly slower to multiply four integers at once compared to four
|
|
338
|
-
* integers independently. Even when pmulld was fastest, Sandy/Ivy Bridge, it is
|
|
339
|
-
* still not worth it to go into SSE just to multiply unless doing a long operation.
|
|
340
|
-
*
|
|
341
|
-
* - Four instructions are required to rotate,
|
|
342
|
-
* movqda tmp, v // not required with VEX encoding
|
|
343
|
-
* pslld tmp, 13 // tmp <<= 13
|
|
344
|
-
* psrld v, 19 // x >>= 19
|
|
345
|
-
* por v, tmp // x |= tmp
|
|
346
|
-
* compared to one for scalar:
|
|
347
|
-
* roll v, 13 // reliably fast across the board
|
|
348
|
-
* shldl v, v, 13 // Sandy Bridge and later prefer this for some reason
|
|
349
|
-
*
|
|
350
|
-
* - Instruction level parallelism is actually more beneficial here because the
|
|
351
|
-
* SIMD actually serializes this operation: While v1 is rotating, v2 can load data,
|
|
352
|
-
* while v3 can multiply. SSE forces them to operate together.
|
|
353
|
-
*
|
|
354
|
-
* How this hack works:
|
|
355
|
-
* __asm__("" // Declare an assembly block but don't declare any instructions
|
|
356
|
-
* : // However, as an Input/Output Operand,
|
|
357
|
-
* "+r" // constrain a read/write operand (+) as a general purpose register (r).
|
|
358
|
-
* (acc) // and set acc as the operand
|
|
359
|
-
* );
|
|
360
|
-
*
|
|
361
|
-
* Because of the 'r', the compiler has promised that seed will be in a
|
|
362
|
-
* general purpose register and the '+' says that it will be 'read/write',
|
|
363
|
-
* so it has to assume it has changed. It is like volatile without all the
|
|
364
|
-
* loads and stores.
|
|
365
|
-
*
|
|
366
|
-
* Since the argument has to be in a normal register (not an SSE register),
|
|
367
|
-
* each time XXH32_round is called, it is impossible to vectorize. */
|
|
368
|
-
__asm__("" : "+r" (acc));
|
|
369
|
-
#endif
|
|
370
|
-
return acc;
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
/* mix all bits */
|
|
374
|
-
static xxh_u32 XXH32_avalanche(xxh_u32 h32)
|
|
375
|
-
{
|
|
376
|
-
h32 ^= h32 >> 15;
|
|
377
|
-
h32 *= PRIME32_2;
|
|
378
|
-
h32 ^= h32 >> 13;
|
|
379
|
-
h32 *= PRIME32_3;
|
|
380
|
-
h32 ^= h32 >> 16;
|
|
381
|
-
return(h32);
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
#define XXH_get32bits(p) XXH_readLE32_align(p, align)
|
|
385
|
-
|
|
386
|
-
static xxh_u32
|
|
387
|
-
XXH32_finalize(xxh_u32 h32, const xxh_u8* ptr, size_t len, XXH_alignment align)
|
|
388
|
-
{
|
|
389
|
-
#define PROCESS1 \
|
|
390
|
-
h32 += (*ptr++) * PRIME32_5; \
|
|
391
|
-
h32 = XXH_rotl32(h32, 11) * PRIME32_1 ;
|
|
392
|
-
|
|
393
|
-
#define PROCESS4 \
|
|
394
|
-
h32 += XXH_get32bits(ptr) * PRIME32_3; \
|
|
395
|
-
ptr+=4; \
|
|
396
|
-
h32 = XXH_rotl32(h32, 17) * PRIME32_4 ;
|
|
397
|
-
|
|
398
|
-
/* Compact rerolled version */
|
|
399
|
-
if (XXH_REROLL) {
|
|
400
|
-
len &= 15;
|
|
401
|
-
while (len >= 4) {
|
|
402
|
-
PROCESS4;
|
|
403
|
-
len -= 4;
|
|
404
|
-
}
|
|
405
|
-
while (len > 0) {
|
|
406
|
-
PROCESS1;
|
|
407
|
-
--len;
|
|
408
|
-
}
|
|
409
|
-
return XXH32_avalanche(h32);
|
|
410
|
-
} else {
|
|
411
|
-
switch(len&15) /* or switch(bEnd - p) */ {
|
|
412
|
-
case 12: PROCESS4;
|
|
413
|
-
FALLTHROUGH_INTENDED;
|
|
414
|
-
/* fallthrough */
|
|
415
|
-
case 8: PROCESS4;
|
|
416
|
-
FALLTHROUGH_INTENDED;
|
|
417
|
-
/* fallthrough */
|
|
418
|
-
case 4: PROCESS4;
|
|
419
|
-
return XXH32_avalanche(h32);
|
|
420
|
-
|
|
421
|
-
case 13: PROCESS4;
|
|
422
|
-
FALLTHROUGH_INTENDED;
|
|
423
|
-
/* fallthrough */
|
|
424
|
-
case 9: PROCESS4;
|
|
425
|
-
FALLTHROUGH_INTENDED;
|
|
426
|
-
/* fallthrough */
|
|
427
|
-
case 5: PROCESS4;
|
|
428
|
-
PROCESS1;
|
|
429
|
-
return XXH32_avalanche(h32);
|
|
430
|
-
|
|
431
|
-
case 14: PROCESS4;
|
|
432
|
-
FALLTHROUGH_INTENDED;
|
|
433
|
-
/* fallthrough */
|
|
434
|
-
case 10: PROCESS4;
|
|
435
|
-
FALLTHROUGH_INTENDED;
|
|
436
|
-
/* fallthrough */
|
|
437
|
-
case 6: PROCESS4;
|
|
438
|
-
PROCESS1;
|
|
439
|
-
PROCESS1;
|
|
440
|
-
return XXH32_avalanche(h32);
|
|
441
|
-
|
|
442
|
-
case 15: PROCESS4;
|
|
443
|
-
FALLTHROUGH_INTENDED;
|
|
444
|
-
/* fallthrough */
|
|
445
|
-
case 11: PROCESS4;
|
|
446
|
-
FALLTHROUGH_INTENDED;
|
|
447
|
-
/* fallthrough */
|
|
448
|
-
case 7: PROCESS4;
|
|
449
|
-
FALLTHROUGH_INTENDED;
|
|
450
|
-
/* fallthrough */
|
|
451
|
-
case 3: PROCESS1;
|
|
452
|
-
FALLTHROUGH_INTENDED;
|
|
453
|
-
/* fallthrough */
|
|
454
|
-
case 2: PROCESS1;
|
|
455
|
-
FALLTHROUGH_INTENDED;
|
|
456
|
-
/* fallthrough */
|
|
457
|
-
case 1: PROCESS1;
|
|
458
|
-
FALLTHROUGH_INTENDED;
|
|
459
|
-
/* fallthrough */
|
|
460
|
-
case 0: return XXH32_avalanche(h32);
|
|
461
|
-
}
|
|
462
|
-
XXH_ASSERT(0);
|
|
463
|
-
return h32; /* reaching this point is deemed impossible */
|
|
464
|
-
}
|
|
465
|
-
}
|
|
466
|
-
|
|
467
|
-
XXH_FORCE_INLINE xxh_u32
|
|
468
|
-
XXH32_endian_align(const xxh_u8* input, size_t len, xxh_u32 seed, XXH_alignment align)
|
|
469
|
-
{
|
|
470
|
-
const xxh_u8* bEnd = input + len;
|
|
471
|
-
xxh_u32 h32;
|
|
472
|
-
|
|
473
|
-
#if defined(XXH_ACCEPT_NULL_INPUT_POINTER) && (XXH_ACCEPT_NULL_INPUT_POINTER>=1)
|
|
474
|
-
if (input==NULL) {
|
|
475
|
-
len=0;
|
|
476
|
-
bEnd=input=(const xxh_u8*)(size_t)16;
|
|
477
|
-
}
|
|
478
|
-
#endif
|
|
479
|
-
|
|
480
|
-
if (len>=16) {
|
|
481
|
-
const xxh_u8* const limit = bEnd - 15;
|
|
482
|
-
xxh_u32 v1 = seed + PRIME32_1 + PRIME32_2;
|
|
483
|
-
xxh_u32 v2 = seed + PRIME32_2;
|
|
484
|
-
xxh_u32 v3 = seed + 0;
|
|
485
|
-
xxh_u32 v4 = seed - PRIME32_1;
|
|
486
|
-
|
|
487
|
-
do {
|
|
488
|
-
v1 = XXH32_round(v1, XXH_get32bits(input)); input += 4;
|
|
489
|
-
v2 = XXH32_round(v2, XXH_get32bits(input)); input += 4;
|
|
490
|
-
v3 = XXH32_round(v3, XXH_get32bits(input)); input += 4;
|
|
491
|
-
v4 = XXH32_round(v4, XXH_get32bits(input)); input += 4;
|
|
492
|
-
} while (input < limit);
|
|
493
|
-
|
|
494
|
-
h32 = XXH_rotl32(v1, 1) + XXH_rotl32(v2, 7)
|
|
495
|
-
+ XXH_rotl32(v3, 12) + XXH_rotl32(v4, 18);
|
|
496
|
-
} else {
|
|
497
|
-
h32 = seed + PRIME32_5;
|
|
498
|
-
}
|
|
499
|
-
|
|
500
|
-
h32 += (xxh_u32)len;
|
|
501
|
-
|
|
502
|
-
return XXH32_finalize(h32, input, len&15, align);
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
XXH_PUBLIC_API XXH32_hash_t XXH32 (const void* input, size_t len, XXH32_hash_t seed)
|
|
507
|
-
{
|
|
508
|
-
#if 0
|
|
509
|
-
/* Simple version, good for code maintenance, but unfortunately slow for small inputs */
|
|
510
|
-
XXH32_state_t state;
|
|
511
|
-
XXH32_reset(&state, seed);
|
|
512
|
-
XXH32_update(&state, (const xxh_u8*)input, len);
|
|
513
|
-
return XXH32_digest(&state);
|
|
514
|
-
|
|
515
|
-
#else
|
|
516
|
-
|
|
517
|
-
if (XXH_FORCE_ALIGN_CHECK) {
|
|
518
|
-
if ((((size_t)input) & 3) == 0) { /* Input is 4-bytes aligned, leverage the speed benefit */
|
|
519
|
-
return XXH32_endian_align((const xxh_u8*)input, len, seed, XXH_aligned);
|
|
520
|
-
} }
|
|
521
|
-
|
|
522
|
-
return XXH32_endian_align((const xxh_u8*)input, len, seed, XXH_unaligned);
|
|
523
|
-
#endif
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
/*====== Hash streaming ======*/
|
|
529
|
-
|
|
530
|
-
XXH_PUBLIC_API XXH32_state_t* XXH32_createState(void)
|
|
531
|
-
{
|
|
532
|
-
return (XXH32_state_t*)XXH_malloc(sizeof(XXH32_state_t));
|
|
533
|
-
}
|
|
534
|
-
XXH_PUBLIC_API XXH_errorcode XXH32_freeState(XXH32_state_t* statePtr)
|
|
535
|
-
{
|
|
536
|
-
XXH_free(statePtr);
|
|
537
|
-
return XXH_OK;
|
|
538
|
-
}
|
|
539
|
-
|
|
540
|
-
XXH_PUBLIC_API void XXH32_copyState(XXH32_state_t* dstState, const XXH32_state_t* srcState)
|
|
541
|
-
{
|
|
542
|
-
memcpy(dstState, srcState, sizeof(*dstState));
|
|
543
|
-
}
|
|
544
|
-
|
|
545
|
-
XXH_PUBLIC_API XXH_errorcode XXH32_reset(XXH32_state_t* statePtr, XXH32_hash_t seed)
|
|
546
|
-
{
|
|
547
|
-
XXH32_state_t state; /* using a local state to memcpy() in order to avoid strict-aliasing warnings */
|
|
548
|
-
memset(&state, 0, sizeof(state));
|
|
549
|
-
state.v1 = seed + PRIME32_1 + PRIME32_2;
|
|
550
|
-
state.v2 = seed + PRIME32_2;
|
|
551
|
-
state.v3 = seed + 0;
|
|
552
|
-
state.v4 = seed - PRIME32_1;
|
|
553
|
-
/* do not write into reserved, planned to be removed in a future version */
|
|
554
|
-
memcpy(statePtr, &state, sizeof(state) - sizeof(state.reserved));
|
|
555
|
-
return XXH_OK;
|
|
556
|
-
}
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
XXH_PUBLIC_API XXH_errorcode
|
|
560
|
-
XXH32_update(XXH32_state_t* state, const void* input, size_t len)
|
|
561
|
-
{
|
|
562
|
-
if (input==NULL)
|
|
563
|
-
#if defined(XXH_ACCEPT_NULL_INPUT_POINTER) && (XXH_ACCEPT_NULL_INPUT_POINTER>=1)
|
|
564
|
-
return XXH_OK;
|
|
565
|
-
#else
|
|
566
|
-
return XXH_ERROR;
|
|
567
|
-
#endif
|
|
568
|
-
|
|
569
|
-
{ const xxh_u8* p = (const xxh_u8*)input;
|
|
570
|
-
const xxh_u8* const bEnd = p + len;
|
|
571
|
-
|
|
572
|
-
state->total_len_32 += (XXH32_hash_t)len;
|
|
573
|
-
state->large_len |= (XXH32_hash_t)((len>=16) | (state->total_len_32>=16));
|
|
574
|
-
|
|
575
|
-
if (state->memsize + len < 16) { /* fill in tmp buffer */
|
|
576
|
-
XXH_memcpy((xxh_u8*)(state->mem32) + state->memsize, input, len);
|
|
577
|
-
state->memsize += (XXH32_hash_t)len;
|
|
578
|
-
return XXH_OK;
|
|
579
|
-
}
|
|
580
|
-
|
|
581
|
-
if (state->memsize) { /* some data left from previous update */
|
|
582
|
-
XXH_memcpy((xxh_u8*)(state->mem32) + state->memsize, input, 16-state->memsize);
|
|
583
|
-
{ const xxh_u32* p32 = state->mem32;
|
|
584
|
-
state->v1 = XXH32_round(state->v1, XXH_readLE32(p32)); p32++;
|
|
585
|
-
state->v2 = XXH32_round(state->v2, XXH_readLE32(p32)); p32++;
|
|
586
|
-
state->v3 = XXH32_round(state->v3, XXH_readLE32(p32)); p32++;
|
|
587
|
-
state->v4 = XXH32_round(state->v4, XXH_readLE32(p32));
|
|
588
|
-
}
|
|
589
|
-
p += 16-state->memsize;
|
|
590
|
-
state->memsize = 0;
|
|
591
|
-
}
|
|
592
|
-
|
|
593
|
-
// uintptr_t casts added to avoid array-bounds error on
|
|
594
|
-
// some inlined calls
|
|
595
|
-
if ((uintptr_t)p <= (uintptr_t)bEnd - 16) {
|
|
596
|
-
const uintptr_t limit = (uintptr_t)bEnd - 16;
|
|
597
|
-
xxh_u32 v1 = state->v1;
|
|
598
|
-
xxh_u32 v2 = state->v2;
|
|
599
|
-
xxh_u32 v3 = state->v3;
|
|
600
|
-
xxh_u32 v4 = state->v4;
|
|
601
|
-
|
|
602
|
-
do {
|
|
603
|
-
v1 = XXH32_round(v1, XXH_readLE32(p)); p+=4;
|
|
604
|
-
v2 = XXH32_round(v2, XXH_readLE32(p)); p+=4;
|
|
605
|
-
v3 = XXH32_round(v3, XXH_readLE32(p)); p+=4;
|
|
606
|
-
v4 = XXH32_round(v4, XXH_readLE32(p)); p+=4;
|
|
607
|
-
} while ((uintptr_t)p <= limit);
|
|
608
|
-
|
|
609
|
-
state->v1 = v1;
|
|
610
|
-
state->v2 = v2;
|
|
611
|
-
state->v3 = v3;
|
|
612
|
-
state->v4 = v4;
|
|
613
|
-
}
|
|
614
|
-
|
|
615
|
-
if (p < bEnd) {
|
|
616
|
-
XXH_memcpy(state->mem32, p, (size_t)(bEnd-p));
|
|
617
|
-
state->memsize = (unsigned)(bEnd-p);
|
|
618
|
-
}
|
|
619
|
-
}
|
|
620
|
-
|
|
621
|
-
return XXH_OK;
|
|
622
|
-
}
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
XXH_PUBLIC_API XXH32_hash_t XXH32_digest (const XXH32_state_t* state)
|
|
626
|
-
{
|
|
627
|
-
xxh_u32 h32;
|
|
628
|
-
|
|
629
|
-
if (state->large_len) {
|
|
630
|
-
h32 = XXH_rotl32(state->v1, 1)
|
|
631
|
-
+ XXH_rotl32(state->v2, 7)
|
|
632
|
-
+ XXH_rotl32(state->v3, 12)
|
|
633
|
-
+ XXH_rotl32(state->v4, 18);
|
|
634
|
-
} else {
|
|
635
|
-
h32 = state->v3 /* == seed */ + PRIME32_5;
|
|
636
|
-
}
|
|
637
|
-
|
|
638
|
-
h32 += state->total_len_32;
|
|
639
|
-
|
|
640
|
-
return XXH32_finalize(h32, (const xxh_u8*)state->mem32, state->memsize, XXH_aligned);
|
|
641
|
-
}
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
/*====== Canonical representation ======*/
|
|
645
|
-
|
|
646
|
-
/*! Default XXH result types are basic unsigned 32 and 64 bits.
|
|
647
|
-
* The canonical representation follows human-readable write convention, aka big-endian (large digits first).
|
|
648
|
-
* These functions allow transformation of hash result into and from its canonical format.
|
|
649
|
-
* This way, hash values can be written into a file or buffer, remaining comparable across different systems.
|
|
650
|
-
*/
|
|
651
|
-
|
|
652
|
-
XXH_PUBLIC_API void XXH32_canonicalFromHash(XXH32_canonical_t* dst, XXH32_hash_t hash)
|
|
653
|
-
{
|
|
654
|
-
XXH_STATIC_ASSERT(sizeof(XXH32_canonical_t) == sizeof(XXH32_hash_t));
|
|
655
|
-
if (XXH_CPU_LITTLE_ENDIAN) hash = XXH_swap32(hash);
|
|
656
|
-
memcpy(dst, &hash, sizeof(*dst));
|
|
657
|
-
}
|
|
658
|
-
|
|
659
|
-
XXH_PUBLIC_API XXH32_hash_t XXH32_hashFromCanonical(const XXH32_canonical_t* src)
|
|
660
|
-
{
|
|
661
|
-
return XXH_readBE32(src);
|
|
662
|
-
}
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
#ifndef XXH_NO_LONG_LONG
|
|
666
|
-
|
|
667
|
-
/* *******************************************************************
|
|
668
|
-
* 64-bit hash functions
|
|
669
|
-
*********************************************************************/
|
|
670
|
-
|
|
671
|
-
/*====== Memory access ======*/
|
|
672
|
-
|
|
673
|
-
typedef XXH64_hash_t xxh_u64;
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
/*! XXH_REROLL_XXH64:
|
|
677
|
-
* Whether to reroll the XXH64_finalize() loop.
|
|
9
|
+
* BSD 2-Clause License (https://www.opensource.org/licenses/bsd-license.php)
|
|
678
10
|
*
|
|
679
|
-
*
|
|
680
|
-
*
|
|
11
|
+
* Redistribution and use in source and binary forms, with or without
|
|
12
|
+
* modification, are permitted provided that the following conditions are
|
|
13
|
+
* met:
|
|
681
14
|
*
|
|
682
|
-
*
|
|
683
|
-
*
|
|
684
|
-
*
|
|
685
|
-
*
|
|
686
|
-
*
|
|
15
|
+
* * Redistributions of source code must retain the above copyright
|
|
16
|
+
* notice, this list of conditions and the following disclaimer.
|
|
17
|
+
* * Redistributions in binary form must reproduce the above
|
|
18
|
+
* copyright notice, this list of conditions and the following disclaimer
|
|
19
|
+
* in the documentation and/or other materials provided with the
|
|
20
|
+
* distribution.
|
|
687
21
|
*
|
|
688
|
-
*
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
/* Force direct memory access. Only works on CPU which support unaligned memory access in hardware */
|
|
705
|
-
static xxh_u64 XXH_read64(const void* memPtr) { return *(const xxh_u64*) memPtr; }
|
|
706
|
-
|
|
707
|
-
#elif (defined(XXH_FORCE_MEMORY_ACCESS) && (XXH_FORCE_MEMORY_ACCESS==1))
|
|
708
|
-
|
|
709
|
-
/* __pack instructions are safer, but compiler specific, hence potentially problematic for some compilers */
|
|
710
|
-
/* currently only defined for gcc and icc */
|
|
711
|
-
typedef union { xxh_u32 u32; xxh_u64 u64; } __attribute__((packed)) unalign64;
|
|
712
|
-
static xxh_u64 XXH_read64(const void* ptr) { return ((const unalign64*)ptr)->u64; }
|
|
713
|
-
|
|
714
|
-
#else
|
|
715
|
-
|
|
716
|
-
/* portable and safe solution. Generally efficient.
|
|
717
|
-
* see : http://stackoverflow.com/a/32095106/646947
|
|
22
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
23
|
+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
24
|
+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
25
|
+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
26
|
+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
27
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
28
|
+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
29
|
+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
30
|
+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
31
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
32
|
+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
33
|
+
*
|
|
34
|
+
* You can contact the author at:
|
|
35
|
+
* - xxHash homepage: https://www.xxhash.com
|
|
36
|
+
* - xxHash source repository: https://github.com/Cyan4973/xxHash
|
|
718
37
|
*/
|
|
719
38
|
|
|
720
|
-
static xxh_u64 XXH_read64(const void* memPtr)
|
|
721
|
-
{
|
|
722
|
-
xxh_u64 val;
|
|
723
|
-
memcpy(&val, memPtr, sizeof(val));
|
|
724
|
-
return val;
|
|
725
|
-
}
|
|
726
|
-
|
|
727
|
-
#endif /* XXH_FORCE_DIRECT_MEMORY_ACCESS */
|
|
728
|
-
|
|
729
|
-
#if defined(_MSC_VER) /* Visual Studio */
|
|
730
|
-
# define XXH_swap64 _byteswap_uint64
|
|
731
|
-
#elif XXH_GCC_VERSION >= 403
|
|
732
|
-
# define XXH_swap64 __builtin_bswap64
|
|
733
|
-
#else
|
|
734
|
-
static xxh_u64 XXH_swap64 (xxh_u64 x)
|
|
735
|
-
{
|
|
736
|
-
return ((x << 56) & 0xff00000000000000ULL) |
|
|
737
|
-
((x << 40) & 0x00ff000000000000ULL) |
|
|
738
|
-
((x << 24) & 0x0000ff0000000000ULL) |
|
|
739
|
-
((x << 8) & 0x000000ff00000000ULL) |
|
|
740
|
-
((x >> 8) & 0x00000000ff000000ULL) |
|
|
741
|
-
((x >> 24) & 0x0000000000ff0000ULL) |
|
|
742
|
-
((x >> 40) & 0x000000000000ff00ULL) |
|
|
743
|
-
((x >> 56) & 0x00000000000000ffULL);
|
|
744
|
-
}
|
|
745
|
-
#endif
|
|
746
|
-
|
|
747
|
-
XXH_FORCE_INLINE xxh_u64 XXH_readLE64(const void* ptr)
|
|
748
|
-
{
|
|
749
|
-
return XXH_CPU_LITTLE_ENDIAN ? XXH_read64(ptr) : XXH_swap64(XXH_read64(ptr));
|
|
750
|
-
}
|
|
751
|
-
|
|
752
|
-
static xxh_u64 XXH_readBE64(const void* ptr)
|
|
753
|
-
{
|
|
754
|
-
return XXH_CPU_LITTLE_ENDIAN ? XXH_swap64(XXH_read64(ptr)) : XXH_read64(ptr);
|
|
755
|
-
}
|
|
756
|
-
|
|
757
|
-
XXH_FORCE_INLINE xxh_u64
|
|
758
|
-
XXH_readLE64_align(const void* ptr, XXH_alignment align)
|
|
759
|
-
{
|
|
760
|
-
if (align==XXH_unaligned)
|
|
761
|
-
return XXH_readLE64(ptr);
|
|
762
|
-
else
|
|
763
|
-
return XXH_CPU_LITTLE_ENDIAN ? *(const xxh_u64*)ptr : XXH_swap64(*(const xxh_u64*)ptr);
|
|
764
|
-
}
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
/*====== xxh64 ======*/
|
|
768
|
-
|
|
769
|
-
static const xxh_u64 PRIME64_1 = 0x9E3779B185EBCA87ULL; /* 0b1001111000110111011110011011000110000101111010111100101010000111 */
|
|
770
|
-
static const xxh_u64 PRIME64_2 = 0xC2B2AE3D27D4EB4FULL; /* 0b1100001010110010101011100011110100100111110101001110101101001111 */
|
|
771
|
-
static const xxh_u64 PRIME64_3 = 0x165667B19E3779F9ULL; /* 0b0001011001010110011001111011000110011110001101110111100111111001 */
|
|
772
|
-
static const xxh_u64 PRIME64_4 = 0x85EBCA77C2B2AE63ULL; /* 0b1000010111101011110010100111011111000010101100101010111001100011 */
|
|
773
|
-
static const xxh_u64 PRIME64_5 = 0x27D4EB2F165667C5ULL; /* 0b0010011111010100111010110010111100010110010101100110011111000101 */
|
|
774
|
-
|
|
775
|
-
static xxh_u64 XXH64_round(xxh_u64 acc, xxh_u64 input)
|
|
776
|
-
{
|
|
777
|
-
acc += input * PRIME64_2;
|
|
778
|
-
acc = XXH_rotl64(acc, 31);
|
|
779
|
-
acc *= PRIME64_1;
|
|
780
|
-
return acc;
|
|
781
|
-
}
|
|
782
|
-
|
|
783
|
-
static xxh_u64 XXH64_mergeRound(xxh_u64 acc, xxh_u64 val)
|
|
784
|
-
{
|
|
785
|
-
val = XXH64_round(0, val);
|
|
786
|
-
acc ^= val;
|
|
787
|
-
acc = acc * PRIME64_1 + PRIME64_4;
|
|
788
|
-
return acc;
|
|
789
|
-
}
|
|
790
|
-
|
|
791
|
-
static xxh_u64 XXH64_avalanche(xxh_u64 h64)
|
|
792
|
-
{
|
|
793
|
-
h64 ^= h64 >> 33;
|
|
794
|
-
h64 *= PRIME64_2;
|
|
795
|
-
h64 ^= h64 >> 29;
|
|
796
|
-
h64 *= PRIME64_3;
|
|
797
|
-
h64 ^= h64 >> 32;
|
|
798
|
-
return h64;
|
|
799
|
-
}
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
#define XXH_get64bits(p) XXH_readLE64_align(p, align)
|
|
803
|
-
|
|
804
|
-
static xxh_u64
|
|
805
|
-
XXH64_finalize(xxh_u64 h64, const xxh_u8* ptr, size_t len, XXH_alignment align)
|
|
806
|
-
{
|
|
807
|
-
#define PROCESS1_64 \
|
|
808
|
-
h64 ^= (*ptr++) * PRIME64_5; \
|
|
809
|
-
h64 = XXH_rotl64(h64, 11) * PRIME64_1;
|
|
810
|
-
|
|
811
|
-
#define PROCESS4_64 \
|
|
812
|
-
h64 ^= (xxh_u64)(XXH_get32bits(ptr)) * PRIME64_1; \
|
|
813
|
-
ptr+=4; \
|
|
814
|
-
h64 = XXH_rotl64(h64, 23) * PRIME64_2 + PRIME64_3;
|
|
815
|
-
|
|
816
|
-
#define PROCESS8_64 { \
|
|
817
|
-
xxh_u64 const k1 = XXH64_round(0, XXH_get64bits(ptr)); \
|
|
818
|
-
ptr+=8; \
|
|
819
|
-
h64 ^= k1; \
|
|
820
|
-
h64 = XXH_rotl64(h64,27) * PRIME64_1 + PRIME64_4; \
|
|
821
|
-
}
|
|
822
|
-
|
|
823
|
-
/* Rerolled version for 32-bit targets is faster and much smaller. */
|
|
824
|
-
if (XXH_REROLL || XXH_REROLL_XXH64) {
|
|
825
|
-
len &= 31;
|
|
826
|
-
while (len >= 8) {
|
|
827
|
-
PROCESS8_64;
|
|
828
|
-
len -= 8;
|
|
829
|
-
}
|
|
830
|
-
if (len >= 4) {
|
|
831
|
-
PROCESS4_64;
|
|
832
|
-
len -= 4;
|
|
833
|
-
}
|
|
834
|
-
while (len > 0) {
|
|
835
|
-
PROCESS1_64;
|
|
836
|
-
--len;
|
|
837
|
-
}
|
|
838
|
-
return XXH64_avalanche(h64);
|
|
839
|
-
} else {
|
|
840
|
-
switch(len & 31) {
|
|
841
|
-
case 24: PROCESS8_64;
|
|
842
|
-
FALLTHROUGH_INTENDED;
|
|
843
|
-
/* fallthrough */
|
|
844
|
-
case 16: PROCESS8_64;
|
|
845
|
-
FALLTHROUGH_INTENDED;
|
|
846
|
-
/* fallthrough */
|
|
847
|
-
case 8: PROCESS8_64;
|
|
848
|
-
return XXH64_avalanche(h64);
|
|
849
|
-
|
|
850
|
-
case 28: PROCESS8_64;
|
|
851
|
-
FALLTHROUGH_INTENDED;
|
|
852
|
-
/* fallthrough */
|
|
853
|
-
case 20: PROCESS8_64;
|
|
854
|
-
FALLTHROUGH_INTENDED;
|
|
855
|
-
/* fallthrough */
|
|
856
|
-
case 12: PROCESS8_64;
|
|
857
|
-
FALLTHROUGH_INTENDED;
|
|
858
|
-
/* fallthrough */
|
|
859
|
-
case 4: PROCESS4_64;
|
|
860
|
-
return XXH64_avalanche(h64);
|
|
861
|
-
|
|
862
|
-
case 25: PROCESS8_64;
|
|
863
|
-
FALLTHROUGH_INTENDED;
|
|
864
|
-
/* fallthrough */
|
|
865
|
-
case 17: PROCESS8_64;
|
|
866
|
-
FALLTHROUGH_INTENDED;
|
|
867
|
-
/* fallthrough */
|
|
868
|
-
case 9: PROCESS8_64;
|
|
869
|
-
PROCESS1_64;
|
|
870
|
-
return XXH64_avalanche(h64);
|
|
871
|
-
|
|
872
|
-
case 29: PROCESS8_64;
|
|
873
|
-
FALLTHROUGH_INTENDED;
|
|
874
|
-
/* fallthrough */
|
|
875
|
-
case 21: PROCESS8_64;
|
|
876
|
-
FALLTHROUGH_INTENDED;
|
|
877
|
-
/* fallthrough */
|
|
878
|
-
case 13: PROCESS8_64;
|
|
879
|
-
FALLTHROUGH_INTENDED;
|
|
880
|
-
/* fallthrough */
|
|
881
|
-
case 5: PROCESS4_64;
|
|
882
|
-
PROCESS1_64;
|
|
883
|
-
return XXH64_avalanche(h64);
|
|
884
|
-
|
|
885
|
-
case 26: PROCESS8_64;
|
|
886
|
-
FALLTHROUGH_INTENDED;
|
|
887
|
-
/* fallthrough */
|
|
888
|
-
case 18: PROCESS8_64;
|
|
889
|
-
FALLTHROUGH_INTENDED;
|
|
890
|
-
/* fallthrough */
|
|
891
|
-
case 10: PROCESS8_64;
|
|
892
|
-
PROCESS1_64;
|
|
893
|
-
PROCESS1_64;
|
|
894
|
-
return XXH64_avalanche(h64);
|
|
895
|
-
|
|
896
|
-
case 30: PROCESS8_64;
|
|
897
|
-
FALLTHROUGH_INTENDED;
|
|
898
|
-
/* fallthrough */
|
|
899
|
-
case 22: PROCESS8_64;
|
|
900
|
-
FALLTHROUGH_INTENDED;
|
|
901
|
-
/* fallthrough */
|
|
902
|
-
case 14: PROCESS8_64;
|
|
903
|
-
FALLTHROUGH_INTENDED;
|
|
904
|
-
/* fallthrough */
|
|
905
|
-
case 6: PROCESS4_64;
|
|
906
|
-
PROCESS1_64;
|
|
907
|
-
PROCESS1_64;
|
|
908
|
-
return XXH64_avalanche(h64);
|
|
909
|
-
|
|
910
|
-
case 27: PROCESS8_64;
|
|
911
|
-
FALLTHROUGH_INTENDED;
|
|
912
|
-
/* fallthrough */
|
|
913
|
-
case 19: PROCESS8_64;
|
|
914
|
-
FALLTHROUGH_INTENDED;
|
|
915
|
-
/* fallthrough */
|
|
916
|
-
case 11: PROCESS8_64;
|
|
917
|
-
PROCESS1_64;
|
|
918
|
-
PROCESS1_64;
|
|
919
|
-
PROCESS1_64;
|
|
920
|
-
return XXH64_avalanche(h64);
|
|
921
39
|
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
case 23: PROCESS8_64;
|
|
926
|
-
FALLTHROUGH_INTENDED;
|
|
927
|
-
/* fallthrough */
|
|
928
|
-
case 15: PROCESS8_64;
|
|
929
|
-
FALLTHROUGH_INTENDED;
|
|
930
|
-
/* fallthrough */
|
|
931
|
-
case 7: PROCESS4_64;
|
|
932
|
-
FALLTHROUGH_INTENDED;
|
|
933
|
-
/* fallthrough */
|
|
934
|
-
case 3: PROCESS1_64;
|
|
935
|
-
FALLTHROUGH_INTENDED;
|
|
936
|
-
/* fallthrough */
|
|
937
|
-
case 2: PROCESS1_64;
|
|
938
|
-
FALLTHROUGH_INTENDED;
|
|
939
|
-
/* fallthrough */
|
|
940
|
-
case 1: PROCESS1_64;
|
|
941
|
-
FALLTHROUGH_INTENDED;
|
|
942
|
-
/* fallthrough */
|
|
943
|
-
case 0: return XXH64_avalanche(h64);
|
|
944
|
-
}
|
|
945
|
-
}
|
|
946
|
-
/* impossible to reach */
|
|
947
|
-
XXH_ASSERT(0);
|
|
948
|
-
return 0; /* unreachable, but some compilers complain without it */
|
|
949
|
-
}
|
|
950
|
-
|
|
951
|
-
XXH_FORCE_INLINE xxh_u64
|
|
952
|
-
XXH64_endian_align(const xxh_u8* input, size_t len, xxh_u64 seed, XXH_alignment align)
|
|
953
|
-
{
|
|
954
|
-
const xxh_u8* bEnd = input + len;
|
|
955
|
-
xxh_u64 h64;
|
|
956
|
-
|
|
957
|
-
#if defined(XXH_ACCEPT_NULL_INPUT_POINTER) && (XXH_ACCEPT_NULL_INPUT_POINTER>=1)
|
|
958
|
-
if (input==NULL) {
|
|
959
|
-
len=0;
|
|
960
|
-
bEnd=input=(const xxh_u8*)(size_t)32;
|
|
961
|
-
}
|
|
962
|
-
#endif
|
|
963
|
-
|
|
964
|
-
if (len>=32) {
|
|
965
|
-
const xxh_u8* const limit = bEnd - 32;
|
|
966
|
-
xxh_u64 v1 = seed + PRIME64_1 + PRIME64_2;
|
|
967
|
-
xxh_u64 v2 = seed + PRIME64_2;
|
|
968
|
-
xxh_u64 v3 = seed + 0;
|
|
969
|
-
xxh_u64 v4 = seed - PRIME64_1;
|
|
970
|
-
|
|
971
|
-
do {
|
|
972
|
-
v1 = XXH64_round(v1, XXH_get64bits(input)); input+=8;
|
|
973
|
-
v2 = XXH64_round(v2, XXH_get64bits(input)); input+=8;
|
|
974
|
-
v3 = XXH64_round(v3, XXH_get64bits(input)); input+=8;
|
|
975
|
-
v4 = XXH64_round(v4, XXH_get64bits(input)); input+=8;
|
|
976
|
-
} while (input<=limit);
|
|
977
|
-
|
|
978
|
-
h64 = XXH_rotl64(v1, 1) + XXH_rotl64(v2, 7) + XXH_rotl64(v3, 12) + XXH_rotl64(v4, 18);
|
|
979
|
-
h64 = XXH64_mergeRound(h64, v1);
|
|
980
|
-
h64 = XXH64_mergeRound(h64, v2);
|
|
981
|
-
h64 = XXH64_mergeRound(h64, v3);
|
|
982
|
-
h64 = XXH64_mergeRound(h64, v4);
|
|
983
|
-
|
|
984
|
-
} else {
|
|
985
|
-
h64 = seed + PRIME64_5;
|
|
986
|
-
}
|
|
987
|
-
|
|
988
|
-
h64 += (xxh_u64) len;
|
|
989
|
-
|
|
990
|
-
return XXH64_finalize(h64, input, len, align);
|
|
991
|
-
}
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
XXH_PUBLIC_API XXH64_hash_t XXH64 (const void* input, size_t len, XXH64_hash_t seed)
|
|
995
|
-
{
|
|
996
|
-
#if 0
|
|
997
|
-
/* Simple version, good for code maintenance, but unfortunately slow for small inputs */
|
|
998
|
-
XXH64_state_t state;
|
|
999
|
-
XXH64_reset(&state, seed);
|
|
1000
|
-
XXH64_update(&state, (const xxh_u8*)input, len);
|
|
1001
|
-
return XXH64_digest(&state);
|
|
1002
|
-
|
|
1003
|
-
#else
|
|
1004
|
-
|
|
1005
|
-
if (XXH_FORCE_ALIGN_CHECK) {
|
|
1006
|
-
if ((((size_t)input) & 7)==0) { /* Input is aligned, let's leverage the speed advantage */
|
|
1007
|
-
return XXH64_endian_align((const xxh_u8*)input, len, seed, XXH_aligned);
|
|
1008
|
-
} }
|
|
1009
|
-
|
|
1010
|
-
return XXH64_endian_align((const xxh_u8*)input, len, seed, XXH_unaligned);
|
|
1011
|
-
|
|
1012
|
-
#endif
|
|
1013
|
-
}
|
|
1014
|
-
|
|
1015
|
-
/*====== Hash Streaming ======*/
|
|
1016
|
-
|
|
1017
|
-
XXH_PUBLIC_API XXH64_state_t* XXH64_createState(void)
|
|
1018
|
-
{
|
|
1019
|
-
return (XXH64_state_t*)XXH_malloc(sizeof(XXH64_state_t));
|
|
1020
|
-
}
|
|
1021
|
-
XXH_PUBLIC_API XXH_errorcode XXH64_freeState(XXH64_state_t* statePtr)
|
|
1022
|
-
{
|
|
1023
|
-
XXH_free(statePtr);
|
|
1024
|
-
return XXH_OK;
|
|
1025
|
-
}
|
|
1026
|
-
|
|
1027
|
-
XXH_PUBLIC_API void XXH64_copyState(XXH64_state_t* dstState, const XXH64_state_t* srcState)
|
|
1028
|
-
{
|
|
1029
|
-
memcpy(dstState, srcState, sizeof(*dstState));
|
|
1030
|
-
}
|
|
1031
|
-
|
|
1032
|
-
XXH_PUBLIC_API XXH_errorcode XXH64_reset(XXH64_state_t* statePtr, XXH64_hash_t seed)
|
|
1033
|
-
{
|
|
1034
|
-
XXH64_state_t state; /* using a local state to memcpy() in order to avoid strict-aliasing warnings */
|
|
1035
|
-
memset(&state, 0, sizeof(state));
|
|
1036
|
-
state.v1 = seed + PRIME64_1 + PRIME64_2;
|
|
1037
|
-
state.v2 = seed + PRIME64_2;
|
|
1038
|
-
state.v3 = seed + 0;
|
|
1039
|
-
state.v4 = seed - PRIME64_1;
|
|
1040
|
-
/* do not write into reserved64, might be removed in a future version */
|
|
1041
|
-
memcpy(statePtr, &state, sizeof(state) - sizeof(state.reserved64));
|
|
1042
|
-
return XXH_OK;
|
|
1043
|
-
}
|
|
1044
|
-
|
|
1045
|
-
XXH_PUBLIC_API XXH_errorcode
|
|
1046
|
-
XXH64_update (XXH64_state_t* state, const void* input, size_t len)
|
|
1047
|
-
{
|
|
1048
|
-
if (input==NULL)
|
|
1049
|
-
#if defined(XXH_ACCEPT_NULL_INPUT_POINTER) && (XXH_ACCEPT_NULL_INPUT_POINTER>=1)
|
|
1050
|
-
return XXH_OK;
|
|
1051
|
-
#else
|
|
1052
|
-
return XXH_ERROR;
|
|
1053
|
-
#endif
|
|
1054
|
-
|
|
1055
|
-
{ const xxh_u8* p = (const xxh_u8*)input;
|
|
1056
|
-
const xxh_u8* const bEnd = p + len;
|
|
1057
|
-
|
|
1058
|
-
state->total_len += len;
|
|
1059
|
-
|
|
1060
|
-
if (state->memsize + len < 32) { /* fill in tmp buffer */
|
|
1061
|
-
XXH_memcpy(((xxh_u8*)state->mem64) + state->memsize, input, len);
|
|
1062
|
-
state->memsize += (xxh_u32)len;
|
|
1063
|
-
return XXH_OK;
|
|
1064
|
-
}
|
|
1065
|
-
|
|
1066
|
-
if (state->memsize) { /* tmp buffer is full */
|
|
1067
|
-
XXH_memcpy(((xxh_u8*)state->mem64) + state->memsize, input, 32-state->memsize);
|
|
1068
|
-
state->v1 = XXH64_round(state->v1, XXH_readLE64(state->mem64+0));
|
|
1069
|
-
state->v2 = XXH64_round(state->v2, XXH_readLE64(state->mem64+1));
|
|
1070
|
-
state->v3 = XXH64_round(state->v3, XXH_readLE64(state->mem64+2));
|
|
1071
|
-
state->v4 = XXH64_round(state->v4, XXH_readLE64(state->mem64+3));
|
|
1072
|
-
p += 32-state->memsize;
|
|
1073
|
-
state->memsize = 0;
|
|
1074
|
-
}
|
|
1075
|
-
|
|
1076
|
-
// uintptr_t casts added to avoid array-bounds error on
|
|
1077
|
-
// some inlined calls
|
|
1078
|
-
if ((uintptr_t)p + 32 <= (uintptr_t)bEnd) {
|
|
1079
|
-
const uintptr_t limit = (uintptr_t)bEnd - 32;
|
|
1080
|
-
xxh_u64 v1 = state->v1;
|
|
1081
|
-
xxh_u64 v2 = state->v2;
|
|
1082
|
-
xxh_u64 v3 = state->v3;
|
|
1083
|
-
xxh_u64 v4 = state->v4;
|
|
1084
|
-
|
|
1085
|
-
do {
|
|
1086
|
-
v1 = XXH64_round(v1, XXH_readLE64(p)); p+=8;
|
|
1087
|
-
v2 = XXH64_round(v2, XXH_readLE64(p)); p+=8;
|
|
1088
|
-
v3 = XXH64_round(v3, XXH_readLE64(p)); p+=8;
|
|
1089
|
-
v4 = XXH64_round(v4, XXH_readLE64(p)); p+=8;
|
|
1090
|
-
} while ((uintptr_t)p <= limit);
|
|
1091
|
-
|
|
1092
|
-
state->v1 = v1;
|
|
1093
|
-
state->v2 = v2;
|
|
1094
|
-
state->v3 = v3;
|
|
1095
|
-
state->v4 = v4;
|
|
1096
|
-
}
|
|
1097
|
-
|
|
1098
|
-
if (p < bEnd) {
|
|
1099
|
-
XXH_memcpy(state->mem64, p, (size_t)(bEnd-p));
|
|
1100
|
-
state->memsize = (unsigned)(bEnd-p);
|
|
1101
|
-
}
|
|
1102
|
-
}
|
|
1103
|
-
|
|
1104
|
-
return XXH_OK;
|
|
1105
|
-
}
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
XXH_PUBLIC_API XXH64_hash_t XXH64_digest (const XXH64_state_t* state)
|
|
1109
|
-
{
|
|
1110
|
-
xxh_u64 h64;
|
|
1111
|
-
|
|
1112
|
-
if (state->total_len >= 32) {
|
|
1113
|
-
xxh_u64 const v1 = state->v1;
|
|
1114
|
-
xxh_u64 const v2 = state->v2;
|
|
1115
|
-
xxh_u64 const v3 = state->v3;
|
|
1116
|
-
xxh_u64 const v4 = state->v4;
|
|
1117
|
-
|
|
1118
|
-
h64 = XXH_rotl64(v1, 1) + XXH_rotl64(v2, 7) + XXH_rotl64(v3, 12) + XXH_rotl64(v4, 18);
|
|
1119
|
-
h64 = XXH64_mergeRound(h64, v1);
|
|
1120
|
-
h64 = XXH64_mergeRound(h64, v2);
|
|
1121
|
-
h64 = XXH64_mergeRound(h64, v3);
|
|
1122
|
-
h64 = XXH64_mergeRound(h64, v4);
|
|
1123
|
-
} else {
|
|
1124
|
-
h64 = state->v3 /*seed*/ + PRIME64_5;
|
|
1125
|
-
}
|
|
1126
|
-
|
|
1127
|
-
h64 += (xxh_u64) state->total_len;
|
|
1128
|
-
|
|
1129
|
-
return XXH64_finalize(h64, (const xxh_u8*)state->mem64, (size_t)state->total_len, XXH_aligned);
|
|
1130
|
-
}
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
/*====== Canonical representation ======*/
|
|
1134
|
-
|
|
1135
|
-
XXH_PUBLIC_API void XXH64_canonicalFromHash(XXH64_canonical_t* dst, XXH64_hash_t hash)
|
|
1136
|
-
{
|
|
1137
|
-
XXH_STATIC_ASSERT(sizeof(XXH64_canonical_t) == sizeof(XXH64_hash_t));
|
|
1138
|
-
if (XXH_CPU_LITTLE_ENDIAN) hash = XXH_swap64(hash);
|
|
1139
|
-
memcpy(dst, &hash, sizeof(*dst));
|
|
1140
|
-
}
|
|
1141
|
-
|
|
1142
|
-
XXH_PUBLIC_API XXH64_hash_t XXH64_hashFromCanonical(const XXH64_canonical_t* src)
|
|
1143
|
-
{
|
|
1144
|
-
return XXH_readBE64(src);
|
|
1145
|
-
}
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
/* *********************************************************************
|
|
1150
|
-
* XXH3
|
|
1151
|
-
* New generation hash designed for speed on small keys and vectorization
|
|
1152
|
-
************************************************************************ */
|
|
1153
|
-
|
|
1154
|
-
#include "xxh3p.h" /* XXH3 preview for RocksDB */
|
|
40
|
+
/*
|
|
41
|
+
* xxhash.c instantiates functions defined in xxhash.h
|
|
42
|
+
*/
|
|
1155
43
|
|
|
1156
|
-
#
|
|
44
|
+
#ifndef XXH_STATIC_LINKING_ONLY
|
|
45
|
+
#define XXH_STATIC_LINKING_ONLY /* access advanced declarations */
|
|
46
|
+
#endif // !defined(XXH_STATIC_LINKING_ONLY)
|
|
47
|
+
#define XXH_IMPLEMENTATION /* access definitions */
|
|
1157
48
|
|
|
1158
|
-
#
|
|
49
|
+
#include "xxhash.h"
|