DPDK  18.05.1
rte_net_crc.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2017 Intel Corporation
3  */
4 
5 #ifndef _RTE_NET_CRC_H_
6 #define _RTE_NET_CRC_H_
7 
8 #include <stdint.h>
9 
10 #ifdef __cplusplus
11 extern "C" {
12 #endif
13 
15 #define CRC32_ETH_POLYNOMIAL 0x04c11db7UL
16 #define CRC16_CCITT_POLYNOMIAL 0x1021U
17 
18 #define CRC_LUT_SIZE 256
19 
21 enum rte_net_crc_type {
22  RTE_NET_CRC16_CCITT = 0,
23  RTE_NET_CRC32_ETH,
24  RTE_NET_CRC_REQS
25 };
26 
28 enum rte_net_crc_alg {
29  RTE_NET_CRC_SCALAR = 0,
30  RTE_NET_CRC_SSE42,
31  RTE_NET_CRC_NEON,
32 };
33 
45 void
46 rte_net_crc_set_alg(enum rte_net_crc_alg alg);
47 
61 uint32_t
62 rte_net_crc_calc(const void *data,
63  uint32_t data_len,
64  enum rte_net_crc_type type);
65 
66 #ifdef __cplusplus
67 }
68 #endif
69 
70 
71 #endif /* _RTE_NET_CRC_H_ */