X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=crc%2Fcrc32c.h;h=5d664079b940fcb1691ceb569e7882fee7b57966;hb=c1f50f765a0a51931605c1fb223d166e3b3a93c6;hp=596fd6c56a98f835933ee68c17b1e845e0309a7d;hpb=f57d6f943806727b70d3d15230dcac09b22fab1a;p=fio.git diff --git a/crc/crc32c.h b/crc/crc32c.h index 596fd6c5..5d664079 100644 --- a/crc/crc32c.h +++ b/crc/crc32c.h @@ -20,17 +20,39 @@ #include "../arch/arch.h" -extern uint32_t crc32c(unsigned char const *, unsigned long); +extern uint32_t crc32c_sw(unsigned char const *, unsigned long); +extern int crc32c_arm64_available; +extern int crc32c_intel_available; + +#ifdef ARCH_HAVE_ARM64_CRC_CRYPTO +extern uint32_t crc32c_arm64(unsigned char const *, unsigned long); +extern void crc32c_arm64_probe(void); +#else +#define crc32c_arm64 crc32c_sw +static inline void crc32c_arm64_probe(void) +{ +} +#endif #ifdef ARCH_HAVE_SSE4_2 extern uint32_t crc32c_intel(unsigned char const *, unsigned long); -extern int crc32c_intel_works(void); +extern void crc32c_intel_probe(void); #else -#define crc32c_intel crc32c -static inline int crc32c_intel_works(void) +#define crc32c_intel crc32c_sw +static inline void crc32c_intel_probe(void) { - return 0; } #endif +static inline uint32_t fio_crc32c(unsigned char const *buf, unsigned long len) +{ + if (crc32c_arm64_available) + return crc32c_arm64(buf, len); + + if (crc32c_intel_available) + return crc32c_intel(buf, len); + + return crc32c_sw(buf, len); +} + #endif