]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
AArch64: Use __memcpy_simd on Neoverse N2/V1
authorWilco Dijkstra <wdijkstr@arm.com>
Wed, 14 Oct 2020 12:56:21 +0000 (13:56 +0100)
committerWilco Dijkstra <wdijkstr@arm.com>
Wed, 14 Oct 2020 16:29:12 +0000 (17:29 +0100)
Add CPU detection of Neoverse N2 and Neoverse V1, and select __memcpy_simd as
the memcpy/memmove ifunc.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
(cherry picked from commit e11ed9d2b4558eeacff81557dc9557001af42a6b)

sysdeps/aarch64/multiarch/memcpy.c
sysdeps/aarch64/multiarch/memmove.c
sysdeps/unix/sysv/linux/aarch64/cpu-features.h

index 18b5f5154314eafbd8b16f811b233412a80050f3..e69a1ae5af64a4890bb81543517398233fab5cae 100644 (file)
@@ -41,7 +41,8 @@ libc_ifunc (__libc_memcpy,
                ? __memcpy_falkor
                : (IS_THUNDERX2 (midr) || IS_THUNDERX2PA (midr)
                  ? __memcpy_thunderx2
-                 : (IS_NEOVERSE_N1 (midr)
+                 : (IS_NEOVERSE_N1 (midr) || IS_NEOVERSE_N2 (midr)
+                    || IS_NEOVERSE_V1 (midr)
                     ? __memcpy_simd
                     : __memcpy_generic)))));
 
index bc3f2e566d4bc1f4ee5610b64e5e5e0447d87897..b426dad83466a6874351b4c466380380d86970e2 100644 (file)
@@ -38,7 +38,8 @@ libc_ifunc (__libc_memmove,
             ? __memmove_thunderx
             : (IS_FALKOR (midr) || IS_PHECDA (midr)
                ? __memmove_falkor
-                 : (IS_NEOVERSE_N1 (midr)
+                 : (IS_NEOVERSE_N1 (midr) || IS_NEOVERSE_N2 (midr)
+                    || IS_NEOVERSE_V1 (midr)
                     ? __memmove_simd
                     : __memmove_generic))));
 
index c52ed7fc12713223fddeaecdfc46810f9c97b2df..fbe1148652398e3fa40b36c7fe9d0732d963592e 100644 (file)
                         && MIDR_PARTNUM(midr) == 0x000)
 #define IS_NEOVERSE_N1(midr) (MIDR_IMPLEMENTOR(midr) == 'A'                  \
                              && MIDR_PARTNUM(midr) == 0xd0c)
+#define IS_NEOVERSE_N2(midr) (MIDR_IMPLEMENTOR(midr) == 'A'                  \
+                             && MIDR_PARTNUM(midr) == 0xd49)
+#define IS_NEOVERSE_V1(midr) (MIDR_IMPLEMENTOR(midr) == 'A'                  \
+                             && MIDR_PARTNUM(midr) == 0xd40)
 
 struct cpu_features
 {