2025-12-30 19:51:25 +01:00
// SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0-only
2022-03-01 08:32:52 -05:00
/*
2025-12-27 21:25:25 +01:00
* Copyright (c) Meta Platforms, Inc. and affiliates.
2022-03-01 08:32:52 -05: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
# include "zstd_compress_internal.h"
2025-12-27 21:25:25 +01: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
# define ZSTD_ROW_HASH_TAG_BITS 8 /* nb bits to use for the tag */
# 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)
U32 ZSTD_insertAndFindFirstIndex ( ZSTD_MatchState_t * ms , const BYTE * ip ) ;
void ZSTD_row_update ( ZSTD_MatchState_t * const ms , const BYTE * ip ) ;
void ZSTD_dedicatedDictSearch_lazy_loadDictionary ( ZSTD_MatchState_t * ms , const BYTE * const ip ) ;
2022-03-01 08:32:52 -05: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 */
2025-12-27 21:25:25 +01:00
# endif
2022-03-01 08:32:52 -05:00
2025-12-27 21:25:25 +01:00
# ifndef ZSTD_EXCLUDE_GREEDY_BLOCK_COMPRESSOR
size_t ZSTD_compressBlock_greedy (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_greedy_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_greedy_dictMatchState (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_greedy_dictMatchState_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_greedy_dedicatedDictSearch (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_greedy_dedicatedDictSearch_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_greedy_extDict (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_greedy_extDict_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01: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 (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_lazy_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy_dictMatchState (
2025-12-27 21:25:25 +01:00
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_lazy_dictMatchState_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01:00
size_t ZSTD_compressBlock_lazy_dedicatedDictSearch (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy_dedicatedDictSearch_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy_extDict (
2025-12-27 21:25:25 +01:00
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy_extDict_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
# 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 (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_dictMatchState (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_dictMatchState_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_dedicatedDictSearch (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_dedicatedDictSearch_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_extDict (
2025-12-27 21:25:25 +01:00
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_lazy2_extDict_row (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
# 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 (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_btlazy2_dictMatchState (
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
size_t ZSTD_compressBlock_btlazy2_extDict (
2025-12-27 21:25:25 +01:00
ZSTD_MatchState_t * ms , SeqStore_t * seqStore , U32 rep [ ZSTD_REP_NUM ] ,
2022-03-01 08:32:52 -05:00
void const * src , size_t srcSize ) ;
2025-12-27 21:25:25 +01: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
2022-03-01 08:32:52 -05:00
# endif
# endif /* ZSTD_LAZY_H */