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)
55 asm(
".arch armv8-a+crc");
57 "crc32cb %w[crc], %w[crc], %w[value]"
58 : [crc]
"+r" (init_val)
59 : [value]
"r" (data));
63 static inline uint32_t
64 crc32c_arm64_u16(uint16_t data, uint32_t init_val)
66 asm(
".arch armv8-a+crc");
68 "crc32ch %w[crc], %w[crc], %w[value]"
69 : [crc]
"+r" (init_val)
70 : [value]
"r" (data));
74 static inline uint32_t
75 crc32c_arm64_u32(uint32_t data, uint32_t init_val)
77 asm(
".arch armv8-a+crc");
79 "crc32cw %w[crc], %w[crc], %w[value]"
80 : [crc]
"+r" (init_val)
81 : [value]
"r" (data));
85 static inline uint32_t
86 crc32c_arm64_u64(uint64_t data, uint32_t init_val)
88 asm(
".arch armv8-a+crc");
90 "crc32cx %w[crc], %w[crc], %x[value]"
91 : [crc]
"+r" (init_val)
92 : [value]
"r" (data));
121 static inline void __attribute__((constructor))
122 rte_hash_crc_init_alg(
void)
139 static inline uint32_t
142 if (
likely(crc32_alg & CRC32_ARM64))
143 return crc32c_arm64_u8(data, init_val);
145 return crc32c_1byte(data, init_val);
160 static inline uint32_t
163 if (
likely(crc32_alg & CRC32_ARM64))
164 return crc32c_arm64_u16(data, init_val);
166 return crc32c_2bytes(data, init_val);
181 static inline uint32_t
184 if (
likely(crc32_alg & CRC32_ARM64))
185 return crc32c_arm64_u32(data, init_val);
187 return crc32c_1word(data, init_val);
202 static inline uint32_t
205 if (
likely(crc32_alg == CRC32_ARM64))
206 return crc32c_arm64_u64(data, init_val);
208 return crc32c_2words(data, init_val);