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