34 #ifndef _RTE_CRC_ARM64_H_
35 #define _RTE_CRC_ARM64_H_
52 static inline uint32_t
53 crc32c_arm64_u8(uint8_t data, uint32_t init_val)
56 "crc32cb %w[crc], %w[crc], %w[value]"
57 : [crc]
"+r" (init_val)
58 : [value]
"r" (data));
62 static inline uint32_t
63 crc32c_arm64_u16(uint16_t data, uint32_t init_val)
66 "crc32ch %w[crc], %w[crc], %w[value]"
67 : [crc]
"+r" (init_val)
68 : [value]
"r" (data));
72 static inline uint32_t
73 crc32c_arm64_u32(uint32_t data, uint32_t init_val)
76 "crc32cw %w[crc], %w[crc], %w[value]"
77 : [crc]
"+r" (init_val)
78 : [value]
"r" (data));
82 static inline uint32_t
83 crc32c_arm64_u64(uint64_t data, uint32_t init_val)
86 "crc32cx %w[crc], %w[crc], %x[value]"
87 : [crc]
"+r" (init_val)
88 : [value]
"r" (data));
136 static inline uint32_t
139 if (
likely(crc32_alg & CRC32_ARM64))
140 return crc32c_arm64_u8(data, init_val);
142 return crc32c_1byte(data, init_val);
157 static inline uint32_t
160 if (
likely(crc32_alg & CRC32_ARM64))
161 return crc32c_arm64_u16(data, init_val);
163 return crc32c_2bytes(data, init_val);
178 static inline uint32_t
181 if (
likely(crc32_alg & CRC32_ARM64))
182 return crc32c_arm64_u32(data, init_val);
184 return crc32c_1word(data, init_val);
199 static inline uint32_t
202 if (
likely(crc32_alg == CRC32_ARM64))
203 return crc32c_arm64_u64(data, init_val);
205 return crc32c_2words(data, init_val);
static uint32_t rte_hash_crc_1byte(uint8_t data, uint32_t init_val)
static void rte_hash_crc_set_alg(uint8_t alg)
static uint32_t rte_hash_crc_8byte(uint64_t data, uint32_t init_val)
static uint32_t rte_hash_crc_4byte(uint32_t data, uint32_t init_val)
__extension__ int rte_cpu_get_flag_enabled(enum rte_cpu_flag_t feature)
static uint32_t rte_hash_crc_2byte(uint16_t data, uint32_t init_val)