]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
[arm] Fix use of CRC32 intrinsics with Armv8-a and hard-float
authorKyrylo Tkachov <kyrylo.tkachov@arm.com>
Wed, 25 Sep 2019 13:48:29 +0000 (13:48 +0000)
committerKyrylo Tkachov <ktkachov@gcc.gnu.org>
Wed, 25 Sep 2019 13:48:29 +0000 (13:48 +0000)
Backport from mainline
2019-08-22  Kyrylo Tkachov <kyrylo.tkachov@arm.com>

* config/arm/arm_acle.h: Use arch=armv8-a+crc+simd pragma for CRC32
intrinsics if __ARM_FP.
Use __ARM_FEATURE_CRC32 ifdef guard.

* gcc.target/arm/acle/crc_hf_1.c: New test.

From-SVN: r276126

gcc/ChangeLog
gcc/config/arm/arm_acle.h
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/arm/acle/crc_hf_1.c [new file with mode: 0644]

index 53726d633fe936da0c5aac51564fc20a8ee0cf53..b4cd6e269b9e08fe9bca61fe60f18ffe11825645 100644 (file)
@@ -1,3 +1,12 @@
+2019-09-25  Kyrylo Tkachov <kyrylo.tkachov@arm.com>
+
+       Backport from mainline
+       2019-08-22  Kyrylo Tkachov <kyrylo.tkachov@arm.com>
+
+       * config/arm/arm_acle.h: Use arch=armv8-a+crc+simd pragma for CRC32
+       intrinsics if __ARM_FP.
+       Use __ARM_FEATURE_CRC32 ifdef guard.
+
 2019-09-23  Max Filippov  <jcmvbkbc@gmail.com>
 
        Backport from mainline
index 2c7acc698ea50e0cd539a7d9647498746cd1536f..6857ab1787df0ffa672e5078e5a0b9c9cc52e695 100644 (file)
@@ -174,8 +174,12 @@ __arm_mrrc2 (const unsigned int __coproc, const unsigned int __opc1,
 #endif /* (!__thumb__ || __thumb2__) &&  __ARM_ARCH >= 4.  */
 
 #pragma GCC push_options
-#if __ARM_ARCH >= 8
+#ifdef __ARM_FEATURE_CRC32
+#ifdef __ARM_FP
+#pragma GCC target ("arch=armv8-a+crc+simd")
+#else
 #pragma GCC target ("arch=armv8-a+crc")
+#endif
 
 __extension__ static __inline uint32_t __attribute__ ((__always_inline__))
 __crc32b (uint32_t __a, uint8_t __b)
@@ -235,7 +239,7 @@ __crc32cd (uint32_t __a, uint64_t __b)
 }
 #endif
 
-#endif /* __ARM_ARCH >= 8.  */
+#endif /* __ARM_FEATURE_CRC32  */
 #pragma GCC pop_options
 
 #ifdef __cplusplus
index d48010f89218316d85926e1a53ff3787cc016eb8..71b6ec52fcd494d2720429966fb8ac309aea590a 100644 (file)
@@ -1,3 +1,10 @@
+2019-09-25  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       Backport from mainline
+       2019-08-22  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       * gcc.target/arm/acle/crc_hf_1.c: New test.
+
 2019-09-21  Paul Thomas  <pault@gcc.gnu.org>
 
        Backport from mainline
diff --git a/gcc/testsuite/gcc.target/arm/acle/crc_hf_1.c b/gcc/testsuite/gcc.target/arm/acle/crc_hf_1.c
new file mode 100644 (file)
index 0000000..e6cbfc0
--- /dev/null
@@ -0,0 +1,14 @@
+/* Test that using an Armv8-a hard-float target doesn't
+   break CRC intrinsics.  */
+
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_hard_vfp_ok }  */
+/* { dg-options "-mfloat-abi=hard -march=armv8-a+simd+crc" } */
+
+#include <arm_acle.h>
+
+uint32_t
+foo (uint32_t a, uint32_t b)
+{
+  return __crc32cw (a, b);
+}