zstdlib 0.13.0-x86_64-linux

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 (129) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +6 -0
  3. data/CHANGES.md +107 -0
  4. data/Gemfile +3 -0
  5. data/README.md +107 -0
  6. data/Rakefile +59 -0
  7. data/ext/zstdlib_c/extconf.rb +59 -0
  8. data/ext/zstdlib_c/ruby/zlib-2.2/zstdlib.c +4675 -0
  9. data/ext/zstdlib_c/ruby/zlib-2.3/zstdlib.c +4702 -0
  10. data/ext/zstdlib_c/ruby/zlib-2.4/zstdlib.c +4859 -0
  11. data/ext/zstdlib_c/ruby/zlib-2.5/zstdlib.c +4864 -0
  12. data/ext/zstdlib_c/ruby/zlib-2.6/zstdlib.c +4906 -0
  13. data/ext/zstdlib_c/ruby/zlib-2.7/zstdlib.c +4895 -0
  14. data/ext/zstdlib_c/ruby/zlib-3.0/zstdlib.c +4994 -0
  15. data/ext/zstdlib_c/ruby/zlib-3.1/zstdlib.c +5076 -0
  16. data/ext/zstdlib_c/ruby/zlib-3.2/zstdlib.c +5090 -0
  17. data/ext/zstdlib_c/ruby/zlib-3.3/zstdlib.c +5090 -0
  18. data/ext/zstdlib_c/zlib-1.3.1/adler32.c +164 -0
  19. data/ext/zstdlib_c/zlib-1.3.1/compress.c +75 -0
  20. data/ext/zstdlib_c/zlib-1.3.1/crc32.c +1049 -0
  21. data/ext/zstdlib_c/zlib-1.3.1/crc32.h +9446 -0
  22. data/ext/zstdlib_c/zlib-1.3.1/deflate.c +2139 -0
  23. data/ext/zstdlib_c/zlib-1.3.1/deflate.h +377 -0
  24. data/ext/zstdlib_c/zlib-1.3.1/gzclose.c +23 -0
  25. data/ext/zstdlib_c/zlib-1.3.1/gzguts.h +214 -0
  26. data/ext/zstdlib_c/zlib-1.3.1/gzlib.c +582 -0
  27. data/ext/zstdlib_c/zlib-1.3.1/gzread.c +602 -0
  28. data/ext/zstdlib_c/zlib-1.3.1/gzwrite.c +631 -0
  29. data/ext/zstdlib_c/zlib-1.3.1/infback.c +628 -0
  30. data/ext/zstdlib_c/zlib-1.3.1/inffast.c +320 -0
  31. data/ext/zstdlib_c/zlib-1.3.1/inffast.h +11 -0
  32. data/ext/zstdlib_c/zlib-1.3.1/inffixed.h +94 -0
  33. data/ext/zstdlib_c/zlib-1.3.1/inflate.c +1526 -0
  34. data/ext/zstdlib_c/zlib-1.3.1/inflate.h +126 -0
  35. data/ext/zstdlib_c/zlib-1.3.1/inftrees.c +299 -0
  36. data/ext/zstdlib_c/zlib-1.3.1/inftrees.h +62 -0
  37. data/ext/zstdlib_c/zlib-1.3.1/trees.c +1117 -0
  38. data/ext/zstdlib_c/zlib-1.3.1/trees.h +128 -0
  39. data/ext/zstdlib_c/zlib-1.3.1/uncompr.c +85 -0
  40. data/ext/zstdlib_c/zlib-1.3.1/zconf.h +543 -0
  41. data/ext/zstdlib_c/zlib-1.3.1/zlib.h +1938 -0
  42. data/ext/zstdlib_c/zlib-1.3.1/zutil.c +299 -0
  43. data/ext/zstdlib_c/zlib-1.3.1/zutil.h +254 -0
  44. data/ext/zstdlib_c/zlib.mk +14 -0
  45. data/ext/zstdlib_c/zlibwrapper/zlibwrapper.c +10 -0
  46. data/ext/zstdlib_c/zlibwrapper.mk +14 -0
  47. data/ext/zstdlib_c/zstd-1.5.6/lib/common/allocations.h +55 -0
  48. data/ext/zstdlib_c/zstd-1.5.6/lib/common/bits.h +200 -0
  49. data/ext/zstdlib_c/zstd-1.5.6/lib/common/bitstream.h +457 -0
  50. data/ext/zstdlib_c/zstd-1.5.6/lib/common/compiler.h +450 -0
  51. data/ext/zstdlib_c/zstd-1.5.6/lib/common/cpu.h +249 -0
  52. data/ext/zstdlib_c/zstd-1.5.6/lib/common/debug.c +30 -0
  53. data/ext/zstdlib_c/zstd-1.5.6/lib/common/debug.h +116 -0
  54. data/ext/zstdlib_c/zstd-1.5.6/lib/common/entropy_common.c +340 -0
  55. data/ext/zstdlib_c/zstd-1.5.6/lib/common/error_private.c +63 -0
  56. data/ext/zstdlib_c/zstd-1.5.6/lib/common/error_private.h +168 -0
  57. data/ext/zstdlib_c/zstd-1.5.6/lib/common/fse.h +640 -0
  58. data/ext/zstdlib_c/zstd-1.5.6/lib/common/fse_decompress.c +313 -0
  59. data/ext/zstdlib_c/zstd-1.5.6/lib/common/huf.h +286 -0
  60. data/ext/zstdlib_c/zstd-1.5.6/lib/common/mem.h +426 -0
  61. data/ext/zstdlib_c/zstd-1.5.6/lib/common/pool.c +371 -0
  62. data/ext/zstdlib_c/zstd-1.5.6/lib/common/pool.h +90 -0
  63. data/ext/zstdlib_c/zstd-1.5.6/lib/common/portability_macros.h +158 -0
  64. data/ext/zstdlib_c/zstd-1.5.6/lib/common/threading.c +182 -0
  65. data/ext/zstdlib_c/zstd-1.5.6/lib/common/threading.h +150 -0
  66. data/ext/zstdlib_c/zstd-1.5.6/lib/common/xxhash.c +18 -0
  67. data/ext/zstdlib_c/zstd-1.5.6/lib/common/xxhash.h +7020 -0
  68. data/ext/zstdlib_c/zstd-1.5.6/lib/common/zstd_common.c +48 -0
  69. data/ext/zstdlib_c/zstd-1.5.6/lib/common/zstd_deps.h +111 -0
  70. data/ext/zstdlib_c/zstd-1.5.6/lib/common/zstd_internal.h +392 -0
  71. data/ext/zstdlib_c/zstd-1.5.6/lib/common/zstd_trace.h +163 -0
  72. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/clevels.h +134 -0
  73. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/fse_compress.c +625 -0
  74. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/hist.c +181 -0
  75. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/hist.h +75 -0
  76. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/huf_compress.c +1464 -0
  77. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress.c +7153 -0
  78. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_internal.h +1534 -0
  79. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_literals.c +235 -0
  80. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_literals.h +39 -0
  81. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_sequences.c +442 -0
  82. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_sequences.h +54 -0
  83. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_superblock.c +688 -0
  84. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_compress_superblock.h +32 -0
  85. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_cwksp.h +748 -0
  86. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_double_fast.c +770 -0
  87. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_double_fast.h +50 -0
  88. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_fast.c +968 -0
  89. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_fast.h +38 -0
  90. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_lazy.c +2199 -0
  91. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_lazy.h +202 -0
  92. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_ldm.c +730 -0
  93. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_ldm.h +117 -0
  94. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_ldm_geartab.h +106 -0
  95. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_opt.c +1576 -0
  96. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstd_opt.h +80 -0
  97. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstdmt_compress.c +1882 -0
  98. data/ext/zstdlib_c/zstd-1.5.6/lib/compress/zstdmt_compress.h +113 -0
  99. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/huf_decompress.c +1944 -0
  100. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/huf_decompress_amd64.S +595 -0
  101. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_ddict.c +244 -0
  102. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_ddict.h +44 -0
  103. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_decompress.c +2407 -0
  104. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_decompress_block.c +2215 -0
  105. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_decompress_block.h +73 -0
  106. data/ext/zstdlib_c/zstd-1.5.6/lib/decompress/zstd_decompress_internal.h +240 -0
  107. data/ext/zstdlib_c/zstd-1.5.6/lib/zdict.h +474 -0
  108. data/ext/zstdlib_c/zstd-1.5.6/lib/zstd.h +3089 -0
  109. data/ext/zstdlib_c/zstd-1.5.6/lib/zstd_errors.h +114 -0
  110. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzclose.c +26 -0
  111. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzcompatibility.h +68 -0
  112. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzguts.h +229 -0
  113. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzlib.c +587 -0
  114. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzread.c +637 -0
  115. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/gzwrite.c +631 -0
  116. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/zstd_zlibwrapper.c +1200 -0
  117. data/ext/zstdlib_c/zstd-1.5.6/zlibWrapper/zstd_zlibwrapper.h +91 -0
  118. data/ext/zstdlib_c/zstd.mk +15 -0
  119. data/lib/2.4/zstdlib_c.so +0 -0
  120. data/lib/2.5/zstdlib_c.so +0 -0
  121. data/lib/2.6/zstdlib_c.so +0 -0
  122. data/lib/2.7/zstdlib_c.so +0 -0
  123. data/lib/3.0/zstdlib_c.so +0 -0
  124. data/lib/3.1/zstdlib_c.so +0 -0
  125. data/lib/3.2/zstdlib_c.so +0 -0
  126. data/lib/3.3/zstdlib_c.so +0 -0
  127. data/lib/zstdlib.rb +6 -0
  128. data/test/zstdlib_test.rb +21 -0
  129. metadata +243 -0
