]> gcc.gnu.org Git - gcc.git/commitdiff
forwprop: Remove incorrect assertion [PR102897]
authorKewen Lin <linkw@linux.ibm.com>
Tue, 26 Oct 2021 09:09:38 +0000 (04:09 -0500)
committerKewen Lin <linkw@linux.ibm.com>
Tue, 26 Oct 2021 09:10:00 +0000 (04:10 -0500)
As PR102897 shows, there is one incorrect assertion in function
simplify_permutation, which is based on the wrong assumption that
all cases with op2_type == tgt_type are handled previously, the
proposed fix is to remove the assertion.

gcc/ChangeLog:

PR tree-optimization/102897
* tree-ssa-forwprop.c (simplify_permutation): Remove a wrong assertion.

gcc/testsuite/ChangeLog:

* gcc.dg/pr102897.c: New test.

gcc/testsuite/gcc.dg/pr102897.c [new file with mode: 0644]
gcc/tree-ssa-forwprop.c

diff --git a/gcc/testsuite/gcc.dg/pr102897.c b/gcc/testsuite/gcc.dg/pr102897.c
new file mode 100644 (file)
index 0000000..bb14dcc
--- /dev/null
@@ -0,0 +1,16 @@
+/* { dg-do compile } */
+/* Specify C99 to avoid the warning/error on compound literals.  */
+/* { dg-options "-O1 -std=c99" } */
+
+/* Verify that there is no ICE.  */
+
+typedef __attribute__((vector_size(8))) signed char int8x8_t;
+typedef __attribute__((vector_size(8))) unsigned char uint8x8_t;
+
+int8x8_t fn1 (int8x8_t val20, char tmp)
+{
+  uint8x8_t __trans_tmp_3;
+  __trans_tmp_3 = (uint8x8_t){tmp};
+  int8x8_t __a = (int8x8_t) __trans_tmp_3;
+  return __builtin_shuffle (__a, val20, (uint8x8_t){0});
+}
index 5b30d4c1a7662d6cffcd0f62075a8f3dd5823e1e..a830bab78bab38b6ede9e09ff64fc91d5bc494fb 100644 (file)
@@ -2267,8 +2267,6 @@ simplify_permutation (gimple_stmt_iterator *gsi)
          if (!VECTOR_TYPE_P (tgt_type))
            return 0;
          tree op2_type = TREE_TYPE (op2);
-         /* Should have folded this before.  */
-         gcc_assert (op2_type != tgt_type);
 
          /* Figure out the shrunk factor.  */
          poly_uint64 tgt_units = TYPE_VECTOR_SUBPARTS (tgt_type);
This page took 0.083223 seconds and 5 git commands to generate.