Skip to content

Commit b52f603

Browse files
authored
Merge pull request #143 from DataDog/viq111/1.5.6
Update vendored zstd to 1.5.6
2 parents dd7b332 + cf4778e commit b52f603

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

53 files changed

+4665
-2365
lines changed

README.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -6,8 +6,8 @@
66

77
[C Zstd Homepage](https://github.com/facebook/zstd)
88

9-
The current headers and C files are from *v1.5.5* (Commit
10-
[63779c79](https://github.com/facebook/zstd/releases/tag/v1.5.5)).
9+
The current headers and C files are from *v1.5.6* (Commit
10+
[794ea1b](https://github.com/facebook/zstd/releases/tag/v1.5.6)).
1111

1212
## Usage
1313

allocations.h

+1-1
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,7 @@
1515
#define ZSTD_DEPS_NEED_MALLOC
1616
#include "zstd_deps.h" /* ZSTD_malloc, ZSTD_calloc, ZSTD_free, ZSTD_memset */
1717

18-
#include "mem.h" /* MEM_STATIC */
18+
#include "compiler.h" /* MEM_STATIC */
1919
#define ZSTD_STATIC_LINKING_ONLY
2020
#include "zstd.h" /* ZSTD_customMem */
2121

bitstream.h

+49-29
Original file line numberDiff line numberDiff line change
@@ -91,19 +91,20 @@ MEM_STATIC size_t BIT_closeCStream(BIT_CStream_t* bitC);
9191
/*-********************************************
9292
* bitStream decoding API (read backward)
9393
**********************************************/
94+
typedef size_t BitContainerType;
9495
typedef struct {
95-
size_t bitContainer;
96+
BitContainerType bitContainer;
9697
unsigned bitsConsumed;
9798
const char* ptr;
9899
const char* start;
99100
const char* limitPtr;
100101
} BIT_DStream_t;
101102

102-
typedef enum { BIT_DStream_unfinished = 0,
103-
BIT_DStream_endOfBuffer = 1,
104-
BIT_DStream_completed = 2,
105-
BIT_DStream_overflow = 3 } BIT_DStream_status; /* result of BIT_reloadDStream() */
106-
/* 1,2,4,8 would be better for bitmap combinations, but slows down performance a bit ... :( */
103+
typedef enum { BIT_DStream_unfinished = 0, /* fully refilled */
104+
BIT_DStream_endOfBuffer = 1, /* still some bits left in bitstream */
105+
BIT_DStream_completed = 2, /* bitstream entirely consumed, bit-exact */
106+
BIT_DStream_overflow = 3 /* user requested more bits than present in bitstream */
107+
} BIT_DStream_status; /* result of BIT_reloadDStream() */
107108

108109
MEM_STATIC size_t BIT_initDStream(BIT_DStream_t* bitD, const void* srcBuffer, size_t srcSize);
109110
MEM_STATIC size_t BIT_readBits(BIT_DStream_t* bitD, unsigned nbBits);
@@ -113,7 +114,7 @@ MEM_STATIC unsigned BIT_endOfDStream(const BIT_DStream_t* bitD);
113114

114115
/* Start by invoking BIT_initDStream().
115116
* A chunk of the bitStream is then stored into a local register.
116-
* Local register size is 64-bits on 64-bits systems, 32-bits on 32-bits systems (size_t).
117+
* Local register size is 64-bits on 64-bits systems, 32-bits on 32-bits systems (BitContainerType).
117118
* You can then retrieve bitFields stored into the local register, **in reverse order**.
118119
* Local register is explicitly reloaded from memory by the BIT_reloadDStream() method.
119120
* A reload guarantee a minimum of ((8*sizeof(bitD->bitContainer))-7) bits when its result is BIT_DStream_unfinished.
@@ -163,7 +164,7 @@ MEM_STATIC size_t BIT_initCStream(BIT_CStream_t* bitC,
163164
return 0;
164165
}
165166

166-
MEM_STATIC FORCE_INLINE_ATTR size_t BIT_getLowerBits(size_t bitContainer, U32 const nbBits)
167+
FORCE_INLINE_TEMPLATE size_t BIT_getLowerBits(size_t bitContainer, U32 const nbBits)
167168
{
168169
#if defined(STATIC_BMI2) && STATIC_BMI2 == 1 && !defined(ZSTD_NO_INTRINSICS)
169170
return _bzhi_u64(bitContainer, nbBits);
@@ -268,22 +269,22 @@ MEM_STATIC size_t BIT_initDStream(BIT_DStream_t* bitD, const void* srcBuffer, si
268269
bitD->bitContainer = *(const BYTE*)(bitD->start);
269270
switch(srcSize)
270271
{
271-
case 7: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[6]) << (sizeof(bitD->bitContainer)*8 - 16);
272+
case 7: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[6]) << (sizeof(bitD->bitContainer)*8 - 16);
272273
ZSTD_FALLTHROUGH;
273274

274-
case 6: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[5]) << (sizeof(bitD->bitContainer)*8 - 24);
275+
case 6: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[5]) << (sizeof(bitD->bitContainer)*8 - 24);
275276
ZSTD_FALLTHROUGH;
276277

277-
case 5: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[4]) << (sizeof(bitD->bitContainer)*8 - 32);
278+
case 5: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[4]) << (sizeof(bitD->bitContainer)*8 - 32);
278279
ZSTD_FALLTHROUGH;
279280

280-
case 4: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[3]) << 24;
281+
case 4: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[3]) << 24;
281282
ZSTD_FALLTHROUGH;
282283

283-
case 3: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[2]) << 16;
284+
case 3: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[2]) << 16;
284285
ZSTD_FALLTHROUGH;
285286

286-
case 2: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[1]) << 8;
287+
case 2: bitD->bitContainer += (BitContainerType)(((const BYTE*)(srcBuffer))[1]) << 8;
287288
ZSTD_FALLTHROUGH;
288289

289290
default: break;
@@ -298,12 +299,12 @@ MEM_STATIC size_t BIT_initDStream(BIT_DStream_t* bitD, const void* srcBuffer, si
298299
return srcSize;
299300
}
300301

301-
MEM_STATIC FORCE_INLINE_ATTR size_t BIT_getUpperBits(size_t bitContainer, U32 const start)
302+
FORCE_INLINE_TEMPLATE size_t BIT_getUpperBits(BitContainerType bitContainer, U32 const start)
302303
{
303304
return bitContainer >> start;
304305
}
305306

306-
MEM_STATIC FORCE_INLINE_ATTR size_t BIT_getMiddleBits(size_t bitContainer, U32 const start, U32 const nbBits)
307+
FORCE_INLINE_TEMPLATE size_t BIT_getMiddleBits(BitContainerType bitContainer, U32 const start, U32 const nbBits)
307308
{
308309
U32 const regMask = sizeof(bitContainer)*8 - 1;
309310
/* if start > regMask, bitstream is corrupted, and result is undefined */
@@ -326,7 +327,7 @@ MEM_STATIC FORCE_INLINE_ATTR size_t BIT_getMiddleBits(size_t bitContainer, U32 c
326327
* On 32-bits, maxNbBits==24.
327328
* On 64-bits, maxNbBits==56.
328329
* @return : value extracted */
329-
MEM_STATIC FORCE_INLINE_ATTR size_t BIT_lookBits(const BIT_DStream_t* bitD, U32 nbBits)
330+
FORCE_INLINE_TEMPLATE size_t BIT_lookBits(const BIT_DStream_t* bitD, U32 nbBits)
330331
{
331332
/* arbitrate between double-shift and shift+mask */
332333
#if 1
@@ -349,7 +350,7 @@ MEM_STATIC size_t BIT_lookBitsFast(const BIT_DStream_t* bitD, U32 nbBits)
349350
return (bitD->bitContainer << (bitD->bitsConsumed & regMask)) >> (((regMask+1)-nbBits) & regMask);
350351
}
351352

352-
MEM_STATIC FORCE_INLINE_ATTR void BIT_skipBits(BIT_DStream_t* bitD, U32 nbBits)
353+
FORCE_INLINE_TEMPLATE void BIT_skipBits(BIT_DStream_t* bitD, U32 nbBits)
353354
{
354355
bitD->bitsConsumed += nbBits;
355356
}
@@ -358,7 +359,7 @@ MEM_STATIC FORCE_INLINE_ATTR void BIT_skipBits(BIT_DStream_t* bitD, U32 nbBits)
358359
* Read (consume) next n bits from local register and update.
359360
* Pay attention to not read more than nbBits contained into local register.
360361
* @return : extracted value. */
361-
MEM_STATIC FORCE_INLINE_ATTR size_t BIT_readBits(BIT_DStream_t* bitD, unsigned nbBits)
362+
FORCE_INLINE_TEMPLATE size_t BIT_readBits(BIT_DStream_t* bitD, unsigned nbBits)
362363
{
363364
size_t const value = BIT_lookBits(bitD, nbBits);
364365
BIT_skipBits(bitD, nbBits);
@@ -375,6 +376,21 @@ MEM_STATIC size_t BIT_readBitsFast(BIT_DStream_t* bitD, unsigned nbBits)
375376
return value;
376377
}
377378

379+
/*! BIT_reloadDStream_internal() :
380+
* Simple variant of BIT_reloadDStream(), with two conditions:
381+
* 1. bitstream is valid : bitsConsumed <= sizeof(bitD->bitContainer)*8
382+
* 2. look window is valid after shifted down : bitD->ptr >= bitD->start
383+
*/
384+
MEM_STATIC BIT_DStream_status BIT_reloadDStream_internal(BIT_DStream_t* bitD)
385+
{
386+
assert(bitD->bitsConsumed <= sizeof(bitD->bitContainer)*8);
387+
bitD->ptr -= bitD->bitsConsumed >> 3;
388+
assert(bitD->ptr >= bitD->start);
389+
bitD->bitsConsumed &= 7;
390+
bitD->bitContainer = MEM_readLEST(bitD->ptr);
391+
return BIT_DStream_unfinished;
392+
}
393+
378394
/*! BIT_reloadDStreamFast() :
379395
* Similar to BIT_reloadDStream(), but with two differences:
380396
* 1. bitsConsumed <= sizeof(bitD->bitContainer)*8 must hold!
@@ -385,31 +401,35 @@ MEM_STATIC BIT_DStream_status BIT_reloadDStreamFast(BIT_DStream_t* bitD)
385401
{
386402
if (UNLIKELY(bitD->ptr < bitD->limitPtr))
387403
return BIT_DStream_overflow;
388-
assert(bitD->bitsConsumed <= sizeof(bitD->bitContainer)*8);
389-
bitD->ptr -= bitD->bitsConsumed >> 3;
390-
bitD->bitsConsumed &= 7;
391-
bitD->bitContainer = MEM_readLEST(bitD->ptr);
392-
return BIT_DStream_unfinished;
404+
return BIT_reloadDStream_internal(bitD);
393405
}
394406

395407
/*! BIT_reloadDStream() :
396408
* Refill `bitD` from buffer previously set in BIT_initDStream() .
397-
* This function is safe, it guarantees it will not read beyond src buffer.
409+
* This function is safe, it guarantees it will not never beyond src buffer.
398410
* @return : status of `BIT_DStream_t` internal register.
399411
* when status == BIT_DStream_unfinished, internal register is filled with at least 25 or 57 bits */
400-
MEM_STATIC FORCE_INLINE_ATTR BIT_DStream_status BIT_reloadDStream(BIT_DStream_t* bitD)
412+
FORCE_INLINE_TEMPLATE BIT_DStream_status BIT_reloadDStream(BIT_DStream_t* bitD)
401413
{
402-
if (bitD->bitsConsumed > (sizeof(bitD->bitContainer)*8)) /* overflow detected, like end of stream */
414+
/* note : once in overflow mode, a bitstream remains in this mode until it's reset */
415+
if (UNLIKELY(bitD->bitsConsumed > (sizeof(bitD->bitContainer)*8))) {
416+
static const BitContainerType zeroFilled = 0;
417+
bitD->ptr = (const char*)&zeroFilled; /* aliasing is allowed for char */
418+
/* overflow detected, erroneous scenario or end of stream: no update */
403419
return BIT_DStream_overflow;
420+
}
421+
422+
assert(bitD->ptr >= bitD->start);
404423

405424
if (bitD->ptr >= bitD->limitPtr) {
406-
return BIT_reloadDStreamFast(bitD);
425+
return BIT_reloadDStream_internal(bitD);
407426
}
408427
if (bitD->ptr == bitD->start) {
428+
/* reached end of bitStream => no update */
409429
if (bitD->bitsConsumed < sizeof(bitD->bitContainer)*8) return BIT_DStream_endOfBuffer;
410430
return BIT_DStream_completed;
411431
}
412-
/* start < ptr < limitPtr */
432+
/* start < ptr < limitPtr => cautious update */
413433
{ U32 nbBytes = bitD->bitsConsumed >> 3;
414434
BIT_DStream_status result = BIT_DStream_unfinished;
415435
if (bitD->ptr - nbBytes < bitD->start) {

0 commit comments

Comments
 (0)