xref: /aosp_15_r20/external/zlib/crc32_simd.h (revision 86ee64e75fa5f8bce2c8c356138035642429cd05)
1*86ee64e7SAndroid Build Coastguard Worker /* crc32_simd.h
2*86ee64e7SAndroid Build Coastguard Worker  *
3*86ee64e7SAndroid Build Coastguard Worker  * Copyright 2017 The Chromium Authors
4*86ee64e7SAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
5*86ee64e7SAndroid Build Coastguard Worker  * found in the Chromium source repository LICENSE file.
6*86ee64e7SAndroid Build Coastguard Worker  */
7*86ee64e7SAndroid Build Coastguard Worker 
8*86ee64e7SAndroid Build Coastguard Worker #include <stdint.h>
9*86ee64e7SAndroid Build Coastguard Worker 
10*86ee64e7SAndroid Build Coastguard Worker #include "zconf.h"
11*86ee64e7SAndroid Build Coastguard Worker #include "zutil.h"
12*86ee64e7SAndroid Build Coastguard Worker #include "deflate.h"
13*86ee64e7SAndroid Build Coastguard Worker 
14*86ee64e7SAndroid Build Coastguard Worker /*
15*86ee64e7SAndroid Build Coastguard Worker  * crc32_sse42_simd_(): compute the crc32 of the buffer, where the buffer
16*86ee64e7SAndroid Build Coastguard Worker  * length must be at least 64, and a multiple of 16.
17*86ee64e7SAndroid Build Coastguard Worker  */
18*86ee64e7SAndroid Build Coastguard Worker uint32_t ZLIB_INTERNAL crc32_sse42_simd_(const unsigned char* buf,
19*86ee64e7SAndroid Build Coastguard Worker                                          z_size_t len,
20*86ee64e7SAndroid Build Coastguard Worker                                          uint32_t crc);
21*86ee64e7SAndroid Build Coastguard Worker 
22*86ee64e7SAndroid Build Coastguard Worker uint32_t ZLIB_INTERNAL crc32_avx512_simd_(const unsigned char* buf,
23*86ee64e7SAndroid Build Coastguard Worker                                           z_size_t len,
24*86ee64e7SAndroid Build Coastguard Worker                                           uint32_t crc);
25*86ee64e7SAndroid Build Coastguard Worker 
26*86ee64e7SAndroid Build Coastguard Worker /*
27*86ee64e7SAndroid Build Coastguard Worker  * crc32_sse42_simd_ buffer size constraints: see the use in zlib/crc32.c
28*86ee64e7SAndroid Build Coastguard Worker  * for computing the crc32 of an arbitrary length buffer.
29*86ee64e7SAndroid Build Coastguard Worker  */
30*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_SSE42_MINIMUM_LENGTH 64
31*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_SSE42_CHUNKSIZE_MASK 15
32*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_AVX512_MINIMUM_LENGTH 256
33*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_AVX512_CHUNKSIZE_MASK 63
34*86ee64e7SAndroid Build Coastguard Worker 
35*86ee64e7SAndroid Build Coastguard Worker /*
36*86ee64e7SAndroid Build Coastguard Worker  * CRC32 checksums using ARMv8-a crypto instructions.
37*86ee64e7SAndroid Build Coastguard Worker  */
38*86ee64e7SAndroid Build Coastguard Worker uint32_t ZLIB_INTERNAL armv8_crc32_little(const unsigned char* buf,
39*86ee64e7SAndroid Build Coastguard Worker                                           z_size_t len,
40*86ee64e7SAndroid Build Coastguard Worker                                           uint32_t crc);
41*86ee64e7SAndroid Build Coastguard Worker 
42*86ee64e7SAndroid Build Coastguard Worker /* aarch64 specific code. */
43*86ee64e7SAndroid Build Coastguard Worker #if defined(__aarch64__)
44*86ee64e7SAndroid Build Coastguard Worker 
45*86ee64e7SAndroid Build Coastguard Worker /* 128 is the sweet spot at the time of coding (late 2020). */
46*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_PMULL_MINIMUM_LENGTH 128
47*86ee64e7SAndroid Build Coastguard Worker #define Z_CRC32_PMULL_CHUNKSIZE_MASK 15
48*86ee64e7SAndroid Build Coastguard Worker 
49*86ee64e7SAndroid Build Coastguard Worker /*
50*86ee64e7SAndroid Build Coastguard Worker  * CRC32 checksums using ARMv8-a PMULL instructions, where the buffer
51*86ee64e7SAndroid Build Coastguard Worker  * length must be at least 64, and a multiple of 16.
52*86ee64e7SAndroid Build Coastguard Worker  */
53*86ee64e7SAndroid Build Coastguard Worker uint32_t ZLIB_INTERNAL armv8_crc32_pmull_little(const unsigned char* buf,
54*86ee64e7SAndroid Build Coastguard Worker                                                 z_size_t len,
55*86ee64e7SAndroid Build Coastguard Worker                                                 uint32_t crc);
56*86ee64e7SAndroid Build Coastguard Worker 
57*86ee64e7SAndroid Build Coastguard Worker #endif
58