]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
arm64/lib: Handle CRC-32 alternative in C code
authorArd Biesheuvel <ardb@kernel.org>
Fri, 18 Oct 2024 07:53:49 +0000 (09:53 +0200)
committerCatalin Marinas <catalin.marinas@arm.com>
Tue, 22 Oct 2024 10:54:43 +0000 (11:54 +0100)
In preparation for adding another code path for performing CRC-32, move
the alternative patching for ARM64_HAS_CRC32 into C code. The logic for
deciding whether to use this new code path will be implemented in C too.

Reviewed-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Link: https://lore.kernel.org/r/20241018075347.2821102-6-ardb+git@google.com
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
arch/arm64/lib/Makefile
arch/arm64/lib/crc32-glue.c [new file with mode: 0644]
arch/arm64/lib/crc32.S

index 13e6a2829116cad1216dd35bf171ca1801561fee..8e882f479d98143e5c70423d00f0cd255b2b793d 100644 (file)
@@ -13,7 +13,7 @@ endif
 
 lib-$(CONFIG_ARCH_HAS_UACCESS_FLUSHCACHE) += uaccess_flushcache.o
 
-obj-$(CONFIG_CRC32) += crc32.o
+obj-$(CONFIG_CRC32) += crc32.o crc32-glue.o
 
 obj-$(CONFIG_FUNCTION_ERROR_INJECTION) += error-inject.o
 
diff --git a/arch/arm64/lib/crc32-glue.c b/arch/arm64/lib/crc32-glue.c
new file mode 100644 (file)
index 0000000..0b51761
--- /dev/null
@@ -0,0 +1,34 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/crc32.h>
+#include <linux/linkage.h>
+
+#include <asm/alternative.h>
+
+asmlinkage u32 crc32_le_arm64(u32 crc, unsigned char const *p, size_t len);
+asmlinkage u32 crc32c_le_arm64(u32 crc, unsigned char const *p, size_t len);
+asmlinkage u32 crc32_be_arm64(u32 crc, unsigned char const *p, size_t len);
+
+u32 __pure crc32_le(u32 crc, unsigned char const *p, size_t len)
+{
+       if (!alternative_has_cap_likely(ARM64_HAS_CRC32))
+               return crc32_le_base(crc, p, len);
+
+       return crc32_le_arm64(crc, p, len);
+}
+
+u32 __pure __crc32c_le(u32 crc, unsigned char const *p, size_t len)
+{
+       if (!alternative_has_cap_likely(ARM64_HAS_CRC32))
+               return __crc32c_le_base(crc, p, len);
+
+       return crc32c_le_arm64(crc, p, len);
+}
+
+u32 __pure crc32_be(u32 crc, unsigned char const *p, size_t len)
+{
+       if (!alternative_has_cap_likely(ARM64_HAS_CRC32))
+               return crc32_be_base(crc, p, len);
+
+       return crc32_be_arm64(crc, p, len);
+}
index 8340dccff46ff93efd9bfac5a13332939afc99dd..22139691c7ae9b65a67cf0ed683a7ad4a377e43d 100644 (file)
@@ -6,7 +6,6 @@
  */
 
 #include <linux/linkage.h>
-#include <asm/alternative.h>
 #include <asm/assembler.h>
 
        .arch           armv8-a+crc
@@ -136,25 +135,16 @@ CPU_BE( rev16             \reg, \reg      )
        .endm
 
        .align          5
-SYM_FUNC_START(crc32_le)
-alternative_if_not ARM64_HAS_CRC32
-       b               crc32_le_base
-alternative_else_nop_endif
+SYM_FUNC_START(crc32_le_arm64)
        __crc32
-SYM_FUNC_END(crc32_le)
+SYM_FUNC_END(crc32_le_arm64)
 
        .align          5
-SYM_FUNC_START(__crc32c_le)
-alternative_if_not ARM64_HAS_CRC32
-       b               __crc32c_le_base
-alternative_else_nop_endif
+SYM_FUNC_START(crc32c_le_arm64)
        __crc32         c
-SYM_FUNC_END(__crc32c_le)
+SYM_FUNC_END(crc32c_le_arm64)
 
        .align          5
-SYM_FUNC_START(crc32_be)
-alternative_if_not ARM64_HAS_CRC32
-       b               crc32_be_base
-alternative_else_nop_endif
+SYM_FUNC_START(crc32_be_arm64)
        __crc32         be=1
-SYM_FUNC_END(crc32_be)
+SYM_FUNC_END(crc32_be_arm64)