crc32.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * RISC-V optimized CRC32 functions
  4. *
  5. * Copyright 2025 Google LLC
  6. */
  7. #include <asm/hwcap.h>
  8. #include <asm/alternative-macros.h>
  9. #include "crc-clmul.h"
  10. static inline u32 crc32_le_arch(u32 crc, const u8 *p, size_t len)
  11. {
  12. if (riscv_has_extension_likely(RISCV_ISA_EXT_ZBC))
  13. return crc32_lsb_clmul(crc, p, len,
  14. &crc32_lsb_0xedb88320_consts);
  15. return crc32_le_base(crc, p, len);
  16. }
  17. static inline u32 crc32_be_arch(u32 crc, const u8 *p, size_t len)
  18. {
  19. if (riscv_has_extension_likely(RISCV_ISA_EXT_ZBC))
  20. return crc32_msb_clmul(crc, p, len,
  21. &crc32_msb_0x04c11db7_consts);
  22. return crc32_be_base(crc, p, len);
  23. }
  24. static inline u32 crc32c_arch(u32 crc, const u8 *p, size_t len)
  25. {
  26. if (riscv_has_extension_likely(RISCV_ISA_EXT_ZBC))
  27. return crc32_lsb_clmul(crc, p, len,
  28. &crc32_lsb_0x82f63b78_consts);
  29. return crc32c_base(crc, p, len);
  30. }
  31. static inline u32 crc32_optimizations_arch(void)
  32. {
  33. if (riscv_has_extension_likely(RISCV_ISA_EXT_ZBC))
  34. return CRC32_LE_OPTIMIZATION |
  35. CRC32_BE_OPTIMIZATION |
  36. CRC32C_OPTIMIZATION;
  37. return 0;
  38. }