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));
123 static inline void __attribute__((constructor))
124 rte_hash_crc_init_alg(
void)
141 static inline uint32_t
144 if (
likely(crc32_alg & CRC32_ARM64))
145 return crc32c_arm64_u8(data, init_val);
147 return crc32c_1byte(data, init_val);
162 static inline uint32_t
165 if (
likely(crc32_alg & CRC32_ARM64))
166 return crc32c_arm64_u16(data, init_val);
168 return crc32c_2bytes(data, init_val);
183 static inline uint32_t
186 if (
likely(crc32_alg & CRC32_ARM64))
187 return crc32c_arm64_u32(data, init_val);
189 return crc32c_1word(data, init_val);
204 static inline uint32_t
207 if (
likely(crc32_alg == CRC32_ARM64))
208 return crc32c_arm64_u64(data, init_val);
210 return crc32c_2words(data, init_val);