/* SPDX-License-Identifier: GPL-2.0-only */ /* * CRC64 using ARM PMULL instructions */ #include static __ro_after_init DEFINE_STATIC_KEY_FALSE(have_pmull); u64 crc64_nvme_neon(u64 crc, const u8 *p, size_t len); #define crc64_be_arch crc64_be_generic static inline u64 crc64_nvme_arch(u64 crc, const u8 *p, size_t len) { if (len >= 128 && static_branch_likely(&have_pmull) && likely(may_use_simd())) { do { size_t chunk = min_t(size_t, len & ~15, SZ_4K); scoped_ksimd() crc = crc64_nvme_neon(crc, p, chunk); p += chunk; len -= chunk; } while (len >= 128); } return crc64_nvme_generic(crc, p, len); } #define crc64_mod_init_arch crc64_mod_init_arch static void crc64_mod_init_arch(void) { if (elf_hwcap2 & HWCAP2_PMULL) static_branch_enable(&have_pmull); }