aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorHaochen Jiang <haochen.jiang@intel.com>2024-11-01 15:59:47 +0800
committerHaochen Jiang <haochen.jiang@intel.com>2024-11-02 02:15:46 +0800
commitc5a36c4e591e41efe3e4d892ff62831d801752d3 (patch)
treeecfaebba8a502053ada24f07d5bd3537e7050596 /gcc
parente8689ac75faca61a0251d1098dbafa8c637ec489 (diff)
downloadgcc-c5a36c4e591e41efe3e4d892ff62831d801752d3.zip
gcc-c5a36c4e591e41efe3e4d892ff62831d801752d3.tar.gz
gcc-c5a36c4e591e41efe3e4d892ff62831d801752d3.tar.bz2
i386: Do not allow pointer conversion for CMPccXADD intrin under -O0
The pointer conversion to wider type under macro would not consider whether the higher bit is cleaned or not. It will lead to unexpected cmp result. After this change, it will throw an incompatible pointer type error just like -O2 does currently. gcc/ChangeLog: * config/i386/cmpccxaddintrin.h (_cmpccxadd_epi32): Do not do type conversion for pointer. (_cmpccxadd_epi64): Ditto. gcc/testsuite/ChangeLog: * gcc.target/i386/cmpccxadd-1b.c: New test.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/config/i386/cmpccxaddintrin.h6
-rw-r--r--gcc/testsuite/gcc.target/i386/cmpccxadd-1b.c15
2 files changed, 18 insertions, 3 deletions
diff --git a/gcc/config/i386/cmpccxaddintrin.h b/gcc/config/i386/cmpccxaddintrin.h
index 39f368f..9349fb0 100644
--- a/gcc/config/i386/cmpccxaddintrin.h
+++ b/gcc/config/i386/cmpccxaddintrin.h
@@ -72,11 +72,11 @@ _cmpccxadd_epi64 (long long *__A, long long __B, long long __C,
}
#else
#define _cmpccxadd_epi32(A,B,C,D) \
- __builtin_ia32_cmpccxadd ((int *) (A), (int) (B), (int) (C), \
+ __builtin_ia32_cmpccxadd ((A), (int) (B), (int) (C), \
(_CMPCCX_ENUM) (D))
#define _cmpccxadd_epi64(A,B,C,D) \
- __builtin_ia32_cmpccxadd64 ((long long *) (A), (long long) (B), \
- (long long) (C), (_CMPCCX_ENUM) (D))
+ __builtin_ia32_cmpccxadd64 ((A), (long long) (B), (long long) (C), \
+ (_CMPCCX_ENUM) (D))
#endif
#ifdef __DISABLE_CMPCCXADD__
diff --git a/gcc/testsuite/gcc.target/i386/cmpccxadd-1b.c b/gcc/testsuite/gcc.target/i386/cmpccxadd-1b.c
new file mode 100644
index 0000000..7d20325
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/cmpccxadd-1b.c
@@ -0,0 +1,15 @@
+/* { dg-do compile { target { ! ia32 } } } */
+/* { dg-options "-O0 -mcmpccxadd" } */
+#include <x86gprintrin.h>
+
+short *a;
+int b, c;
+int *d;
+long long e, f;
+
+void extern
+cmpccxadd_test(void)
+{
+ b = _cmpccxadd_epi32 (a, b, c, _CMPCCX_O); /* { dg-error "incompatible pointer type" } */
+ e = _cmpccxadd_epi64 (d, e, f, _CMPCCX_O); /* { dg-error "incompatible pointer type" } */
+}