1*a28cd43dSSascha Wildner /* 2*a28cd43dSSascha Wildner * Copyright (c) 2016-2020, Yann Collet, Facebook, Inc. 3*a28cd43dSSascha Wildner * All rights reserved. 4*a28cd43dSSascha Wildner * 5*a28cd43dSSascha Wildner * This source code is licensed under both the BSD-style license (found in the 6*a28cd43dSSascha Wildner * LICENSE file in the root directory of this source tree) and the GPLv2 (found 7*a28cd43dSSascha Wildner * in the COPYING file in the root directory of this source tree). 8*a28cd43dSSascha Wildner * You may select, at your option, one of the above-listed licenses. 9*a28cd43dSSascha Wildner */ 10*a28cd43dSSascha Wildner 11*a28cd43dSSascha Wildner #ifndef ZSTDMT_COMPRESS_H 12*a28cd43dSSascha Wildner #define ZSTDMT_COMPRESS_H 13*a28cd43dSSascha Wildner 14*a28cd43dSSascha Wildner #if defined (__cplusplus) 15*a28cd43dSSascha Wildner extern "C" { 16*a28cd43dSSascha Wildner #endif 17*a28cd43dSSascha Wildner 18*a28cd43dSSascha Wildner 19*a28cd43dSSascha Wildner /* Note : This is an internal API. 20*a28cd43dSSascha Wildner * These APIs used to be exposed with ZSTDLIB_API, 21*a28cd43dSSascha Wildner * because it used to be the only way to invoke MT compression. 22*a28cd43dSSascha Wildner * Now, you must use ZSTD_compress2 and ZSTD_compressStream2() instead. 23*a28cd43dSSascha Wildner * 24*a28cd43dSSascha Wildner * This API requires ZSTD_MULTITHREAD to be defined during compilation, 25*a28cd43dSSascha Wildner * otherwise ZSTDMT_createCCtx*() will fail. 26*a28cd43dSSascha Wildner */ 27*a28cd43dSSascha Wildner 28*a28cd43dSSascha Wildner /* === Dependencies === */ 29*a28cd43dSSascha Wildner #include "../common/zstd_deps.h" /* size_t */ 30*a28cd43dSSascha Wildner #define ZSTD_STATIC_LINKING_ONLY /* ZSTD_parameters */ 31*a28cd43dSSascha Wildner #include "../zstd.h" /* ZSTD_inBuffer, ZSTD_outBuffer, ZSTDLIB_API */ 32*a28cd43dSSascha Wildner 33*a28cd43dSSascha Wildner 34*a28cd43dSSascha Wildner /* === Constants === */ 35*a28cd43dSSascha Wildner #ifndef ZSTDMT_NBWORKERS_MAX 36*a28cd43dSSascha Wildner # define ZSTDMT_NBWORKERS_MAX 200 37*a28cd43dSSascha Wildner #endif 38*a28cd43dSSascha Wildner #ifndef ZSTDMT_JOBSIZE_MIN 39*a28cd43dSSascha Wildner # define ZSTDMT_JOBSIZE_MIN (1 MB) 40*a28cd43dSSascha Wildner #endif 41*a28cd43dSSascha Wildner #define ZSTDMT_JOBLOG_MAX (MEM_32bits() ? 29 : 30) 42*a28cd43dSSascha Wildner #define ZSTDMT_JOBSIZE_MAX (MEM_32bits() ? (512 MB) : (1024 MB)) 43*a28cd43dSSascha Wildner 44*a28cd43dSSascha Wildner 45*a28cd43dSSascha Wildner /* ======================================================== 46*a28cd43dSSascha Wildner * === Private interface, for use by ZSTD_compress.c === 47*a28cd43dSSascha Wildner * === Not exposed in libzstd. Never invoke directly === 48*a28cd43dSSascha Wildner * ======================================================== */ 49*a28cd43dSSascha Wildner 50*a28cd43dSSascha Wildner /* === Memory management === */ 51*a28cd43dSSascha Wildner typedef struct ZSTDMT_CCtx_s ZSTDMT_CCtx; 52*a28cd43dSSascha Wildner /* Requires ZSTD_MULTITHREAD to be defined during compilation, otherwise it will return NULL. */ 53*a28cd43dSSascha Wildner ZSTDMT_CCtx* ZSTDMT_createCCtx_advanced(unsigned nbWorkers, 54*a28cd43dSSascha Wildner ZSTD_customMem cMem, 55*a28cd43dSSascha Wildner ZSTD_threadPool *pool); 56*a28cd43dSSascha Wildner size_t ZSTDMT_freeCCtx(ZSTDMT_CCtx* mtctx); 57*a28cd43dSSascha Wildner 58*a28cd43dSSascha Wildner size_t ZSTDMT_sizeof_CCtx(ZSTDMT_CCtx* mtctx); 59*a28cd43dSSascha Wildner 60*a28cd43dSSascha Wildner /* === Streaming functions === */ 61*a28cd43dSSascha Wildner 62*a28cd43dSSascha Wildner size_t ZSTDMT_nextInputSizeHint(const ZSTDMT_CCtx* mtctx); 63*a28cd43dSSascha Wildner 64*a28cd43dSSascha Wildner /*! ZSTDMT_initCStream_internal() : 65*a28cd43dSSascha Wildner * Private use only. Init streaming operation. 66*a28cd43dSSascha Wildner * expects params to be valid. 67*a28cd43dSSascha Wildner * must receive dict, or cdict, or none, but not both. 68*a28cd43dSSascha Wildner * @return : 0, or an error code */ 69*a28cd43dSSascha Wildner size_t ZSTDMT_initCStream_internal(ZSTDMT_CCtx* zcs, 70*a28cd43dSSascha Wildner const void* dict, size_t dictSize, ZSTD_dictContentType_e dictContentType, 71*a28cd43dSSascha Wildner const ZSTD_CDict* cdict, 72*a28cd43dSSascha Wildner ZSTD_CCtx_params params, unsigned long long pledgedSrcSize); 73*a28cd43dSSascha Wildner 74*a28cd43dSSascha Wildner /*! ZSTDMT_compressStream_generic() : 75*a28cd43dSSascha Wildner * Combines ZSTDMT_compressStream() with optional ZSTDMT_flushStream() or ZSTDMT_endStream() 76*a28cd43dSSascha Wildner * depending on flush directive. 77*a28cd43dSSascha Wildner * @return : minimum amount of data still to be flushed 78*a28cd43dSSascha Wildner * 0 if fully flushed 79*a28cd43dSSascha Wildner * or an error code 80*a28cd43dSSascha Wildner * note : needs to be init using any ZSTD_initCStream*() variant */ 81*a28cd43dSSascha Wildner size_t ZSTDMT_compressStream_generic(ZSTDMT_CCtx* mtctx, 82*a28cd43dSSascha Wildner ZSTD_outBuffer* output, 83*a28cd43dSSascha Wildner ZSTD_inBuffer* input, 84*a28cd43dSSascha Wildner ZSTD_EndDirective endOp); 85*a28cd43dSSascha Wildner 86*a28cd43dSSascha Wildner /*! ZSTDMT_toFlushNow() 87*a28cd43dSSascha Wildner * Tell how many bytes are ready to be flushed immediately. 88*a28cd43dSSascha Wildner * Probe the oldest active job (not yet entirely flushed) and check its output buffer. 89*a28cd43dSSascha Wildner * If return 0, it means there is no active job, 90*a28cd43dSSascha Wildner * or, it means oldest job is still active, but everything produced has been flushed so far, 91*a28cd43dSSascha Wildner * therefore flushing is limited by speed of oldest job. */ 92*a28cd43dSSascha Wildner size_t ZSTDMT_toFlushNow(ZSTDMT_CCtx* mtctx); 93*a28cd43dSSascha Wildner 94*a28cd43dSSascha Wildner /*! ZSTDMT_updateCParams_whileCompressing() : 95*a28cd43dSSascha Wildner * Updates only a selected set of compression parameters, to remain compatible with current frame. 96*a28cd43dSSascha Wildner * New parameters will be applied to next compression job. */ 97*a28cd43dSSascha Wildner void ZSTDMT_updateCParams_whileCompressing(ZSTDMT_CCtx* mtctx, const ZSTD_CCtx_params* cctxParams); 98*a28cd43dSSascha Wildner 99*a28cd43dSSascha Wildner /*! ZSTDMT_getFrameProgression(): 100*a28cd43dSSascha Wildner * tells how much data has been consumed (input) and produced (output) for current frame. 101*a28cd43dSSascha Wildner * able to count progression inside worker threads. 102*a28cd43dSSascha Wildner */ 103*a28cd43dSSascha Wildner ZSTD_frameProgression ZSTDMT_getFrameProgression(ZSTDMT_CCtx* mtctx); 104*a28cd43dSSascha Wildner 105*a28cd43dSSascha Wildner 106*a28cd43dSSascha Wildner #if defined (__cplusplus) 107*a28cd43dSSascha Wildner } 108*a28cd43dSSascha Wildner #endif 109*a28cd43dSSascha Wildner 110*a28cd43dSSascha Wildner #endif /* ZSTDMT_COMPRESS_H */ 111