aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2018-05-02 23:56:17 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2018-05-02 23:56:17 +0200
commit31aa23df38a66c429d08c06a0005eccecc9234dc (patch)
treeda4886e607b08410f158790f4f8e9ced6de28a7a /gcc/testsuite/gcc.c-torture
parent019808c95c540a830a64c132257bde018abf6a1e (diff)
downloadgcc-31aa23df38a66c429d08c06a0005eccecc9234dc.zip
gcc-31aa23df38a66c429d08c06a0005eccecc9234dc.tar.gz
gcc-31aa23df38a66c429d08c06a0005eccecc9234dc.tar.bz2
re PR target/85582 (wrong code at -O1 and above on x86_64-linux-gnu in 32-bit mode)
PR target/85582 * config/i386/i386.md (*ashl<dwi>3_doubleword_mask, *ashl<dwi>3_doubleword_mask_1, *<shift_insn><dwi>3_doubleword_mask, *<shift_insn><dwi>3_doubleword_mask_1): In condition require that the highest significant bit of the shift count mask is clear. In check whether and[sq]i3 is needed verify that all significant bits of the shift count other than the highest are set. * gcc.c-torture/execute/pr85582-3.c: New test. From-SVN: r259862
Diffstat (limited to 'gcc/testsuite/gcc.c-torture')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/pr85582-3.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/pr85582-3.c b/gcc/testsuite/gcc.c-torture/execute/pr85582-3.c
new file mode 100644
index 0000000..99deb47
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/pr85582-3.c
@@ -0,0 +1,55 @@
+/* PR target/85582 */
+
+#ifdef __SIZEOF_INT128__
+typedef __int128 S;
+typedef unsigned __int128 U;
+#else
+typedef long long S;
+typedef unsigned long long U;
+#endif
+
+__attribute__((noipa)) U
+f1 (U x, int y)
+{
+ return x << (y & -2);
+}
+
+__attribute__((noipa)) S
+f2 (S x, int y)
+{
+ return x >> (y & -2);
+}
+
+__attribute__((noipa)) U
+f3 (U x, int y)
+{
+ return x >> (y & -2);
+}
+
+int
+main ()
+{
+ U a = (U) 1 << (sizeof (U) * __CHAR_BIT__ - 7);
+ if (f1 (a, 5) != ((U) 1 << (sizeof (S) * __CHAR_BIT__ - 3)))
+ __builtin_abort ();
+ S b = (U) 0x101 << (sizeof (S) * __CHAR_BIT__ / 2 - 7);
+ if (f1 (b, sizeof (S) * __CHAR_BIT__ / 2) != (U) 0x101 << (sizeof (S) * __CHAR_BIT__ - 7))
+ __builtin_abort ();
+ if (f1 (b, sizeof (S) * __CHAR_BIT__ / 2 + 2) != (U) 0x101 << (sizeof (S) * __CHAR_BIT__ - 5))
+ __builtin_abort ();
+ S c = (U) 1 << (sizeof (S) * __CHAR_BIT__ - 1);
+ if ((U) f2 (c, 5) != ((U) 0x1f << (sizeof (S) * __CHAR_BIT__ - 5)))
+ __builtin_abort ();
+ if ((U) f2 (c, sizeof (S) * __CHAR_BIT__ / 2) != ((U) -1 << (sizeof (S) * __CHAR_BIT__ / 2 - 1)))
+ __builtin_abort ();
+ if ((U) f2 (c, sizeof (S) * __CHAR_BIT__ / 2 + 2) != ((U) -1 << (sizeof (S) * __CHAR_BIT__ / 2 - 3)))
+ __builtin_abort ();
+ U d = (U) 1 << (sizeof (S) * __CHAR_BIT__ - 1);
+ if (f3 (c, 5) != ((U) 0x1 << (sizeof (S) * __CHAR_BIT__ - 5)))
+ __builtin_abort ();
+ if (f3 (c, sizeof (S) * __CHAR_BIT__ / 2) != ((U) 1 << (sizeof (S) * __CHAR_BIT__ / 2 - 1)))
+ __builtin_abort ();
+ if (f3 (c, sizeof (S) * __CHAR_BIT__ / 2 + 2) != ((U) 1 << (sizeof (S) * __CHAR_BIT__ / 2 - 3)))
+ __builtin_abort ();
+ return 0;
+}