| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |  * Copyright (c) 2016-present, Yann Collet, Facebook, Inc. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  |  * This source code is licensed under both the BSD-style license (found in the | 
					
						
							|  |  |  |  * LICENSE file in the root directory of this source tree) and the GPLv2 (found | 
					
						
							|  |  |  |  * in the COPYING file in the root directory of this source tree). | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |  * You may select, at your option, one of the above-listed licenses. | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef ZSTD_CCOMMON_H_MODULE
 | 
					
						
							|  |  |  | #define ZSTD_CCOMMON_H_MODULE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | /* this module contains definitions which must be identical
 | 
					
						
							|  |  |  |  * across compression, decompression and dictBuilder. | 
					
						
							|  |  |  |  * It also contains a few functions useful to at least 2 of them | 
					
						
							|  |  |  |  * and which benefit from being inlined */ | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*-*************************************
 | 
					
						
							|  |  |  | *  Dependencies | 
					
						
							|  |  |  | ***************************************/ | 
					
						
							| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  | #include "compiler.h"
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #include "mem.h"
 | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  | #include "debug.h"                 /* assert, DEBUGLOG, RAWLOG, g_debuglevel */
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #include "error_private.h"
 | 
					
						
							|  |  |  | #define ZSTD_STATIC_LINKING_ONLY
 | 
					
						
							|  |  |  | #include "zstd.h"
 | 
					
						
							| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  | #define FSE_STATIC_LINKING_ONLY
 | 
					
						
							|  |  |  | #include "fse.h"
 | 
					
						
							|  |  |  | #define HUF_STATIC_LINKING_ONLY
 | 
					
						
							|  |  |  | #include "huf.h"
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #ifndef XXH_STATIC_LINKING_ONLY
 | 
					
						
							| 
									
										
										
										
											2017-07-22 18:46:05 -03:00
										 |  |  | #  define XXH_STATIC_LINKING_ONLY  /* XXH64_state_t */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include "xxhash.h"                /* XXH_reset, update, digest */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  | #if defined (__cplusplus)
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  | /* ---- static assert (debug) --- */ | 
					
						
							|  |  |  | #define ZSTD_STATIC_ASSERT(c) DEBUG_STATIC_ASSERT(c)
 | 
					
						
							|  |  |  | #define ZSTD_isError ERR_isError   /* for inlining */
 | 
					
						
							|  |  |  | #define FSE_isError  ERR_isError
 | 
					
						
							|  |  |  | #define HUF_isError  ERR_isError
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-*************************************
 | 
					
						
							|  |  |  | *  shared macros | 
					
						
							|  |  |  | ***************************************/ | 
					
						
							|  |  |  | #undef MIN
 | 
					
						
							|  |  |  | #undef MAX
 | 
					
						
							|  |  |  | #define MIN(a,b) ((a)<(b) ? (a) : (b))
 | 
					
						
							|  |  |  | #define MAX(a,b) ((a)>(b) ? (a) : (b))
 | 
					
						
							| 
									
										
										
										
											2019-04-18 11:53:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Return the specified error if the condition evaluates to true. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-11-01 21:36:06 -05:00
										 |  |  |  * In debug modes, prints additional information. | 
					
						
							|  |  |  |  * In order to do that (particularly, printing the conditional that failed), | 
					
						
							|  |  |  |  * this can't just wrap RETURN_ERROR(). | 
					
						
							| 
									
										
										
										
											2019-04-18 11:53:29 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | #define RETURN_ERROR_IF(cond, err, ...) \
 | 
					
						
							|  |  |  |   if (cond) { \ | 
					
						
							|  |  |  |     RAWLOG(3, "%s:%d: ERROR!: check %s failed, returning %s", __FILE__, __LINE__, ZSTD_QUOTE(cond), ZSTD_QUOTE(ERROR(err))); \ | 
					
						
							|  |  |  |     RAWLOG(3, ": " __VA_ARGS__); \ | 
					
						
							|  |  |  |     RAWLOG(3, "\n"); \ | 
					
						
							|  |  |  |     return ERROR(err); \ | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Unconditionally return the specified error. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In debug modes, prints additional information. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define RETURN_ERROR(err, ...) \
 | 
					
						
							|  |  |  |   do { \ | 
					
						
							|  |  |  |     RAWLOG(3, "%s:%d: ERROR!: unconditional check failed, returning %s", __FILE__, __LINE__, ZSTD_QUOTE(ERROR(err))); \ | 
					
						
							|  |  |  |     RAWLOG(3, ": " __VA_ARGS__); \ | 
					
						
							|  |  |  |     RAWLOG(3, "\n"); \ | 
					
						
							|  |  |  |     return ERROR(err); \ | 
					
						
							|  |  |  |   } while(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * If the provided expression evaluates to an error code, returns that error code. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In debug modes, prints additional information. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define FORWARD_IF_ERROR(err, ...) \
 | 
					
						
							|  |  |  |   do { \ | 
					
						
							|  |  |  |     size_t const err_code = (err); \ | 
					
						
							|  |  |  |     if (ERR_isError(err_code)) { \ | 
					
						
							|  |  |  |       RAWLOG(3, "%s:%d: ERROR!: forwarding error in %s: %s", __FILE__, __LINE__, ZSTD_QUOTE(err), ERR_getErrorName(err_code)); \ | 
					
						
							|  |  |  |       RAWLOG(3, ": " __VA_ARGS__); \ | 
					
						
							|  |  |  |       RAWLOG(3, "\n"); \ | 
					
						
							|  |  |  |       return err_code; \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   } while(0); | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-*************************************
 | 
					
						
							|  |  |  | *  Common constants | 
					
						
							|  |  |  | ***************************************/ | 
					
						
							|  |  |  | #define ZSTD_OPT_NUM    (1<<12)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ZSTD_REP_NUM      3                 /* number of repcodes */
 | 
					
						
							|  |  |  | #define ZSTD_REP_MOVE     (ZSTD_REP_NUM-1)
 | 
					
						
							|  |  |  | static const U32 repStartValue[ZSTD_REP_NUM] = { 1, 4, 8 }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define KB *(1 <<10)
 | 
					
						
							|  |  |  | #define MB *(1 <<20)
 | 
					
						
							|  |  |  | #define GB *(1U<<30)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BIT7 128
 | 
					
						
							|  |  |  | #define BIT6  64
 | 
					
						
							|  |  |  | #define BIT5  32
 | 
					
						
							|  |  |  | #define BIT4  16
 | 
					
						
							|  |  |  | #define BIT1   2
 | 
					
						
							|  |  |  | #define BIT0   1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ZSTD_WINDOWLOG_ABSOLUTEMIN 10
 | 
					
						
							|  |  |  | static const size_t ZSTD_fcs_fieldSize[4] = { 0, 2, 4, 8 }; | 
					
						
							|  |  |  | static const size_t ZSTD_did_fieldSize[4] = { 0, 1, 2, 4 }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  | #define ZSTD_FRAMEIDSIZE 4   /* magic number size */
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #define ZSTD_BLOCKHEADERSIZE 3   /* C standard doesn't allow `static const` variable to be init using another `static const` variable */
 | 
					
						
							|  |  |  | static const size_t ZSTD_blockHeaderSize = ZSTD_BLOCKHEADERSIZE; | 
					
						
							|  |  |  | typedef enum { bt_raw, bt_rle, bt_compressed, bt_reserved } blockType_e; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MIN_SEQUENCES_SIZE 1 /* nbSeq==0 */
 | 
					
						
							|  |  |  | #define MIN_CBLOCK_SIZE (1 /*litCSize*/ + 1 /* RLE or RAW */ + MIN_SEQUENCES_SIZE /* nbSeq==0 */)   /* for a non-null block */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define HufLog 12
 | 
					
						
							|  |  |  | typedef enum { set_basic, set_rle, set_compressed, set_repeat } symbolEncodingType_e; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define LONGNBSEQ 0x7F00
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MINMATCH 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define Litbits  8
 | 
					
						
							|  |  |  | #define MaxLit ((1<<Litbits) - 1)
 | 
					
						
							| 
									
										
										
										
											2018-05-16 02:45:22 +09:00
										 |  |  | #define MaxML   52
 | 
					
						
							|  |  |  | #define MaxLL   35
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  | #define DefaultMaxOff 28
 | 
					
						
							| 
									
										
										
										
											2018-05-16 02:45:22 +09:00
										 |  |  | #define MaxOff  31
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #define MaxSeq MAX(MaxLL, MaxML)   /* Assumption : MaxOff < MaxLL,MaxML */
 | 
					
						
							|  |  |  | #define MLFSELog    9
 | 
					
						
							|  |  |  | #define LLFSELog    9
 | 
					
						
							|  |  |  | #define OffFSELog   8
 | 
					
						
							| 
									
										
										
										
											2018-05-16 02:45:22 +09:00
										 |  |  | #define MaxFSELog  MAX(MAX(MLFSELog, LLFSELog), OffFSELog)
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | static const U32 LL_bits[MaxLL+1] = { 0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       1, 1, 1, 1, 2, 2, 3, 3, | 
					
						
							|  |  |  |                                       4, 6, 7, 8, 9,10,11,12, | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |                                      13,14,15,16 }; | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | static const S16 LL_defaultNorm[MaxLL+1] = { 4, 3, 2, 2, 2, 2, 2, 2, | 
					
						
							|  |  |  |                                              2, 2, 2, 2, 2, 1, 1, 1, | 
					
						
							|  |  |  |                                              2, 2, 2, 2, 2, 2, 2, 2, | 
					
						
							|  |  |  |                                              2, 3, 2, 1, 1, 1, 1, 1, | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |                                             -1,-1,-1,-1 }; | 
					
						
							|  |  |  | #define LL_DEFAULTNORMLOG 6  /* for static allocation */
 | 
					
						
							|  |  |  | static const U32 LL_defaultNormLog = LL_DEFAULTNORMLOG; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | static const U32 ML_bits[MaxML+1] = { 0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       0, 0, 0, 0, 0, 0, 0, 0, | 
					
						
							|  |  |  |                                       1, 1, 1, 1, 2, 2, 3, 3, | 
					
						
							|  |  |  |                                       4, 4, 5, 7, 8, 9,10,11, | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |                                      12,13,14,15,16 }; | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | static const S16 ML_defaultNorm[MaxML+1] = { 1, 4, 3, 2, 2, 2, 2, 2, | 
					
						
							|  |  |  |                                              2, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                              1, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                              1, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                              1, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                              1, 1, 1, 1, 1, 1,-1,-1, | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |                                             -1,-1,-1,-1,-1 }; | 
					
						
							|  |  |  | #define ML_DEFAULTNORMLOG 6  /* for static allocation */
 | 
					
						
							|  |  |  | static const U32 ML_defaultNormLog = ML_DEFAULTNORMLOG; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | static const S16 OF_defaultNorm[DefaultMaxOff+1] = { 1, 1, 1, 1, 1, 1, 2, 2, | 
					
						
							|  |  |  |                                                      2, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                                      1, 1, 1, 1, 1, 1, 1, 1, | 
					
						
							|  |  |  |                                                     -1,-1,-1,-1,-1 }; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #define OF_DEFAULTNORMLOG 5  /* for static allocation */
 | 
					
						
							|  |  |  | static const U32 OF_defaultNormLog = OF_DEFAULTNORMLOG; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-*******************************************
 | 
					
						
							|  |  |  | *  Shared functions to include for inlining | 
					
						
							|  |  |  | *********************************************/ | 
					
						
							|  |  |  | static void ZSTD_copy8(void* dst, const void* src) { memcpy(dst, src, 8); } | 
					
						
							| 
									
										
										
										
											2019-07-20 20:47:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #define COPY8(d,s) { ZSTD_copy8(d,s); d+=8; s+=8; }
 | 
					
						
							| 
									
										
										
										
											2019-07-20 20:47:07 +02:00
										 |  |  | static void ZSTD_copy16(void* dst, const void* src) { memcpy(dst, src, 16); } | 
					
						
							|  |  |  | #define COPY16(d,s) { ZSTD_copy16(d,s); d+=16; s+=16; }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define WILDCOPY_OVERLENGTH 8
 | 
					
						
							|  |  |  | #define VECLEN 16
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef enum { | 
					
						
							|  |  |  |     ZSTD_no_overlap, | 
					
						
							|  |  |  |     ZSTD_overlap_src_before_dst, | 
					
						
							|  |  |  |     /*  ZSTD_overlap_dst_before_src, */ | 
					
						
							|  |  |  | } ZSTD_overlap_e; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*! ZSTD_wildcopy() :
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  |  *  custom version of memcpy(), can overwrite up to WILDCOPY_OVERLENGTH bytes (if length==0) */ | 
					
						
							| 
									
										
										
										
											2019-07-20 20:47:07 +02:00
										 |  |  | MEM_STATIC FORCE_INLINE_ATTR DONT_VECTORIZE | 
					
						
							|  |  |  | void ZSTD_wildcopy(void* dst, const void* src, ptrdiff_t length, ZSTD_overlap_e ovtype) | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-07-20 20:47:07 +02:00
										 |  |  |     ptrdiff_t diff = (BYTE*)dst - (const BYTE*)src; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |     const BYTE* ip = (const BYTE*)src; | 
					
						
							|  |  |  |     BYTE* op = (BYTE*)dst; | 
					
						
							|  |  |  |     BYTE* const oend = op + length; | 
					
						
							| 
									
										
										
										
											2019-07-20 20:47:07 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     assert(diff >= 8 || (ovtype == ZSTD_no_overlap && diff < -8)); | 
					
						
							|  |  |  |     if (length < VECLEN || (ovtype == ZSTD_overlap_src_before_dst && diff < VECLEN)) { | 
					
						
							|  |  |  |       do | 
					
						
							|  |  |  |           COPY8(op, ip) | 
					
						
							|  |  |  |       while (op < oend); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       if ((length & 8) == 0) | 
					
						
							|  |  |  |         COPY8(op, ip); | 
					
						
							|  |  |  |       do { | 
					
						
							|  |  |  |         COPY16(op, ip); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       while (op < oend); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! ZSTD_wildcopy_16min() :
 | 
					
						
							|  |  |  |  *  same semantics as ZSTD_wilcopy() except guaranteed to be able to copy 16 bytes at the start */ | 
					
						
							|  |  |  | MEM_STATIC FORCE_INLINE_ATTR DONT_VECTORIZE | 
					
						
							|  |  |  | void ZSTD_wildcopy_16min(void* dst, const void* src, ptrdiff_t length, ZSTD_overlap_e ovtype) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ptrdiff_t diff = (BYTE*)dst - (const BYTE*)src; | 
					
						
							|  |  |  |     const BYTE* ip = (const BYTE*)src; | 
					
						
							|  |  |  |     BYTE* op = (BYTE*)dst; | 
					
						
							|  |  |  |     BYTE* const oend = op + length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     assert(length >= 8); | 
					
						
							|  |  |  |     assert(diff >= 8 || (ovtype == ZSTD_no_overlap && diff < -8)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (ovtype == ZSTD_overlap_src_before_dst && diff < VECLEN) { | 
					
						
							|  |  |  |       do | 
					
						
							|  |  |  |           COPY8(op, ip) | 
					
						
							|  |  |  |       while (op < oend); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       if ((length & 8) == 0) | 
					
						
							|  |  |  |         COPY8(op, ip); | 
					
						
							|  |  |  |       do { | 
					
						
							|  |  |  |         COPY16(op, ip); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       while (op < oend); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MEM_STATIC void ZSTD_wildcopy_e(void* dst, const void* src, void* dstEnd)   /* should be faster for decoding, but strangely, not verified on all platform */ | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const BYTE* ip = (const BYTE*)src; | 
					
						
							|  |  |  |     BYTE* op = (BYTE*)dst; | 
					
						
							|  |  |  |     BYTE* const oend = (BYTE*)dstEnd; | 
					
						
							|  |  |  |     do | 
					
						
							|  |  |  |         COPY8(op, ip) | 
					
						
							|  |  |  |     while (op < oend); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-*******************************************
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | *  Private declarations | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | *********************************************/ | 
					
						
							|  |  |  | typedef struct seqDef_s { | 
					
						
							|  |  |  |     U32 offset; | 
					
						
							|  |  |  |     U16 litLength; | 
					
						
							|  |  |  |     U16 matchLength; | 
					
						
							|  |  |  | } seqDef; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |     seqDef* sequencesStart; | 
					
						
							|  |  |  |     seqDef* sequences; | 
					
						
							|  |  |  |     BYTE* litStart; | 
					
						
							|  |  |  |     BYTE* lit; | 
					
						
							|  |  |  |     BYTE* llCode; | 
					
						
							|  |  |  |     BYTE* mlCode; | 
					
						
							|  |  |  |     BYTE* ofCode; | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  |     size_t maxNbSeq; | 
					
						
							|  |  |  |     size_t maxNbLit; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  |     U32   longLengthID;   /* 0 == no longLength; 1 == Lit.longLength; 2 == Match.longLength; */ | 
					
						
							|  |  |  |     U32   longLengthPos; | 
					
						
							| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  | } seqStore_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 11:53:29 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Contains the compressed frame size and an upper-bound for the decompressed frame size. | 
					
						
							|  |  |  |  * Note: before using `compressedSize`, check for errors using ZSTD_isError(). | 
					
						
							|  |  |  |  *       similarly, before using `decompressedBound`, check for errors using: | 
					
						
							|  |  |  |  *          `decompressedBound != ZSTD_CONTENTSIZE_ERROR` | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |     size_t compressedSize; | 
					
						
							|  |  |  |     unsigned long long decompressedBound; | 
					
						
							|  |  |  | } ZSTD_frameSizeInfo;   /* decompress & legacy */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | const seqStore_t* ZSTD_getSeqStore(const ZSTD_CCtx* ctx);   /* compress & dictBuilder */ | 
					
						
							|  |  |  | void ZSTD_seqToCodes(const seqStore_t* seqStorePtr);   /* compress, dictBuilder, decodeCorpus (shouldn't get its definition from here) */ | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* custom memory allocation functions */ | 
					
						
							|  |  |  | void* ZSTD_malloc(size_t size, ZSTD_customMem customMem); | 
					
						
							| 
									
										
										
										
											2017-07-22 18:46:05 -03:00
										 |  |  | void* ZSTD_calloc(size_t size, ZSTD_customMem customMem); | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | void ZSTD_free(void* ptr, ZSTD_customMem customMem); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | MEM_STATIC U32 ZSTD_highbit32(U32 val)   /* compress, dictBuilder, decodeCorpus */ | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |     assert(val != 0); | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #   if defined(_MSC_VER)   /* Visual */
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |         unsigned long r=0; | 
					
						
							|  |  |  |         _BitScanReverse(&r, val); | 
					
						
							|  |  |  |         return (unsigned)r; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #   elif defined(__GNUC__) && (__GNUC__ >= 3)   /* GCC Intrinsic */
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |         return 31 - __builtin_clz(val); | 
					
						
							| 
									
										
										
										
											2019-11-01 21:36:06 -05:00
										 |  |  | #   elif defined(__ICCARM__)    /* IAR Intrinsic */
 | 
					
						
							|  |  |  |         return 31 - __CLZ(val); | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #   else   /* Software version */
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  |         static const U32 DeBruijnClz[32] = { 0, 9, 1, 10, 13, 21, 2, 29, 11, 14, 16, 18, 22, 25, 3, 30, 8, 12, 20, 28, 15, 17, 24, 7, 19, 27, 23, 6, 26, 5, 4, 31 }; | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |         U32 v = val; | 
					
						
							|  |  |  |         v |= v >> 1; | 
					
						
							|  |  |  |         v |= v >> 2; | 
					
						
							|  |  |  |         v |= v >> 4; | 
					
						
							|  |  |  |         v |= v >> 8; | 
					
						
							|  |  |  |         v |= v >> 16; | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  |         return DeBruijnClz[(v * 0x07C4ACDDU) >> 27]; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #   endif
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ZSTD_invalidateRepCodes() :
 | 
					
						
							|  |  |  |  * ensures next compression will not use repcodes from previous block. | 
					
						
							|  |  |  |  * Note : only works with regular variant; | 
					
						
							|  |  |  |  *        do not use with extDict variant ! */ | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  | void ZSTD_invalidateRepCodes(ZSTD_CCtx* cctx);   /* zstdmt, adaptive_compression (shouldn't get this definition from here) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-22 18:46:05 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-25 14:49:57 -03:00
										 |  |  | typedef struct { | 
					
						
							|  |  |  |     blockType_e blockType; | 
					
						
							|  |  |  |     U32 lastBlock; | 
					
						
							|  |  |  |     U32 origSize; | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  | } blockProperties_t;   /* declared here for decompress and fullbench */ | 
					
						
							| 
									
										
										
										
											2017-07-25 14:49:57 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*! ZSTD_getcBlockSize() :
 | 
					
						
							| 
									
										
										
										
											2018-01-13 13:50:59 +01:00
										 |  |  |  *  Provides the size of compressed block from block header `src` */ | 
					
						
							|  |  |  | /* Used by: decompress, fullbench (does not get its definition from here) */ | 
					
						
							| 
									
										
										
										
											2017-08-27 12:05:17 +02:00
										 |  |  | size_t ZSTD_getcBlockSize(const void* src, size_t srcSize, | 
					
						
							|  |  |  |                           blockProperties_t* bpPtr); | 
					
						
							| 
									
										
										
										
											2017-07-25 14:49:57 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-03 22:30:03 -02:00
										 |  |  | /*! ZSTD_decodeSeqHeaders() :
 | 
					
						
							|  |  |  |  *  decode sequence header from src */ | 
					
						
							|  |  |  | /* Used by: decompress, fullbench (does not get its definition from here) */ | 
					
						
							|  |  |  | size_t ZSTD_decodeSeqHeaders(ZSTD_DCtx* dctx, int* nbSeqPtr, | 
					
						
							|  |  |  |                        const void* src, size_t srcSize); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-26 16:41:47 -04:00
										 |  |  | #if defined (__cplusplus)
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-07-25 14:49:57 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:43:56 -05:00
										 |  |  | #endif   /* ZSTD_CCOMMON_H_MODULE */
 |