5 #ifndef _RTE_CRC_ARM64_H_ 6 #define _RTE_CRC_ARM64_H_ 23 static inline uint32_t
24 crc32c_arm64_u8(uint8_t data, uint32_t init_val)
27 "crc32cb %w[crc], %w[crc], %w[value]" 28 : [crc]
"+r" (init_val)
29 : [value]
"r" (data));
33 static inline uint32_t
34 crc32c_arm64_u16(uint16_t data, uint32_t init_val)
37 "crc32ch %w[crc], %w[crc], %w[value]" 38 : [crc]
"+r" (init_val)
39 : [value]
"r" (data));
43 static inline uint32_t
44 crc32c_arm64_u32(uint32_t data, uint32_t init_val)
47 "crc32cw %w[crc], %w[crc], %w[value]" 48 : [crc]
"+r" (init_val)
49 : [value]
"r" (data));
53 static inline uint32_t
54 crc32c_arm64_u64(uint64_t data, uint32_t init_val)
57 "crc32cx %w[crc], %w[crc], %x[value]" 58 : [crc]
"+r" (init_val)
59 : [value]
"r" (data));
107 static inline uint32_t
110 if (
likely(crc32_alg & CRC32_ARM64))
111 return crc32c_arm64_u8(data, init_val);
113 return crc32c_1byte(data, init_val);
128 static inline uint32_t
131 if (
likely(crc32_alg & CRC32_ARM64))
132 return crc32c_arm64_u16(data, init_val);
134 return crc32c_2bytes(data, init_val);
149 static inline uint32_t
152 if (
likely(crc32_alg & CRC32_ARM64))
153 return crc32c_arm64_u32(data, init_val);
155 return crc32c_1word(data, init_val);
170 static inline uint32_t
173 if (
likely(crc32_alg == CRC32_ARM64))
174 return crc32c_arm64_u64(data, init_val);
176 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)