multi_compress 0.3.1 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +15 -3
  3. data/GET_STARTED.md +3 -3
  4. data/README.md +75 -66
  5. data/THIRD_PARTY_NOTICES.md +24 -0
  6. data/ext/multi_compress/brotli_dec_static_init.c +3 -0
  7. data/ext/multi_compress/brotli_enc_static_init.c +3 -0
  8. data/ext/multi_compress/extconf.rb +22 -1
  9. data/ext/multi_compress/multi_compress.c +152 -72
  10. data/ext/multi_compress/vendor/.vendored +2 -2
  11. data/ext/multi_compress/vendor/brotli/LICENSE +19 -0
  12. data/ext/multi_compress/vendor/brotli/c/common/constants.c +7 -7
  13. data/ext/multi_compress/vendor/brotli/c/common/constants.h +2 -5
  14. data/ext/multi_compress/vendor/brotli/c/common/context.c +2 -2
  15. data/ext/multi_compress/vendor/brotli/c/common/context.h +1 -2
  16. data/ext/multi_compress/vendor/brotli/c/common/dictionary.c +4 -5856
  17. data/ext/multi_compress/vendor/brotli/c/common/dictionary.h +1 -2
  18. data/ext/multi_compress/vendor/brotli/c/common/dictionary_inc.h +5847 -0
  19. data/ext/multi_compress/vendor/brotli/c/common/platform.c +0 -4
  20. data/ext/multi_compress/vendor/brotli/c/common/platform.h +182 -43
  21. data/ext/multi_compress/vendor/brotli/c/common/shared_dictionary.c +3 -7
  22. data/ext/multi_compress/vendor/brotli/c/common/shared_dictionary_internal.h +1 -1
  23. data/ext/multi_compress/vendor/brotli/c/common/static_init.h +56 -0
  24. data/ext/multi_compress/vendor/brotli/c/common/transform.c +6 -4
  25. data/ext/multi_compress/vendor/brotli/c/common/transform.h +1 -2
  26. data/ext/multi_compress/vendor/brotli/c/common/version.h +3 -3
  27. data/ext/multi_compress/vendor/brotli/c/dec/bit_reader.c +2 -3
  28. data/ext/multi_compress/vendor/brotli/c/dec/bit_reader.h +0 -4
  29. data/ext/multi_compress/vendor/brotli/c/dec/decode.c +128 -39
  30. data/ext/multi_compress/vendor/brotli/c/dec/huffman.c +2 -5
  31. data/ext/multi_compress/vendor/brotli/c/dec/huffman.h +0 -2
  32. data/ext/multi_compress/vendor/brotli/c/dec/prefix.c +67 -0
  33. data/ext/multi_compress/vendor/brotli/c/dec/prefix.h +18 -708
  34. data/ext/multi_compress/vendor/brotli/c/dec/prefix_inc.h +707 -0
  35. data/ext/multi_compress/vendor/brotli/c/dec/state.c +18 -15
  36. data/ext/multi_compress/vendor/brotli/c/dec/state.h +2 -6
  37. data/ext/multi_compress/vendor/brotli/c/dec/static_init.c +53 -0
  38. data/ext/multi_compress/vendor/brotli/c/dec/static_init.h +30 -0
  39. data/ext/multi_compress/vendor/brotli/c/enc/backward_references.c +32 -8
  40. data/ext/multi_compress/vendor/brotli/c/enc/backward_references.h +1 -5
  41. data/ext/multi_compress/vendor/brotli/c/enc/backward_references_hq.c +15 -15
  42. data/ext/multi_compress/vendor/brotli/c/enc/backward_references_hq.h +1 -5
  43. data/ext/multi_compress/vendor/brotli/c/enc/bit_cost.c +28 -4
  44. data/ext/multi_compress/vendor/brotli/c/enc/bit_cost.h +8 -40
  45. data/ext/multi_compress/vendor/brotli/c/enc/bit_cost_inc.h +1 -1
  46. data/ext/multi_compress/vendor/brotli/c/enc/block_splitter.c +9 -12
  47. data/ext/multi_compress/vendor/brotli/c/enc/block_splitter.h +0 -3
  48. data/ext/multi_compress/vendor/brotli/c/enc/block_splitter_inc.h +14 -8
  49. data/ext/multi_compress/vendor/brotli/c/enc/brotli_bit_stream.c +10 -9
  50. data/ext/multi_compress/vendor/brotli/c/enc/brotli_bit_stream.h +0 -6
  51. data/ext/multi_compress/vendor/brotli/c/enc/cluster.c +0 -2
  52. data/ext/multi_compress/vendor/brotli/c/enc/cluster.h +0 -2
  53. data/ext/multi_compress/vendor/brotli/c/enc/command.c +1 -1
  54. data/ext/multi_compress/vendor/brotli/c/enc/command.h +8 -10
  55. data/ext/multi_compress/vendor/brotli/c/enc/compound_dictionary.c +3 -5
  56. data/ext/multi_compress/vendor/brotli/c/enc/compound_dictionary.h +1 -4
  57. data/ext/multi_compress/vendor/brotli/c/enc/compress_fragment.c +3 -13
  58. data/ext/multi_compress/vendor/brotli/c/enc/compress_fragment.h +0 -2
  59. data/ext/multi_compress/vendor/brotli/c/enc/compress_fragment_two_pass.c +5 -15
  60. data/ext/multi_compress/vendor/brotli/c/enc/compress_fragment_two_pass.h +0 -2
  61. data/ext/multi_compress/vendor/brotli/c/enc/dictionary_hash.c +127 -1830
  62. data/ext/multi_compress/vendor/brotli/c/enc/dictionary_hash.h +23 -3
  63. data/ext/multi_compress/vendor/brotli/c/enc/dictionary_hash_inc.h +1829 -0
  64. data/ext/multi_compress/vendor/brotli/c/enc/encode.c +77 -52
  65. data/ext/multi_compress/vendor/brotli/c/enc/encoder_dict.c +9 -7
  66. data/ext/multi_compress/vendor/brotli/c/enc/encoder_dict.h +2 -4
  67. data/ext/multi_compress/vendor/brotli/c/enc/entropy_encode.c +3 -6
  68. data/ext/multi_compress/vendor/brotli/c/enc/entropy_encode.h +2 -4
  69. data/ext/multi_compress/vendor/brotli/c/enc/entropy_encode_static.h +18 -12
  70. data/ext/multi_compress/vendor/brotli/c/enc/fast_log.c +1 -1
  71. data/ext/multi_compress/vendor/brotli/c/enc/fast_log.h +2 -3
  72. data/ext/multi_compress/vendor/brotli/c/enc/find_match_length.h +0 -2
  73. data/ext/multi_compress/vendor/brotli/c/enc/hash.h +38 -31
  74. data/ext/multi_compress/vendor/brotli/c/enc/hash_base.h +38 -0
  75. data/ext/multi_compress/vendor/brotli/c/enc/hash_forgetful_chain_inc.h +11 -1
  76. data/ext/multi_compress/vendor/brotli/c/enc/hash_longest_match64_inc.h +24 -7
  77. data/ext/multi_compress/vendor/brotli/c/enc/hash_longest_match64_simd_inc.h +304 -0
  78. data/ext/multi_compress/vendor/brotli/c/enc/hash_longest_match_inc.h +30 -11
  79. data/ext/multi_compress/vendor/brotli/c/enc/hash_longest_match_quickly_inc.h +4 -0
  80. data/ext/multi_compress/vendor/brotli/c/enc/hash_longest_match_simd_inc.h +278 -0
  81. data/ext/multi_compress/vendor/brotli/c/enc/histogram.c +1 -0
  82. data/ext/multi_compress/vendor/brotli/c/enc/histogram.h +0 -4
  83. data/ext/multi_compress/vendor/brotli/c/enc/literal_cost.c +4 -6
  84. data/ext/multi_compress/vendor/brotli/c/enc/literal_cost.h +0 -2
  85. data/ext/multi_compress/vendor/brotli/c/enc/matching_tag_mask.h +69 -0
  86. data/ext/multi_compress/vendor/brotli/c/enc/memory.c +0 -5
  87. data/ext/multi_compress/vendor/brotli/c/enc/memory.h +0 -4
  88. data/ext/multi_compress/vendor/brotli/c/enc/metablock.c +7 -9
  89. data/ext/multi_compress/vendor/brotli/c/enc/metablock.h +3 -3
  90. data/ext/multi_compress/vendor/brotli/c/enc/metablock_inc.h +4 -4
  91. data/ext/multi_compress/vendor/brotli/c/enc/params.h +0 -1
  92. data/ext/multi_compress/vendor/brotli/c/enc/prefix.h +0 -2
  93. data/ext/multi_compress/vendor/brotli/c/enc/quality.h +17 -10
  94. data/ext/multi_compress/vendor/brotli/c/enc/ringbuffer.h +1 -4
  95. data/ext/multi_compress/vendor/brotli/c/enc/state.h +2 -2
  96. data/ext/multi_compress/vendor/brotli/c/enc/static_dict.c +5 -11
  97. data/ext/multi_compress/vendor/brotli/c/enc/static_dict.h +1 -3
  98. data/ext/multi_compress/vendor/brotli/c/enc/static_dict_lut.c +224 -0
  99. data/ext/multi_compress/vendor/brotli/c/enc/static_dict_lut.h +20 -5837
  100. data/ext/multi_compress/vendor/brotli/c/enc/static_dict_lut_inc.h +5830 -0
  101. data/ext/multi_compress/vendor/brotli/c/enc/static_init.c +59 -0
  102. data/ext/multi_compress/vendor/brotli/c/enc/static_init.h +30 -0
  103. data/ext/multi_compress/vendor/brotli/c/enc/static_init_lazy.cc +26 -0
  104. data/ext/multi_compress/vendor/brotli/c/enc/utf8_util.c +1 -1
  105. data/ext/multi_compress/vendor/brotli/c/enc/utf8_util.h +0 -2
  106. data/ext/multi_compress/vendor/brotli/c/enc/write_bits.h +0 -2
  107. data/ext/multi_compress/vendor/brotli/c/include/brotli/decode.h +1 -1
  108. data/ext/multi_compress/vendor/brotli/c/include/brotli/encode.h +5 -1
  109. data/ext/multi_compress/vendor/brotli/c/include/brotli/port.h +4 -7
  110. data/ext/multi_compress/vendor/brotli/c/include/brotli/types.h +2 -2
  111. data/ext/multi_compress/vendor/lz4/LICENSE +12 -0
  112. data/ext/multi_compress/vendor/zstd/COPYING +339 -0
  113. data/ext/multi_compress/vendor/zstd/LICENSE +30 -0
  114. data/ext/multi_compress/vendor/zstd/lib/Makefile +67 -35
  115. data/ext/multi_compress/vendor/zstd/lib/README.md +33 -2
  116. data/ext/multi_compress/vendor/zstd/lib/common/allocations.h +55 -0
  117. data/ext/multi_compress/vendor/zstd/lib/common/bits.h +205 -0
  118. data/ext/multi_compress/vendor/zstd/lib/common/bitstream.h +84 -108
  119. data/ext/multi_compress/vendor/zstd/lib/common/compiler.h +170 -41
  120. data/ext/multi_compress/vendor/zstd/lib/common/cpu.h +37 -1
  121. data/ext/multi_compress/vendor/zstd/lib/common/debug.c +7 -1
  122. data/ext/multi_compress/vendor/zstd/lib/common/debug.h +21 -21
  123. data/ext/multi_compress/vendor/zstd/lib/common/entropy_common.c +12 -40
  124. data/ext/multi_compress/vendor/zstd/lib/common/error_private.c +10 -2
  125. data/ext/multi_compress/vendor/zstd/lib/common/error_private.h +46 -47
  126. data/ext/multi_compress/vendor/zstd/lib/common/fse.h +8 -100
  127. data/ext/multi_compress/vendor/zstd/lib/common/fse_decompress.c +28 -116
  128. data/ext/multi_compress/vendor/zstd/lib/common/huf.h +79 -166
  129. data/ext/multi_compress/vendor/zstd/lib/common/mem.h +46 -66
  130. data/ext/multi_compress/vendor/zstd/lib/common/pool.c +27 -11
  131. data/ext/multi_compress/vendor/zstd/lib/common/pool.h +8 -11
  132. data/ext/multi_compress/vendor/zstd/lib/common/portability_macros.h +45 -11
  133. data/ext/multi_compress/vendor/zstd/lib/common/threading.c +74 -14
  134. data/ext/multi_compress/vendor/zstd/lib/common/threading.h +5 -18
  135. data/ext/multi_compress/vendor/zstd/lib/common/xxhash.c +5 -11
  136. data/ext/multi_compress/vendor/zstd/lib/common/xxhash.h +2411 -1003
  137. data/ext/multi_compress/vendor/zstd/lib/common/zstd_common.c +1 -36
  138. data/ext/multi_compress/vendor/zstd/lib/common/zstd_deps.h +13 -1
  139. data/ext/multi_compress/vendor/zstd/lib/common/zstd_internal.h +13 -182
  140. data/ext/multi_compress/vendor/zstd/lib/common/zstd_trace.h +6 -13
  141. data/ext/multi_compress/vendor/zstd/lib/compress/clevels.h +1 -1
  142. data/ext/multi_compress/vendor/zstd/lib/compress/fse_compress.c +15 -131
  143. data/ext/multi_compress/vendor/zstd/lib/compress/hist.c +11 -1
  144. data/ext/multi_compress/vendor/zstd/lib/compress/hist.h +8 -1
  145. data/ext/multi_compress/vendor/zstd/lib/compress/huf_compress.c +283 -189
  146. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress.c +2419 -903
  147. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_internal.h +423 -245
  148. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_literals.c +116 -40
  149. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_literals.h +16 -8
  150. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_sequences.c +10 -10
  151. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_sequences.h +8 -7
  152. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_superblock.c +254 -139
  153. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_compress_superblock.h +1 -1
  154. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_cwksp.h +184 -95
  155. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_double_fast.c +163 -81
  156. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_double_fast.h +18 -14
  157. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_fast.c +507 -197
  158. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_fast.h +7 -14
  159. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_lazy.c +579 -484
  160. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_lazy.h +133 -65
  161. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_ldm.c +61 -40
  162. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_ldm.h +7 -15
  163. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_ldm_geartab.h +1 -1
  164. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_opt.c +352 -218
  165. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_opt.h +37 -21
  166. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_preSplit.c +238 -0
  167. data/ext/multi_compress/vendor/zstd/lib/compress/zstd_preSplit.h +33 -0
  168. data/ext/multi_compress/vendor/zstd/lib/compress/zstdmt_compress.c +239 -175
  169. data/ext/multi_compress/vendor/zstd/lib/compress/zstdmt_compress.h +5 -16
  170. data/ext/multi_compress/vendor/zstd/lib/decompress/huf_decompress.c +543 -488
  171. data/ext/multi_compress/vendor/zstd/lib/decompress/huf_decompress_amd64.S +78 -61
  172. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_ddict.c +4 -4
  173. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_ddict.h +1 -1
  174. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_decompress.c +295 -115
  175. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_decompress_block.c +430 -293
  176. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_decompress_block.h +7 -2
  177. data/ext/multi_compress/vendor/zstd/lib/decompress/zstd_decompress_internal.h +11 -7
  178. data/ext/multi_compress/vendor/zstd/lib/deprecated/zbuff.h +1 -1
  179. data/ext/multi_compress/vendor/zstd/lib/deprecated/zbuff_common.c +1 -1
  180. data/ext/multi_compress/vendor/zstd/lib/deprecated/zbuff_compress.c +1 -1
  181. data/ext/multi_compress/vendor/zstd/lib/deprecated/zbuff_decompress.c +3 -1
  182. data/ext/multi_compress/vendor/zstd/lib/dictBuilder/cover.c +95 -46
  183. data/ext/multi_compress/vendor/zstd/lib/dictBuilder/cover.h +3 -9
  184. data/ext/multi_compress/vendor/zstd/lib/dictBuilder/divsufsort.h +0 -10
  185. data/ext/multi_compress/vendor/zstd/lib/dictBuilder/fastcover.c +4 -4
  186. data/ext/multi_compress/vendor/zstd/lib/dictBuilder/zdict.c +25 -97
  187. data/ext/multi_compress/vendor/zstd/lib/dll/example/Makefile +1 -1
  188. data/ext/multi_compress/vendor/zstd/lib/dll/example/README.md +1 -1
  189. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_legacy.h +38 -1
  190. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v01.c +19 -50
  191. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v01.h +1 -1
  192. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v02.c +27 -80
  193. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v02.h +1 -1
  194. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v03.c +28 -83
  195. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v03.h +1 -1
  196. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v04.c +25 -74
  197. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v04.h +1 -1
  198. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v05.c +31 -76
  199. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v05.h +1 -1
  200. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v06.c +44 -88
  201. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v06.h +1 -1
  202. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v07.c +33 -84
  203. data/ext/multi_compress/vendor/zstd/lib/legacy/zstd_v07.h +1 -1
  204. data/ext/multi_compress/vendor/zstd/lib/libzstd.mk +65 -33
  205. data/ext/multi_compress/vendor/zstd/lib/libzstd.pc.in +5 -5
  206. data/ext/multi_compress/vendor/zstd/lib/module.modulemap +13 -3
  207. data/ext/multi_compress/vendor/zstd/lib/zdict.h +65 -36
  208. data/ext/multi_compress/vendor/zstd/lib/zstd.h +890 -267
  209. data/ext/multi_compress/vendor/zstd/lib/zstd_errors.h +28 -16
  210. data/lib/multi_compress/version.rb +1 -1
  211. metadata +29 -2
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (c) Yann Collet, Facebook, Inc.
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
3
  * All rights reserved.
