summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/combine.c1
-rw-r--r--gcc/testsuite/ChangeLog8
-rw-r--r--gcc/testsuite/gcc.dg/pr91860-1.c18
-rw-r--r--gcc/testsuite/gcc.dg/pr91860-2.c13
-rw-r--r--gcc/testsuite/gcc.dg/pr91860-3.c15
-rw-r--r--gcc/testsuite/gcc.dg/pr91860-4.c24
7 files changed, 85 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f346dd5ced7..12613f7f639 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2019-10-11 Jim Wilson <jimw@sifive.com>
+
+ PR rtl-optimization/91860
+ * combine.c (subst): If new_rtx is a constant, also check for
+ SIGN_EXTEND when deciding whether to call simplify_unary_operation.
+
2019-10-11 Richard Sandiford <richard.sandiford@arm.com>
* expr.c (store_expr): Use rtx_to_poly_int64 rather than
diff --git a/gcc/combine.c b/gcc/combine.c
index d295a81abf9..92e4e5e6898 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -5680,6 +5680,7 @@ subst (rtx x, rtx from, rtx to, int in_dest, int in_cond, int unique_copy)
}
else if (CONST_SCALAR_INT_P (new_rtx)
&& (GET_CODE (x) == ZERO_EXTEND
+ || GET_CODE (x) == SIGN_EXTEND
|| GET_CODE (x) == FLOAT
|| GET_CODE (x) == UNSIGNED_FLOAT))
{
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index cdc717945be..cc1a57b7097 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,11 @@
+2019-10-11 Jim Wilson <jimw@sifive.com>
+
+ PR rtl-optimization/91860
+ * gcc.dg/pr91860-1.c: New testcase.
+ * gcc.dg/pr91860-2.c: New testcase.
+ * gcc.dg/pr91860-3.c: New testcase.
+ * gcc.dg/pr91860-4.c: New testcase.
+
2019-10-11 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/91649
diff --git a/gcc/testsuite/gcc.dg/pr91860-1.c b/gcc/testsuite/gcc.dg/pr91860-1.c
new file mode 100644
index 00000000000..e715040e33d
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr91860-1.c
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+/* { dg-options "-Og -fipa-cp -g --param=max-combine-insns=3" } */
+
+char a;
+int b;
+
+static void
+bar (short d)
+{
+ d <<= __builtin_sub_overflow (0, d, &a);
+ b = __builtin_bswap16 (~d);
+}
+
+void
+foo (void)
+{
+ bar (21043);
+}
diff --git a/gcc/testsuite/gcc.dg/pr91860-2.c b/gcc/testsuite/gcc.dg/pr91860-2.c
new file mode 100644
index 00000000000..7b44e648ca6
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr91860-2.c
@@ -0,0 +1,13 @@
+/* { dg-do compile } */
+/* { dg-options "-Og -fexpensive-optimizations -fno-tree-fre -g --param=max-combine-insns=4" } */
+
+unsigned a, b, c;
+void
+foo (void)
+{
+ unsigned short e;
+ __builtin_mul_overflow (0, b, &a);
+ __builtin_sub_overflow (59347, 9, &e);
+ e <<= a & 5;
+ c = e;
+}
diff --git a/gcc/testsuite/gcc.dg/pr91860-3.c b/gcc/testsuite/gcc.dg/pr91860-3.c
new file mode 100644
index 00000000000..2b488cc9048
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr91860-3.c
@@ -0,0 +1,15 @@
+/* { dg-do compile } */
+/* { dg-options "-Og -g2 --param=max-combine-insns=3" } */
+
+int a, b;
+
+void
+foo (void)
+{
+ unsigned short d = 46067;
+ int e = e;
+ d <<= __builtin_mul_overflow (~0, e, &a);
+ d |= -68719476735;
+ b = d;
+}
+
diff --git a/gcc/testsuite/gcc.dg/pr91860-4.c b/gcc/testsuite/gcc.dg/pr91860-4.c
new file mode 100644
index 00000000000..36f2bd55c64
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr91860-4.c
@@ -0,0 +1,24 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target int128 } */
+/* { dg-options "-O2 -g" } */
+
+typedef unsigned char u8;
+typedef unsigned int u32;
+typedef unsigned __int128 u128;
+
+u32 b, c;
+
+static inline
+u128 bar (u8 d, u128 e)
+{
+ __builtin_memset (11 + (char *) &e, b, 1);
+ d <<= e & 7;
+ d = d | d > 0;
+ return d + e;
+}
+
+void
+foo (void)
+{
+ c = bar (~0, 5);
+}