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