4
4
  *
5
5
  * This source code is licensed under both the BSD-style license (found in the
@@ -11,46 +11,62 @@
11
11
  #ifndef ZSTD_OPT_H
12
12
  #define ZSTD_OPT_H
13
13
 
14
- #if defined (__cplusplus)
15
- extern "C" {
16
- #endif
17
-
18
14
  #include "zstd_compress_internal.h"
19
15
 
16
+ #if !defined(ZSTD_EXCLUDE_BTLAZY2_BLOCK_COMPRESSOR) \
17
+ || !defined(ZSTD_EXCLUDE_BTOPT_BLOCK_COMPRESSOR) \
18
+ || !defined(ZSTD_EXCLUDE_BTULTRA_BLOCK_COMPRESSOR)
20
19
  /* used in ZSTD_loadDictionaryContent() */
21
- void ZSTD_updateTree(ZSTD_matchState_t* ms, const BYTE* ip, const BYTE* iend);
20
+ void ZSTD_updateTree(ZSTD_MatchState_t* ms, const BYTE* ip, const BYTE* iend);
21
+ #endif
22
22
 
23
+ #ifndef ZSTD_EXCLUDE_BTOPT_BLOCK_COMPRESSOR
23
24
  size_t ZSTD_compressBlock_btopt(
24
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
25
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
25
26
  void const* src, size_t srcSize);
26
- size_t ZSTD_compressBlock_btultra(
27
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
27
+ size_t ZSTD_compressBlock_btopt_dictMatchState(
28
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
28
29
  void const* src, size_t srcSize);
29
- size_t ZSTD_compressBlock_btultra2(
30
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
30
+ size_t ZSTD_compressBlock_btopt_extDict(
31
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
31
32
  void const* src, size_t srcSize);
32
33
 
34
+ #define ZSTD_COMPRESSBLOCK_BTOPT ZSTD_compressBlock_btopt
35
+ #define ZSTD_COMPRESSBLOCK_BTOPT_DICTMATCHSTATE ZSTD_compressBlock_btopt_dictMatchState
36
+ #define ZSTD_COMPRESSBLOCK_BTOPT_EXTDICT ZSTD_compressBlock_btopt_extDict
37
+ #else
38
+ #define ZSTD_COMPRESSBLOCK_BTOPT NULL
39
+ #define ZSTD_COMPRESSBLOCK_BTOPT_DICTMATCHSTATE NULL
40
+ #define ZSTD_COMPRESSBLOCK_BTOPT_EXTDICT NULL
41
+ #endif
33
42
 
34
- size_t ZSTD_compressBlock_btopt_dictMatchState(
35
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
43
+ #ifndef ZSTD_EXCLUDE_BTULTRA_BLOCK_COMPRESSOR
44
+ size_t ZSTD_compressBlock_btultra(
45
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
36
46
  void const* src, size_t srcSize);
37
47
  size_t ZSTD_compressBlock_btultra_dictMatchState(
38
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
39
- void const* src, size_t srcSize);
40
-
41
- size_t ZSTD_compressBlock_btopt_extDict(
42
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
48
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
43
49
  void const* src, size_t srcSize);
44
50
  size_t ZSTD_compressBlock_btultra_extDict(
45
- ZSTD_matchState_t* ms, seqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
51
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
46
52
  void const* src, size_t srcSize);
47
53
 
48
54
  /* note : no btultra2 variant for extDict nor dictMatchState,
49
55
  * because btultra2 is not meant to work with dictionaries
50
56
  * and is only specific for the first block (no prefix) */
57
+ size_t ZSTD_compressBlock_btultra2(
58
+ ZSTD_MatchState_t* ms, SeqStore_t* seqStore, U32 rep[ZSTD_REP_NUM],
59
+ void const* src, size_t srcSize);
51
60
 
52
- #if defined (__cplusplus)
53
- }
61
+ #define ZSTD_COMPRESSBLOCK_BTULTRA ZSTD_compressBlock_btultra
62
+ #define ZSTD_COMPRESSBLOCK_BTULTRA_DICTMATCHSTATE ZSTD_compressBlock_btultra_dictMatchState
63
+ #define ZSTD_COMPRESSBLOCK_BTULTRA_EXTDICT ZSTD_compressBlock_btultra_extDict
64
+ #define ZSTD_COMPRESSBLOCK_BTULTRA2 ZSTD_compressBlock_btultra2
65
+ #else
66
+ #define ZSTD_COMPRESSBLOCK_BTULTRA NULL
67
+ #define ZSTD_COMPRESSBLOCK_BTULTRA_DICTMATCHSTATE NULL
68
+ #define ZSTD_COMPRESSBLOCK_BTULTRA_EXTDICT NULL
69
+ #define ZSTD_COMPRESSBLOCK_BTULTRA2 NULL
54
70
  #endif
55
71
 
56
72
  #endif /* ZSTD_OPT_H */
@@ -0,0 +1,238 @@
1
+ /*
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ * All rights reserved.
4
+ *
5
+ * This source code is licensed under both the BSD-style license (found in the
6
+ * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7
+ * in the COPYING file in the root directory of this source tree).
8
+ * You may select, at your option, one of the above-listed licenses.
9
+ */
10
+
11
+ #include "../common/compiler.h" /* ZSTD_ALIGNOF */
12
+ #include "../common/mem.h" /* S64 */
13
+ #include "../common/zstd_deps.h" /* ZSTD_memset */
14
+ #include "../common/zstd_internal.h" /* ZSTD_STATIC_ASSERT */
15
+ #include "hist.h" /* HIST_add */
16
+ #include "zstd_preSplit.h"
17
+
18
+
19
+ #define BLOCKSIZE_MIN 3500
20
+ #define THRESHOLD_PENALTY_RATE 16
21
+ #define THRESHOLD_BASE (THRESHOLD_PENALTY_RATE - 2)
22
+ #define THRESHOLD_PENALTY 3
23
+
24
+ #define HASHLENGTH 2
25
+ #define HASHLOG_MAX 10
26
+ #define HASHTABLESIZE (1 << HASHLOG_MAX)
27
+ #define HASHMASK (HASHTABLESIZE - 1)
28
+ #define KNUTH 0x9e3779b9
29
+
30
+ /* for hashLog > 8, hash 2 bytes.
31
+ * for hashLog == 8, just take the byte, no hashing.
32
+ * The speed of this method relies on compile-time constant propagation */
33
+ FORCE_INLINE_TEMPLATE unsigned hash2(const void *p, unsigned hashLog)
34
+ {
35
+ assert(hashLog >= 8);
36
+ if (hashLog == 8) return (U32)((const BYTE*)p)[0];
37
+ assert(hashLog <= HASHLOG_MAX);
38
+ return (U32)(MEM_read16(p)) * KNUTH >> (32 - hashLog);
39
+ }
40
+
41
+
42
+ typedef struct {
43
+ unsigned events[HASHTABLESIZE];
44
+ size_t nbEvents;
45
+ } Fingerprint;
46
+ typedef struct {
47
+ Fingerprint pastEvents;
48
+ Fingerprint newEvents;
49
+ } FPStats;
50
+
51
+ static void initStats(FPStats* fpstats)
52
+ {
53
+ ZSTD_memset(fpstats, 0, sizeof(FPStats));
54
+ }
55
+
56
+ FORCE_INLINE_TEMPLATE void
57
+ addEvents_generic(Fingerprint* fp, const void* src, size_t srcSize, size_t samplingRate, unsigned hashLog)
58
+ {
59
+ const char* p = (const char*)src;
60
+ size_t limit = srcSize - HASHLENGTH + 1;
61
+ size_t n;
62
+ assert(srcSize >= HASHLENGTH);
63
+ for (n = 0; n < limit; n+=samplingRate) {
64
+ fp->events[hash2(p+n, hashLog)]++;
65
+ }
66
+ fp->nbEvents += limit/samplingRate;
67
+ }
68
+
69
+ FORCE_INLINE_TEMPLATE void
70
+ recordFingerprint_generic(Fingerprint* fp, const void* src, size_t srcSize, size_t samplingRate, unsigned hashLog)
71
+ {
72
+ ZSTD_memset(fp, 0, sizeof(unsigned) * ((size_t)1 << hashLog));
73
+ fp->nbEvents = 0;
74
+ addEvents_generic(fp, src, srcSize, samplingRate, hashLog);
75
+ }
76
+
77
+ typedef void (*RecordEvents_f)(Fingerprint* fp, const void* src, size_t srcSize);
78
+
79
+ #define FP_RECORD(_rate) ZSTD_recordFingerprint_##_rate
80
+
81
+ #define ZSTD_GEN_RECORD_FINGERPRINT(_rate, _hSize) \
82
+ static void FP_RECORD(_rate)(Fingerprint* fp, const void* src, size_t srcSize) \
83
+ { \
84
+ recordFingerprint_generic(fp, src, srcSize, _rate, _hSize); \
85
+ }
86
+
87
+ ZSTD_GEN_RECORD_FINGERPRINT(1, 10)
88
+ ZSTD_GEN_RECORD_FINGERPRINT(5, 10)
89
+ ZSTD_GEN_RECORD_FINGERPRINT(11, 9)
90
+ ZSTD_GEN_RECORD_FINGERPRINT(43, 8)
91
+
92
+
93
+ static U64 abs64(S64 s64) { return (U64)((s64 < 0) ? -s64 : s64); }
94
+
95
+ static U64 fpDistance(const Fingerprint* fp1, const Fingerprint* fp2, unsigned hashLog)
96
+ {
97
+ U64 distance = 0;
98
+ size_t n;
99
+ assert(hashLog <= HASHLOG_MAX);
100
+ for (n = 0; n < ((size_t)1 << hashLog); n++) {
101
+ distance +=
102
+ abs64((S64)fp1->events[n] * (S64)fp2->nbEvents - (S64)fp2->events[n] * (S64)fp1->nbEvents);
103
+ }
104
+ return distance;
105
+ }
106
+
107
+ /* Compare newEvents with pastEvents
108
+ * return 1 when considered "too different"
109
+ */
110
+ static int compareFingerprints(const Fingerprint* ref,
111
+ const Fingerprint* newfp,
112
+ int penalty,
113
+ unsigned hashLog)
114
+ {
115
+ assert(ref->nbEvents > 0);
116
+ assert(newfp->nbEvents > 0);
117
+ { U64 p50 = (U64)ref->nbEvents * (U64)newfp->nbEvents;
118
+ U64 deviation = fpDistance(ref, newfp, hashLog);
119
+ U64 threshold = p50 * (U64)(THRESHOLD_BASE + penalty) / THRESHOLD_PENALTY_RATE;
120
+ return deviation >= threshold;
121
+ }
122
+ }
123
+
124
+ static void mergeEvents(Fingerprint* acc, const Fingerprint* newfp)
125
+ {
126
+ size_t n;
127
+ for (n = 0; n < HASHTABLESIZE; n++) {
128
+ acc->events[n] += newfp->events[n];
129
+ }
130
+ acc->nbEvents += newfp->nbEvents;
131
+ }
132
+
133
+ static void flushEvents(FPStats* fpstats)
134
+ {
135
+ size_t n;
136
+ for (n = 0; n < HASHTABLESIZE; n++) {
137
+ fpstats->pastEvents.events[n] = fpstats->newEvents.events[n];
138
+ }
139
+ fpstats->pastEvents.nbEvents = fpstats->newEvents.nbEvents;
140
+ ZSTD_memset(&fpstats->newEvents, 0, sizeof(fpstats->newEvents));
141
+ }
142
+
143
+ static void removeEvents(Fingerprint* acc, const Fingerprint* slice)
144
+ {
145
+ size_t n;
146
+ for (n = 0; n < HASHTABLESIZE; n++) {
147
+ assert(acc->events[n] >= slice->events[n]);
148
+ acc->events[n] -= slice->events[n];
149
+ }
150
+ acc->nbEvents -= slice->nbEvents;
151
+ }
152
+
153
+ #define CHUNKSIZE (8 << 10)
154
+ static size_t ZSTD_splitBlock_byChunks(const void* blockStart, size_t blockSize,
155
+ int level,
156
+ void* workspace, size_t wkspSize)
157
+ {
158
+ static const RecordEvents_f records_fs[] = {
159
+ FP_RECORD(43), FP_RECORD(11), FP_RECORD(5), FP_RECORD(1)
160
+ };
161
+ static const unsigned hashParams[] = { 8, 9, 10, 10 };
162
+ const RecordEvents_f record_f = (assert(0<=level && level<=3), records_fs[level]);
163
+ FPStats* const fpstats = (FPStats*)workspace;
164
+ const char* p = (const char*)blockStart;
165
+ int penalty = THRESHOLD_PENALTY;
166
+ size_t pos = 0;
167
+ assert(blockSize == (128 << 10));
168
+ assert(workspace != NULL);
169
+ assert((size_t)workspace % ZSTD_ALIGNOF(FPStats) == 0);
170
+ ZSTD_STATIC_ASSERT(ZSTD_SLIPBLOCK_WORKSPACESIZE >= sizeof(FPStats));
171
+ assert(wkspSize >= sizeof(FPStats)); (void)wkspSize;
172
+
173
+ initStats(fpstats);
174
+ record_f(&fpstats->pastEvents, p, CHUNKSIZE);
175
+ for (pos = CHUNKSIZE; pos <= blockSize - CHUNKSIZE; pos += CHUNKSIZE) {
176
+ record_f(&fpstats->newEvents, p + pos, CHUNKSIZE);
177
+ if (compareFingerprints(&fpstats->pastEvents, &fpstats->newEvents, penalty, hashParams[level])) {
178
+ return pos;
179
+ } else {
180
+ mergeEvents(&fpstats->pastEvents, &fpstats->newEvents);
181
+ if (penalty > 0) penalty--;
182
+ }
183
+ }
184
+ assert(pos == blockSize);
185
+ return blockSize;
186
+ (void)flushEvents; (void)removeEvents;
187
+ }
188
+
189
+ /* ZSTD_splitBlock_fromBorders(): very fast strategy :
190
+ * compare fingerprint from beginning and end of the block,
191
+ * derive from their difference if it's preferable to split in the middle,
192
+ * repeat the process a second time, for finer grained decision.
193
+ * 3 times did not brought improvements, so I stopped at 2.
194
+ * Benefits are good enough for a cheap heuristic.
195
+ * More accurate splitting saves more, but speed impact is also more perceptible.
196
+ * For better accuracy, use more elaborate variant *_byChunks.
197
+ */
198
+ static size_t ZSTD_splitBlock_fromBorders(const void* blockStart, size_t blockSize,
199
+ void* workspace, size_t wkspSize)
200
+ {
201
+ #define SEGMENT_SIZE 512
202
+ FPStats* const fpstats = (FPStats*)workspace;
203
+ Fingerprint* middleEvents = (Fingerprint*)(void*)((char*)workspace + 512 * sizeof(unsigned));
204
+ assert(blockSize == (128 << 10));
205
+ assert(workspace != NULL);
206
+ assert((size_t)workspace % ZSTD_ALIGNOF(FPStats) == 0);
207
+ ZSTD_STATIC_ASSERT(ZSTD_SLIPBLOCK_WORKSPACESIZE >= sizeof(FPStats));
208
+ assert(wkspSize >= sizeof(FPStats)); (void)wkspSize;
209
+
210
+ initStats(fpstats);
211
+ HIST_add(fpstats->pastEvents.events, blockStart, SEGMENT_SIZE);
212
+ HIST_add(fpstats->newEvents.events, (const char*)blockStart + blockSize - SEGMENT_SIZE, SEGMENT_SIZE);
213
+ fpstats->pastEvents.nbEvents = fpstats->newEvents.nbEvents = SEGMENT_SIZE;
214
+ if (!compareFingerprints(&fpstats->pastEvents, &fpstats->newEvents, 0, 8))
215
+ return blockSize;
216
+
217
+ HIST_add(middleEvents->events, (const char*)blockStart + blockSize/2 - SEGMENT_SIZE/2, SEGMENT_SIZE);
218
+ middleEvents->nbEvents = SEGMENT_SIZE;
219
+ { U64 const distFromBegin = fpDistance(&fpstats->pastEvents, middleEvents, 8);
220
+ U64 const distFromEnd = fpDistance(&fpstats->newEvents, middleEvents, 8);
221
+ U64 const minDistance = SEGMENT_SIZE * SEGMENT_SIZE / 3;
222
+ if (abs64((S64)distFromBegin - (S64)distFromEnd) < minDistance)
223
+ return 64 KB;
224
+ return (distFromBegin > distFromEnd) ? 32 KB : 96 KB;
225
+ }
226
+ }
227
+
228
+ size_t ZSTD_splitBlock(const void* blockStart, size_t blockSize,
229
+ int level,
230
+ void* workspace, size_t wkspSize)
231
+ {
232
+ DEBUGLOG(6, "ZSTD_splitBlock (level=%i)", level);
233
+ assert(0<=level && level<=4);
234
+ if (level == 0)
235
+ return ZSTD_splitBlock_fromBorders(blockStart, blockSize, workspace, wkspSize);
236
+ /* level >= 1*/
237
+ return ZSTD_splitBlock_byChunks(blockStart, blockSize, level-1, workspace, wkspSize);
238
+ }
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ * All rights reserved.
4
+ *
5
+ * This source code is licensed under both the BSD-style license (found in the
6
+ * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7
+ * in the COPYING file in the root directory of this source tree).
8
+ * You may select, at your option, one of the above-listed licenses.
9
+ */
10
+
11
+ #ifndef ZSTD_PRESPLIT_H
12
+ #define ZSTD_PRESPLIT_H
13
+
14
+ #include <stddef.h> /* size_t */
15
+
16
+ #define ZSTD_SLIPBLOCK_WORKSPACESIZE 8208
17
+
18
+ /* ZSTD_splitBlock():
19
+ * @level must be a value between 0 and 4.
20
+ * higher levels spend more energy to detect block boundaries.
21
+ * @workspace must be aligned for size_t.
22
+ * @wkspSize must be at least >= ZSTD_SLIPBLOCK_WORKSPACESIZE
23
+ * note:
24
+ * For the time being, this function only accepts full 128 KB blocks.
25
+ * Therefore, @blockSize must be == 128 KB.
26
+ * While this could be extended to smaller sizes in the future,
27
+ * it is not yet clear if this would be useful. TBD.
28
+ */
29
+ size_t ZSTD_splitBlock(const void* blockStart, size_t blockSize,
30
+ int level,
31
+ void* workspace, size_t wkspSize);
32
+
33
+ #endif /* ZSTD_PRESPLIT_H */