/* SPDX-License-Identifier: BSD-3-Clause * Copyright(c) 2017 Intel Corporation */ #ifndef _RTE_NET_CRC_H_ #define _RTE_NET_CRC_H_ #include #ifdef __cplusplus extern "C" { #endif /** CRC polynomials */ #define CRC32_ETH_POLYNOMIAL 0x04c11db7UL #define CRC16_CCITT_POLYNOMIAL 0x1021U #define CRC_LUT_SIZE 256 /** CRC types */ enum rte_net_crc_type { RTE_NET_CRC16_CCITT = 0, RTE_NET_CRC32_ETH, RTE_NET_CRC_REQS }; /** CRC compute algorithm */ enum rte_net_crc_alg { RTE_NET_CRC_SCALAR = 0, RTE_NET_CRC_SSE42, RTE_NET_CRC_NEON, }; /** * This API set the CRC computation algorithm (i.e. scalar version, * x86 64-bit sse4.2 intrinsic version, etc.) and internal data * structure. * * @param alg * This parameter is used to select the CRC implementation version. * - RTE_NET_CRC_SCALAR * - RTE_NET_CRC_SSE42 (Use 64-bit SSE4.2 intrinsic) * - RTE_NET_CRC_NEON (Use ARM Neon intrinsic) */ void rte_net_crc_set_alg(enum rte_net_crc_alg alg); /** * CRC compute API * * @param data * Pointer to the packet data for CRC computation * @param data_len * Data length for CRC computation * @param type * CRC type (enum rte_net_crc_type) * * @return * CRC value */ uint32_t rte_net_crc_calc(const void *data, uint32_t data_len, enum rte_net_crc_type type); #ifdef __cplusplus } #endif #endif /* _RTE_NET_CRC_H_ */