2017-10-26 20:41:47 +00:00
/*
2023-05-22 12:32:14 +00:00
* Copyright ( c ) Meta Platforms , Inc . and affiliates .
2017-10-26 20:41:47 +00:00
* All rights reserved .
*
* 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 ) .
* You may select , at your option , one of the above - listed licenses .
*/
# ifndef ZSTD_LAZY_H
# define ZSTD_LAZY_H
# if defined (__cplusplus)
extern " C " {
# endif
2018-05-15 17:45:22 +00:00
# include "zstd_compress_internal.h"
2021-01-08 10:21:43 +00:00
/**
* Dedicated Dictionary Search Structure bucket log . In the
* ZSTD_dedicatedDictSearch mode , the hashTable has
* 2 * * ZSTD_LAZY_DDSS_BUCKET_LOG entries in each bucket , rather than just
* one .
*/
# define ZSTD_LAZY_DDSS_BUCKET_LOG 2
2023-05-22 12:32:14 +00:00
# define ZSTD_ROW_HASH_TAG_BITS 8 /* nb bits to use for the tag */
2024-04-05 09:22:55 +00:00
# if !defined(ZSTD_EXCLUDE_GREEDY_BLOCK_COMPRESSOR) \
| | ! defined ( ZSTD_EXCLUDE_LAZY_BLOCK_COMPRESSOR ) \
| | ! defined ( ZSTD_EXCLUDE_LAZY2_BLOCK_COMPRESSOR ) \
| | ! defined ( ZSTD_EXCLUDE_BTLAZY2_BLOCK_COMPRESSOR )
2019-01-04 00:30:03 +00:00
U32 ZSTD_insertAndFindFirstIndex ( ZSTD_matchState_t * ms , const BYTE * ip ) ;
2021-11-19 11:54:45 +00:00
void ZSTD_row_update ( ZSTD_matchState_t * const ms , const BYTE * ip ) ;
2018-05-15 17:45:22 +00:00
2021-01-08 10:21:43 +00:00
void ZSTD_dedicatedDictSearch_lazy_loadDictionary ( ZSTD_matchState_t * ms , const BYTE * const ip ) ;
2019-04-18 09:53:29 +00:00
void ZSTD_preserveUnsortedMark ( U32 * const table , U32 const size , U32 const reducerValue ) ; /*! used in ZSTD_reduceIndex(). preemptively increase value of ZSTD_DUBT_UNSORTED_MARK */
2024-04-05 09:22:55 +00:00
# endif
2018-05-15 17:45:22 +00:00
2024-04-05 09:22:55 +00:00
# ifndef ZSTD_EXCLUDE_GREEDY_BLOCK_COMPRESSOR
size_t ZSTD_compressBlock_greedy (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_row (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_dictMatchState (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_dictMatchState_row (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_dedicatedDictSearch (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_dedicatedDictSearch_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_extDict (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_greedy_extDict_row (
2019-01-04 00:30:03 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
# define ZSTD_COMPRESSBLOCK_GREEDY ZSTD_compressBlock_greedy
# define ZSTD_COMPRESSBLOCK_GREEDY_ROW ZSTD_compressBlock_greedy_row
# define ZSTD_COMPRESSBLOCK_GREEDY_DICTMATCHSTATE ZSTD_compressBlock_greedy_dictMatchState
# define ZSTD_COMPRESSBLOCK_GREEDY_DICTMATCHSTATE_ROW ZSTD_compressBlock_greedy_dictMatchState_row
# define ZSTD_COMPRESSBLOCK_GREEDY_DEDICATEDDICTSEARCH ZSTD_compressBlock_greedy_dedicatedDictSearch
# define ZSTD_COMPRESSBLOCK_GREEDY_DEDICATEDDICTSEARCH_ROW ZSTD_compressBlock_greedy_dedicatedDictSearch_row
# define ZSTD_COMPRESSBLOCK_GREEDY_EXTDICT ZSTD_compressBlock_greedy_extDict
# define ZSTD_COMPRESSBLOCK_GREEDY_EXTDICT_ROW ZSTD_compressBlock_greedy_extDict_row
# else
# define ZSTD_COMPRESSBLOCK_GREEDY NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_ROW NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_DICTMATCHSTATE NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_DICTMATCHSTATE_ROW NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_DEDICATEDDICTSEARCH NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_DEDICATEDDICTSEARCH_ROW NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_EXTDICT NULL
# define ZSTD_COMPRESSBLOCK_GREEDY_EXTDICT_ROW NULL
# endif
# ifndef ZSTD_EXCLUDE_LAZY_BLOCK_COMPRESSOR
size_t ZSTD_compressBlock_lazy (
2019-01-04 00:30:03 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_row (
2019-01-04 00:30:03 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_dictMatchState (
2019-01-04 00:30:03 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_dictMatchState_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_dedicatedDictSearch (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_dedicatedDictSearch_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_extDict (
2021-01-08 10:21:43 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy_extDict_row (
2021-01-08 10:21:43 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
# define ZSTD_COMPRESSBLOCK_LAZY ZSTD_compressBlock_lazy
# define ZSTD_COMPRESSBLOCK_LAZY_ROW ZSTD_compressBlock_lazy_row
# define ZSTD_COMPRESSBLOCK_LAZY_DICTMATCHSTATE ZSTD_compressBlock_lazy_dictMatchState
# define ZSTD_COMPRESSBLOCK_LAZY_DICTMATCHSTATE_ROW ZSTD_compressBlock_lazy_dictMatchState_row
# define ZSTD_COMPRESSBLOCK_LAZY_DEDICATEDDICTSEARCH ZSTD_compressBlock_lazy_dedicatedDictSearch
# define ZSTD_COMPRESSBLOCK_LAZY_DEDICATEDDICTSEARCH_ROW ZSTD_compressBlock_lazy_dedicatedDictSearch_row
# define ZSTD_COMPRESSBLOCK_LAZY_EXTDICT ZSTD_compressBlock_lazy_extDict
# define ZSTD_COMPRESSBLOCK_LAZY_EXTDICT_ROW ZSTD_compressBlock_lazy_extDict_row
# else
# define ZSTD_COMPRESSBLOCK_LAZY NULL
# define ZSTD_COMPRESSBLOCK_LAZY_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY_DICTMATCHSTATE NULL
# define ZSTD_COMPRESSBLOCK_LAZY_DICTMATCHSTATE_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY_DEDICATEDDICTSEARCH NULL
# define ZSTD_COMPRESSBLOCK_LAZY_DEDICATEDDICTSEARCH_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY_EXTDICT NULL
# define ZSTD_COMPRESSBLOCK_LAZY_EXTDICT_ROW NULL
# endif
# ifndef ZSTD_EXCLUDE_LAZY2_BLOCK_COMPRESSOR
size_t ZSTD_compressBlock_lazy2 (
2021-01-08 10:21:43 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_dictMatchState (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_dictMatchState_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_dedicatedDictSearch (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_dedicatedDictSearch_row (
2018-05-15 17:45:22 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2018-05-15 17:45:22 +00:00
size_t ZSTD_compressBlock_lazy2_extDict (
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_lazy2_extDict_row (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
# define ZSTD_COMPRESSBLOCK_LAZY2 ZSTD_compressBlock_lazy2
# define ZSTD_COMPRESSBLOCK_LAZY2_ROW ZSTD_compressBlock_lazy2_row
# define ZSTD_COMPRESSBLOCK_LAZY2_DICTMATCHSTATE ZSTD_compressBlock_lazy2_dictMatchState
# define ZSTD_COMPRESSBLOCK_LAZY2_DICTMATCHSTATE_ROW ZSTD_compressBlock_lazy2_dictMatchState_row
# define ZSTD_COMPRESSBLOCK_LAZY2_DEDICATEDDICTSEARCH ZSTD_compressBlock_lazy2_dedicatedDictSearch
# define ZSTD_COMPRESSBLOCK_LAZY2_DEDICATEDDICTSEARCH_ROW ZSTD_compressBlock_lazy2_dedicatedDictSearch_row
# define ZSTD_COMPRESSBLOCK_LAZY2_EXTDICT ZSTD_compressBlock_lazy2_extDict
# define ZSTD_COMPRESSBLOCK_LAZY2_EXTDICT_ROW ZSTD_compressBlock_lazy2_extDict_row
# else
# define ZSTD_COMPRESSBLOCK_LAZY2 NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_DICTMATCHSTATE NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_DICTMATCHSTATE_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_DEDICATEDDICTSEARCH NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_DEDICATEDDICTSEARCH_ROW NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_EXTDICT NULL
# define ZSTD_COMPRESSBLOCK_LAZY2_EXTDICT_ROW NULL
# endif
# ifndef ZSTD_EXCLUDE_BTLAZY2_BLOCK_COMPRESSOR
size_t ZSTD_compressBlock_btlazy2 (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2024-04-05 09:22:55 +00:00
size_t ZSTD_compressBlock_btlazy2_dictMatchState (
2021-11-19 11:54:45 +00:00
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
2018-05-15 17:45:22 +00:00
size_t ZSTD_compressBlock_btlazy2_extDict (
ZSTD_matchState_t * ms , seqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2019-01-04 00:30:03 +00:00
void const * src , size_t srcSize ) ;
2023-05-22 12:32:14 +00:00
2024-04-05 09:22:55 +00:00
# define ZSTD_COMPRESSBLOCK_BTLAZY2 ZSTD_compressBlock_btlazy2
# define ZSTD_COMPRESSBLOCK_BTLAZY2_DICTMATCHSTATE ZSTD_compressBlock_btlazy2_dictMatchState
# define ZSTD_COMPRESSBLOCK_BTLAZY2_EXTDICT ZSTD_compressBlock_btlazy2_extDict
# else
# define ZSTD_COMPRESSBLOCK_BTLAZY2 NULL
# define ZSTD_COMPRESSBLOCK_BTLAZY2_DICTMATCHSTATE NULL
# define ZSTD_COMPRESSBLOCK_BTLAZY2_EXTDICT NULL
# endif
2017-10-26 20:41:47 +00:00
# if defined (__cplusplus)
}
# endif
# endif /* ZSTD_LAZY_H */