mirror of
https://github.com/opencv/opencv.git
synced 2025-01-23 01:53:13 +08:00
0de26fd78e
Zlib-ng is zlib replacement with optimizations for "next generation" systems. Its optimization may benifits image library decode and encode speed such as libpng. In our tests, if using zlib-ng and libpng combination on a x86_64 machine with AVX2, the time of `imdecode` amd `imencode` will drop 20% approximately. This patch enables zlib-ng's optimization if `CV_DISABLE_OPTIMIZATION` is OFF. Since Zlib-ng can dispatch intrinsics on the fly, port work is much easier. Related discussion: https://github.com/opencv/opencv/issues/22573
31 lines
979 B
C
31 lines
979 B
C
/*
|
|
* Compute the CRC32 using a parallelized folding approach with the PCLMULQDQ
|
|
* instruction.
|
|
*
|
|
* A white paper describing this algorithm can be found at:
|
|
* doc/crc-pclmulqdq.pdf
|
|
*
|
|
* Copyright (C) 2013 Intel Corporation. All rights reserved.
|
|
* Copyright (C) 2016 Marian Beermann (support for initial value)
|
|
* Authors:
|
|
* Wajdi Feghali <wajdi.k.feghali@intel.com>
|
|
* Jim Guilford <james.guilford@intel.com>
|
|
* Vinodh Gopal <vinodh.gopal@intel.com>
|
|
* Erdinc Ozturk <erdinc.ozturk@intel.com>
|
|
* Jim Kukunas <james.t.kukunas@linux.intel.com>
|
|
*
|
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
|
*/
|
|
|
|
#ifdef X86_PCLMULQDQ_CRC
|
|
|
|
#define CRC32_FOLD_COPY crc32_fold_pclmulqdq_copy
|
|
#define CRC32_FOLD crc32_fold_pclmulqdq
|
|
#define CRC32_FOLD_RESET crc32_fold_pclmulqdq_reset
|
|
#define CRC32_FOLD_FINAL crc32_fold_pclmulqdq_final
|
|
#define CRC32 crc32_pclmulqdq
|
|
|
|
#include "crc32_pclmulqdq_tpl.h"
|
|
|
|
#endif
|