@@ -0,0 +1,450 @@
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_COMPILER_H
12
+ #define ZSTD_COMPILER_H
13
+
14
+ #include <stddef.h>
15
+
16
+ #include "portability_macros.h"
17
+
18
+ /*-*******************************************************
19
+ * Compiler specifics
20
+ *********************************************************/
21
+ /* force inlining */
22
+
23
+ #if !defined(ZSTD_NO_INLINE)
24
+ #if (defined(__GNUC__) && !defined(__STRICT_ANSI__)) || defined(__cplusplus) || defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L /* C99 */
25
+ # define INLINE_KEYWORD inline
26
+ #else
27
+ # define INLINE_KEYWORD
28
+ #endif
29
+
30
+ #if defined(__GNUC__) || defined(__ICCARM__)
31
+ # define FORCE_INLINE_ATTR __attribute__((always_inline))
32
+ #elif defined(_MSC_VER)
33
+ # define FORCE_INLINE_ATTR __forceinline
34
+ #else
35
+ # define FORCE_INLINE_ATTR
36
+ #endif
37
+
38
+ #else
39
+
40
+ #define INLINE_KEYWORD
41
+ #define FORCE_INLINE_ATTR
42
+
43
+ #endif
44
+
45
+ /**
46
+ On MSVC qsort requires that functions passed into it use the __cdecl calling conversion(CC).
47
+ This explicitly marks such functions as __cdecl so that the code will still compile
48
+ if a CC other than __cdecl has been made the default.
49
+ */
50
+ #if defined(_MSC_VER)
51
+ # define WIN_CDECL __cdecl
52
+ #else
53
+ # define WIN_CDECL
54
+ #endif
55
+
56
+ /* UNUSED_ATTR tells the compiler it is okay if the function is unused. */
57
+ #if defined(__GNUC__)
58
+ # define UNUSED_ATTR __attribute__((unused))
59
+ #else
60
+ # define UNUSED_ATTR
61
+ #endif
62
+
63
+ /**
64
+ * FORCE_INLINE_TEMPLATE is used to define C "templates", which take constant
65
+ * parameters. They must be inlined for the compiler to eliminate the constant
66
+ * branches.
67
+ */
68
+ #define FORCE_INLINE_TEMPLATE static INLINE_KEYWORD FORCE_INLINE_ATTR UNUSED_ATTR
69
+ /**
70
+ * HINT_INLINE is used to help the compiler generate better code. It is *not*
71
+ * used for "templates", so it can be tweaked based on the compilers
72
+ * performance.
73
+ *
74
+ * gcc-4.8 and gcc-4.9 have been shown to benefit from leaving off the
75
+ * always_inline attribute.
76
+ *
77
+ * clang up to 5.0.0 (trunk) benefit tremendously from the always_inline
78
+ * attribute.
79
+ */
80
+ #if !defined(__clang__) && defined(__GNUC__) && __GNUC__ >= 4 && __GNUC_MINOR__ >= 8 && __GNUC__ < 5
81
+ # define HINT_INLINE static INLINE_KEYWORD
82
+ #else
83
+ # define HINT_INLINE FORCE_INLINE_TEMPLATE
84
+ #endif
85
+
86
+ /* "soft" inline :
87
+ * The compiler is free to select if it's a good idea to inline or not.
88
+ * The main objective is to silence compiler warnings
89
+ * when a defined function in included but not used.
90
+ *
91
+ * Note : this macro is prefixed `MEM_` because it used to be provided by `mem.h` unit.
92
+ * Updating the prefix is probably preferable, but requires a fairly large codemod,
93
+ * since this name is used everywhere.
94
+ */
95
+ #ifndef MEM_STATIC /* already defined in Linux Kernel mem.h */
96
+ #if defined(__GNUC__)
97
+ # define MEM_STATIC static __inline UNUSED_ATTR
98
+ #elif defined (__cplusplus) || (defined (__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) /* C99 */)
99
+ # define MEM_STATIC static inline
100
+ #elif defined(_MSC_VER)
101
+ # define MEM_STATIC static __inline
102
+ #else
103
+ # define MEM_STATIC static /* this version may generate warnings for unused static functions; disable the relevant warning */
104
+ #endif
105
+ #endif
106
+
107
+ /* force no inlining */
108
+ #ifdef _MSC_VER
109
+ # define FORCE_NOINLINE static __declspec(noinline)
110
+ #else
111
+ # if defined(__GNUC__) || defined(__ICCARM__)
112
+ # define FORCE_NOINLINE static __attribute__((__noinline__))
113
+ # else
114
+ # define FORCE_NOINLINE static
115
+ # endif
116
+ #endif
117
+
118
+
119
+ /* target attribute */
120
+ #if defined(__GNUC__) || defined(__ICCARM__)
121
+ # define TARGET_ATTRIBUTE(target) __attribute__((__target__(target)))
122
+ #else
123
+ # define TARGET_ATTRIBUTE(target)
124
+ #endif
125
+
126
+ /* Target attribute for BMI2 dynamic dispatch.
127
+ * Enable lzcnt, bmi, and bmi2.
128
+ * We test for bmi1 & bmi2. lzcnt is included in bmi1.
129
+ */
130
+ #define BMI2_TARGET_ATTRIBUTE TARGET_ATTRIBUTE("lzcnt,bmi,bmi2")
131
+
132
+ /* prefetch
133
+ * can be disabled, by declaring NO_PREFETCH build macro */
134
+ #if defined(NO_PREFETCH)
135
+ # define PREFETCH_L1(ptr) do { (void)(ptr); } while (0) /* disabled */
136
+ # define PREFETCH_L2(ptr) do { (void)(ptr); } while (0) /* disabled */
137
+ #else
138
+ # if defined(_MSC_VER) && (defined(_M_X64) || defined(_M_I86)) && !defined(_M_ARM64EC) /* _mm_prefetch() is not defined outside of x86/x64 */
139
+ # include <mmintrin.h> /* https://msdn.microsoft.com/fr-fr/library/84szxsww(v=vs.90).aspx */
140
+ # define PREFETCH_L1(ptr) _mm_prefetch((const char*)(ptr), _MM_HINT_T0)
141
+ # define PREFETCH_L2(ptr) _mm_prefetch((const char*)(ptr), _MM_HINT_T1)
142
+ # elif defined(__GNUC__) && ( (__GNUC__ >= 4) || ( (__GNUC__ == 3) && (__GNUC_MINOR__ >= 1) ) )
143
+ # define PREFETCH_L1(ptr) __builtin_prefetch((ptr), 0 /* rw==read */, 3 /* locality */)
144
+ # define PREFETCH_L2(ptr) __builtin_prefetch((ptr), 0 /* rw==read */, 2 /* locality */)
145
+ # elif defined(__aarch64__)
146
+ # define PREFETCH_L1(ptr) do { __asm__ __volatile__("prfm pldl1keep, %0" ::"Q"(*(ptr))); } while (0)
147
+ # define PREFETCH_L2(ptr) do { __asm__ __volatile__("prfm pldl2keep, %0" ::"Q"(*(ptr))); } while (0)
148
+ # else
149
+ # define PREFETCH_L1(ptr) do { (void)(ptr); } while (0) /* disabled */
150
+ # define PREFETCH_L2(ptr) do { (void)(ptr); } while (0) /* disabled */
151
+ # endif
152
+ #endif /* NO_PREFETCH */
153
+
154
+ #define CACHELINE_SIZE 64
155
+
156
+ #define PREFETCH_AREA(p, s) \
157
+ do { \
158
+ const char* const _ptr = (const char*)(p); \
159
+ size_t const _size = (size_t)(s); \
160
+ size_t _pos; \
161
+ for (_pos=0; _pos<_size; _pos+=CACHELINE_SIZE) { \
162
+ PREFETCH_L2(_ptr + _pos); \
163
+ } \
164
+ } while (0)
165
+
166
+ /* vectorization
167
+ * older GCC (pre gcc-4.3 picked as the cutoff) uses a different syntax,
168
+ * and some compilers, like Intel ICC and MCST LCC, do not support it at all. */
169
+ #if !defined(__INTEL_COMPILER) && !defined(__clang__) && defined(__GNUC__) && !defined(__LCC__)
170
+ # if (__GNUC__ == 4 && __GNUC_MINOR__ > 3) || (__GNUC__ >= 5)
171
+ # define DONT_VECTORIZE __attribute__((optimize("no-tree-vectorize")))
172
+ # else
173
+ # define DONT_VECTORIZE _Pragma("GCC optimize(\"no-tree-vectorize\")")
174
+ # endif
175
+ #else
176
+ # define DONT_VECTORIZE
177
+ #endif
178
+
179
+ /* Tell the compiler that a branch is likely or unlikely.
180
+ * Only use these macros if it causes the compiler to generate better code.
181
+ * If you can remove a LIKELY/UNLIKELY annotation without speed changes in gcc
182
+ * and clang, please do.
183
+ */
184
+ #if defined(__GNUC__)
185
+ #define LIKELY(x) (__builtin_expect((x), 1))
186
+ #define UNLIKELY(x) (__builtin_expect((x), 0))
187
+ #else
188
+ #define LIKELY(x) (x)
189
+ #define UNLIKELY(x) (x)
190
+ #endif
191
+
192
+ #if __has_builtin(__builtin_unreachable) || (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5)))
193
+ # define ZSTD_UNREACHABLE do { assert(0), __builtin_unreachable(); } while (0)
194
+ #else
195
+ # define ZSTD_UNREACHABLE do { assert(0); } while (0)
196
+ #endif
197
+
198
+ /* disable warnings */
199
+ #ifdef _MSC_VER /* Visual Studio */
200
+ # include <intrin.h> /* For Visual 2005 */
201
+ # pragma warning(disable : 4100) /* disable: C4100: unreferenced formal parameter */
202
+ # pragma warning(disable : 4127) /* disable: C4127: conditional expression is constant */
203
+ # pragma warning(disable : 4204) /* disable: C4204: non-constant aggregate initializer */
204
+ # pragma warning(disable : 4214) /* disable: C4214: non-int bitfields */
205
+ # pragma warning(disable : 4324) /* disable: C4324: padded structure */
206
+ #endif
207
+
208
+ /*Like DYNAMIC_BMI2 but for compile time determination of BMI2 support*/
209
+ #ifndef STATIC_BMI2
210
+ # if defined(_MSC_VER) && (defined(_M_X64) || defined(_M_I86))
211
+ # ifdef __AVX2__ //MSVC does not have a BMI2 specific flag, but every CPU that supports AVX2 also supports BMI2
212
+ # define STATIC_BMI2 1
213
+ # endif
214
+ # elif defined(__BMI2__) && defined(__x86_64__) && defined(__GNUC__)
215
+ # define STATIC_BMI2 1
216
+ # endif
217
+ #endif
218
+
219
+ #ifndef STATIC_BMI2
220
+ #define STATIC_BMI2 0
221
+ #endif
222
+
223
+ /* compile time determination of SIMD support */
224
+ #if !defined(ZSTD_NO_INTRINSICS)
225
+ # if defined(__SSE2__) || defined(_M_AMD64) || (defined (_M_IX86) && defined(_M_IX86_FP) && (_M_IX86_FP >= 2))
226
+ # define ZSTD_ARCH_X86_SSE2
227
+ # endif
228
+ # if defined(__ARM_NEON) || defined(_M_ARM64)
229
+ # define ZSTD_ARCH_ARM_NEON
230
+ # endif
231
+ #
232
+ # if defined(ZSTD_ARCH_X86_SSE2)
233
+ # include <emmintrin.h>
234
+ # elif defined(ZSTD_ARCH_ARM_NEON)
235
+ # include <arm_neon.h>
236
+ # endif
237
+ #endif
238
+
239
+ /* C-language Attributes are added in C23. */
240
+ #if defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201710L) && defined(__has_c_attribute)
241
+ # define ZSTD_HAS_C_ATTRIBUTE(x) __has_c_attribute(x)
242
+ #else
243
+ # define ZSTD_HAS_C_ATTRIBUTE(x) 0
244
+ #endif
245
+
246
+ /* Only use C++ attributes in C++. Some compilers report support for C++
247
+ * attributes when compiling with C.
248
+ */
249
+ #if defined(__cplusplus) && defined(__has_cpp_attribute)
250
+ # define ZSTD_HAS_CPP_ATTRIBUTE(x) __has_cpp_attribute(x)
251
+ #else
252
+ # define ZSTD_HAS_CPP_ATTRIBUTE(x) 0
253
+ #endif
254
+
255
+ /* Define ZSTD_FALLTHROUGH macro for annotating switch case with the 'fallthrough' attribute.
256
+ * - C23: https://en.cppreference.com/w/c/language/attributes/fallthrough
257
+ * - CPP17: https://en.cppreference.com/w/cpp/language/attributes/fallthrough
258
+ * - Else: __attribute__((__fallthrough__))
259
+ */
260
+ #ifndef ZSTD_FALLTHROUGH
261
+ # if ZSTD_HAS_C_ATTRIBUTE(fallthrough)
262
+ # define ZSTD_FALLTHROUGH [[fallthrough]]
263
+ # elif ZSTD_HAS_CPP_ATTRIBUTE(fallthrough)
264
+ # define ZSTD_FALLTHROUGH [[fallthrough]]
265
+ # elif __has_attribute(__fallthrough__)
266
+ /* Leading semicolon is to satisfy gcc-11 with -pedantic. Without the semicolon
267
+ * gcc complains about: a label can only be part of a statement and a declaration is not a statement.
268
+ */
269
+ # define ZSTD_FALLTHROUGH ; __attribute__((__fallthrough__))
270
+ # else
271
+ # define ZSTD_FALLTHROUGH
272
+ # endif
273
+ #endif
274
+
275
+ /*-**************************************************************
276
+ * Alignment check
277
+ *****************************************************************/
278
+
279
+ /* this test was initially positioned in mem.h,
280
+ * but this file is removed (or replaced) for linux kernel
281
+ * so it's now hosted in compiler.h,
282
+ * which remains valid for both user & kernel spaces.
283
+ */
284
+
285
+ #ifndef ZSTD_ALIGNOF
286
+ # if defined(__GNUC__) || defined(_MSC_VER)
287
+ /* covers gcc, clang & MSVC */
288
+ /* note : this section must come first, before C11,
289
+ * due to a limitation in the kernel source generator */
290
+ # define ZSTD_ALIGNOF(T) __alignof(T)
291
+
292
+ # elif defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201112L)
293
+ /* C11 support */
294
+ # include <stdalign.h>
295
+ # define ZSTD_ALIGNOF(T) alignof(T)
296
+
297
+ # else
298
+ /* No known support for alignof() - imperfect backup */
299
+ # define ZSTD_ALIGNOF(T) (sizeof(void*) < sizeof(T) ? sizeof(void*) : sizeof(T))
300
+
301
+ # endif
302
+ #endif /* ZSTD_ALIGNOF */
303
+
304
+ /*-**************************************************************
305
+ * Sanitizer
306
+ *****************************************************************/
307
+
308
+ /**
309
+ * Zstd relies on pointer overflow in its decompressor.
310
+ * We add this attribute to functions that rely on pointer overflow.
311
+ */
312
+ #ifndef ZSTD_ALLOW_POINTER_OVERFLOW_ATTR
313
+ # if __has_attribute(no_sanitize)
314
+ # if !defined(__clang__) && defined(__GNUC__) && __GNUC__ < 8
315
+ /* gcc < 8 only has signed-integer-overlow which triggers on pointer overflow */
316
+ # define ZSTD_ALLOW_POINTER_OVERFLOW_ATTR __attribute__((no_sanitize("signed-integer-overflow")))
317
+ # else
318
+ /* older versions of clang [3.7, 5.0) will warn that pointer-overflow is ignored. */
319
+ # define ZSTD_ALLOW_POINTER_OVERFLOW_ATTR __attribute__((no_sanitize("pointer-overflow")))
320
+ # endif
321
+ # else
322
+ # define ZSTD_ALLOW_POINTER_OVERFLOW_ATTR
323
+ # endif
324
+ #endif
325
+
326
+ /**
327
+ * Helper function to perform a wrapped pointer difference without trigging
328
+ * UBSAN.
329
+ *
330
+ * @returns lhs - rhs with wrapping
331
+ */
332
+ MEM_STATIC
333
+ ZSTD_ALLOW_POINTER_OVERFLOW_ATTR
334
+ ptrdiff_t ZSTD_wrappedPtrDiff(unsigned char const* lhs, unsigned char const* rhs)
335
+ {
336
+ return lhs - rhs;
337
+ }
338
+
339
+ /**
340
+ * Helper function to perform a wrapped pointer add without triggering UBSAN.
341
+ *
342
+ * @return ptr + add with wrapping
343
+ */
344
+ MEM_STATIC
345
+ ZSTD_ALLOW_POINTER_OVERFLOW_ATTR
346
+ unsigned char const* ZSTD_wrappedPtrAdd(unsigned char const* ptr, ptrdiff_t add)
347
+ {
348
+ return ptr + add;
349
+ }
350
+
351
+ /**
352
+ * Helper function to perform a wrapped pointer subtraction without triggering
353
+ * UBSAN.
354
+ *
355
+ * @return ptr - sub with wrapping
356
+ */
357
+ MEM_STATIC
358
+ ZSTD_ALLOW_POINTER_OVERFLOW_ATTR
359
+ unsigned char const* ZSTD_wrappedPtrSub(unsigned char const* ptr, ptrdiff_t sub)
360
+ {
361
+ return ptr - sub;
362
+ }
363
+
364
+ /**
365
+ * Helper function to add to a pointer that works around C's undefined behavior
366
+ * of adding 0 to NULL.
367
+ *
368
+ * @returns `ptr + add` except it defines `NULL + 0 == NULL`.
369
+ */
370
+ MEM_STATIC
371
+ unsigned char* ZSTD_maybeNullPtrAdd(unsigned char* ptr, ptrdiff_t add)
372
+ {
373
+ return add > 0 ? ptr + add : ptr;
374
+ }
375
+
376
+ /* Issue #3240 reports an ASAN failure on an llvm-mingw build. Out of an
377
+ * abundance of caution, disable our custom poisoning on mingw. */
378
+ #ifdef __MINGW32__
379
+ #ifndef ZSTD_ASAN_DONT_POISON_WORKSPACE
380
+ #define ZSTD_ASAN_DONT_POISON_WORKSPACE 1
381
+ #endif
382
+ #ifndef ZSTD_MSAN_DONT_POISON_WORKSPACE
383
+ #define ZSTD_MSAN_DONT_POISON_WORKSPACE 1
384
+ #endif
385
+ #endif
386
+
387
+ #if ZSTD_MEMORY_SANITIZER && !defined(ZSTD_MSAN_DONT_POISON_WORKSPACE)
388
+ /* Not all platforms that support msan provide sanitizers/msan_interface.h.
389
+ * We therefore declare the functions we need ourselves, rather than trying to
390
+ * include the header file... */
391
+ #include <stddef.h> /* size_t */
392
+ #define ZSTD_DEPS_NEED_STDINT
393
+ #include "zstd_deps.h" /* intptr_t */
394
+
395
+ /* Make memory region fully initialized (without changing its contents). */
396
+ void __msan_unpoison(const volatile void *a, size_t size);
397
+
398
+ /* Make memory region fully uninitialized (without changing its contents).
399
+ This is a legacy interface that does not update origin information. Use
400
+ __msan_allocated_memory() instead. */
401
+ void __msan_poison(const volatile void *a, size_t size);
402
+
403
+ /* Returns the offset of the first (at least partially) poisoned byte in the
404
+ memory range, or -1 if the whole range is good. */
405
+ intptr_t __msan_test_shadow(const volatile void *x, size_t size);
406
+
407
+ /* Print shadow and origin for the memory range to stderr in a human-readable
408
+ format. */
409
+ void __msan_print_shadow(const volatile void *x, size_t size);
410
+ #endif
411
+
412
+ #if ZSTD_ADDRESS_SANITIZER && !defined(ZSTD_ASAN_DONT_POISON_WORKSPACE)
413
+ /* Not all platforms that support asan provide sanitizers/asan_interface.h.
414
+ * We therefore declare the functions we need ourselves, rather than trying to
415
+ * include the header file... */
416
+ #include <stddef.h> /* size_t */
417
+
418
+ /**
419
+ * Marks a memory region (<c>[addr, addr+size)</c>) as unaddressable.
420
+ *
421
+ * This memory must be previously allocated by your program. Instrumented
422
+ * code is forbidden from accessing addresses in this region until it is
423
+ * unpoisoned. This function is not guaranteed to poison the entire region -
424
+ * it could poison only a subregion of <c>[addr, addr+size)</c> due to ASan
425
+ * alignment restrictions.
426
+ *
427
+ * \note This function is not thread-safe because no two threads can poison or
428
+ * unpoison memory in the same memory region simultaneously.
429
+ *
430
+ * \param addr Start of memory region.
431
+ * \param size Size of memory region. */
432
+ void __asan_poison_memory_region(void const volatile *addr, size_t size);
433
+
434
+ /**
435
+ * Marks a memory region (<c>[addr, addr+size)</c>) as addressable.
436
+ *
437
+ * This memory must be previously allocated by your program. Accessing
438
+ * addresses in this region is allowed until this region is poisoned again.
439
+ * This function could unpoison a super-region of <c>[addr, addr+size)</c> due
440
+ * to ASan alignment restrictions.
441
+ *
442
+ * \note This function is not thread-safe because no two threads can
443
+ * poison or unpoison memory in the same memory region simultaneously.
444
+ *
445
+ * \param addr Start of memory region.
446
+ * \param size Size of memory region. */
447
+ void __asan_unpoison_memory_region(void const volatile *addr, size_t size);
448
+ #endif
449
+
450
+ #endif /* ZSTD_COMPILER_H */
@@ -0,0 +1,249 @@
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_COMMON_CPU_H
12
+ #define ZSTD_COMMON_CPU_H
13
+
14
+ /**
15
+ * Implementation taken from folly/CpuId.h
16
+ * https://github.com/facebook/folly/blob/master/folly/CpuId.h
17
+ */
18
+
19
+ #include "mem.h"
20
+
21
+ #ifdef _MSC_VER
22
+ #include <intrin.h>
23
+ #endif
24
+
25
+ typedef struct {
26
+ U32 f1c;
27
+ U32 f1d;
28
+ U32 f7b;
29
+ U32 f7c;
30
+ } ZSTD_cpuid_t;
31
+
32
+ MEM_STATIC ZSTD_cpuid_t ZSTD_cpuid(void) {
33
+ U32 f1c = 0;
34
+ U32 f1d = 0;
35
+ U32 f7b = 0;
36
+ U32 f7c = 0;
37
+ #if defined(_MSC_VER) && (defined(_M_X64) || defined(_M_IX86))
38
+ #if !defined(__clang__)
39
+ int reg[4];
40
+ __cpuid((int*)reg, 0);
41
+ {
42
+ int const n = reg[0];
43
+ if (n >= 1) {
44
+ __cpuid((int*)reg, 1);
45
+ f1c = (U32)reg[2];
46
+ f1d = (U32)reg[3];
47
+ }
48
+ if (n >= 7) {
49
+ __cpuidex((int*)reg, 7, 0);
50
+ f7b = (U32)reg[1];
51
+ f7c = (U32)reg[2];
52
+ }
53
+ }
54
+ #else
55
+ /* Clang compiler has a bug (fixed in https://reviews.llvm.org/D101338) in
56
+ * which the `__cpuid` intrinsic does not save and restore `rbx` as it needs
57
+ * to due to being a reserved register. So in that case, do the `cpuid`
58
+ * ourselves. Clang supports inline assembly anyway.
59
+ */
60
+ U32 n;
61
+ __asm__(
62
+ "pushq %%rbx\n\t"
63
+ "cpuid\n\t"
64
+ "popq %%rbx\n\t"
65
+ : "=a"(n)
66
+ : "a"(0)
67
+ : "rcx", "rdx");
68
+ if (n >= 1) {
69
+ U32 f1a;
70
+ __asm__(
71
+ "pushq %%rbx\n\t"
72
+ "cpuid\n\t"
73
+ "popq %%rbx\n\t"
74
+ : "=a"(f1a), "=c"(f1c), "=d"(f1d)
75
+ : "a"(1)
76
+ :);
77
+ }
78
+ if (n >= 7) {
79
+ __asm__(
80
+ "pushq %%rbx\n\t"
81
+ "cpuid\n\t"
82
+ "movq %%rbx, %%rax\n\t"
83
+ "popq %%rbx"
84
+ : "=a"(f7b), "=c"(f7c)
85
+ : "a"(7), "c"(0)
86
+ : "rdx");
87
+ }
88
+ #endif
89
+ #elif defined(__i386__) && defined(__PIC__) && !defined(__clang__) && defined(__GNUC__)
90
+ /* The following block like the normal cpuid branch below, but gcc
91
+ * reserves ebx for use of its pic register so we must specially
92
+ * handle the save and restore to avoid clobbering the register
93
+ */
94
+ U32 n;
95
+ __asm__(
96
+ "pushl %%ebx\n\t"
97
+ "cpuid\n\t"
98
+ "popl %%ebx\n\t"
99
+ : "=a"(n)
100
+ : "a"(0)
101
+ : "ecx", "edx");
102
+ if (n >= 1) {
103
+ U32 f1a;
104
+ __asm__(
105
+ "pushl %%ebx\n\t"
106
+ "cpuid\n\t"
107
+ "popl %%ebx\n\t"
108
+ : "=a"(f1a), "=c"(f1c), "=d"(f1d)
109
+ : "a"(1));
110
+ }
111
+ if (n >= 7) {
112
+ __asm__(
113
+ "pushl %%ebx\n\t"
114
+ "cpuid\n\t"
115
+ "movl %%ebx, %%eax\n\t"
116
+ "popl %%ebx"
117
+ : "=a"(f7b), "=c"(f7c)
118
+ : "a"(7), "c"(0)
119
+ : "edx");
120
+ }
121
+ #elif defined(__x86_64__) || defined(_M_X64) || defined(__i386__)
122
+ U32 n;
123
+ __asm__("cpuid" : "=a"(n) : "a"(0) : "ebx", "ecx", "edx");
124
+ if (n >= 1) {
125
+ U32 f1a;
126
+ __asm__("cpuid" : "=a"(f1a), "=c"(f1c), "=d"(f1d) : "a"(1) : "ebx");
127
+ }
128
+ if (n >= 7) {
129
+ U32 f7a;
130
+ __asm__("cpuid"
131
+ : "=a"(f7a), "=b"(f7b), "=c"(f7c)
132
+ : "a"(7), "c"(0)
133
+ : "edx");
134
+ }
135
+ #endif
136
+ {
137
+ ZSTD_cpuid_t cpuid;
138
+ cpuid.f1c = f1c;
139
+ cpuid.f1d = f1d;
140
+ cpuid.f7b = f7b;
141
+ cpuid.f7c = f7c;
142
+ return cpuid;
143
+ }
144
+ }
145
+
146
+ #define X(name, r, bit) \
147
+ MEM_STATIC int ZSTD_cpuid_##name(ZSTD_cpuid_t const cpuid) { \
148
+ return ((cpuid.r) & (1U << bit)) != 0; \
149
+ }
150
+
151
+ /* cpuid(1): Processor Info and Feature Bits. */
152
+ #define C(name, bit) X(name, f1c, bit)
153
+ C(sse3, 0)
154
+ C(pclmuldq, 1)
155
+ C(dtes64, 2)
156
+ C(monitor, 3)
157
+ C(dscpl, 4)
158
+ C(vmx, 5)
159
+ C(smx, 6)
160
+ C(eist, 7)
161
+ C(tm2, 8)
162
+ C(ssse3, 9)
163
+ C(cnxtid, 10)
164
+ C(fma, 12)
165
+ C(cx16, 13)
166
+ C(xtpr, 14)
167
+ C(pdcm, 15)
168
+ C(pcid, 17)
169
+ C(dca, 18)
170
+ C(sse41, 19)
171
+ C(sse42, 20)
172
+ C(x2apic, 21)
173
+ C(movbe, 22)
174
+ C(popcnt, 23)
175
+ C(tscdeadline, 24)
176
+ C(aes, 25)
177
+ C(xsave, 26)
178
+ C(osxsave, 27)
179
+ C(avx, 28)
180
+ C(f16c, 29)
181
+ C(rdrand, 30)
182
+ #undef C
183
+ #define D(name, bit) X(name, f1d, bit)
184
+ D(fpu, 0)
185
+ D(vme, 1)
186
+ D(de, 2)
187
+ D(pse, 3)
188
+ D(tsc, 4)
189
+ D(msr, 5)
190
+ D(pae, 6)
191
+ D(mce, 7)
192
+ D(cx8, 8)
193
+ D(apic, 9)
194
+ D(sep, 11)
195
+ D(mtrr, 12)
196
+ D(pge, 13)
197
+ D(mca, 14)
198
+ D(cmov, 15)
199
+ D(pat, 16)
200
+ D(pse36, 17)
201
+ D(psn, 18)
202
+ D(clfsh, 19)
203
+ D(ds, 21)
204
+ D(acpi, 22)
205
+ D(mmx, 23)
206
+ D(fxsr, 24)
207
+ D(sse, 25)
208
+ D(sse2, 26)
209
+ D(ss, 27)
210
+ D(htt, 28)
211
+ D(tm, 29)
212
+ D(pbe, 31)
213
+ #undef D
214
+
215
+ /* cpuid(7): Extended Features. */
216
+ #define B(name, bit) X(name, f7b, bit)
217
+ B(bmi1, 3)
218
+ B(hle, 4)
219
+ B(avx2, 5)
220
+ B(smep, 7)
221
+ B(bmi2, 8)
222
+ B(erms, 9)
223
+ B(invpcid, 10)
224
+ B(rtm, 11)
225
+ B(mpx, 14)
226
+ B(avx512f, 16)
227
+ B(avx512dq, 17)
228
+ B(rdseed, 18)
229
+ B(adx, 19)
230
+ B(smap, 20)
231
+ B(avx512ifma, 21)
232
+ B(pcommit, 22)
233
+ B(clflushopt, 23)
234
+ B(clwb, 24)
235
+ B(avx512pf, 26)
236
+ B(avx512er, 27)
237
+ B(avx512cd, 28)
238
+ B(sha, 29)
239
+ B(avx512bw, 30)
240
+ B(avx512vl, 31)
241
+ #undef B
242
+ #define C(name, bit) X(name, f7c, bit)
243
+ C(prefetchwt1, 0)
244
+ C(avx512vbmi, 1)
245
+ #undef C
246
+
247
+ #undef X
248
+
249
+ #endif /* ZSTD_COMMON_CPU_H */