tree-optimization/98048 - fix vector lowering of ABSU_EXPR
authorRichard Biener <rguenther@suse.de>
Mon, 30 Nov 2020 09:41:36 +0000 (10:41 +0100)
committerRichard Biener <rguenther@suse.de>
Mon, 30 Nov 2020 12:27:56 +0000 (13:27 +0100)
This makes sure to use the correct type for the LHS of the scalar
replacement statement.

20220-11-30  Richard Biener  <rguenther@suse.de>

PR tree-optimization/98048
* tree-vect-generic.c (expand_vector_operations_1): Use the
correct type for the scalar LHS replacement.

* gcc.dg/vect/pr98048.c: New testcase.

gcc/testsuite/gcc.dg/vect/pr98048.c [new file with mode: 0644]
gcc/tree-vect-generic.c

diff --git a/gcc/testsuite/gcc.dg/vect/pr98048.c b/gcc/testsuite/gcc.dg/vect/pr98048.c
new file mode 100644 (file)
index 0000000..e61a376
--- /dev/null
@@ -0,0 +1,14 @@
+/* { dg-do compile } */
+
+extern short var_0;
+extern int var_3;
+extern int arr_277[];
+int a(int b, int c) { return b < c ? b : c; }
+int e;
+void test()
+{
+  e = var_0;
+  for (int d = 0; d < 9; d++)
+    if (var_3)
+      arr_277[d] = a(var_0, -var_0);
+}
index 23bc1cb04b795769d69cb7f58e4aed27e577f44a..55cf0d9bab5c0fd2804101a7425d50b31faa2944 100644 (file)
@@ -2089,7 +2089,7 @@ expand_vector_operations_1 (gimple_stmt_iterator *gsi,
       if (op >= FIRST_NORM_OPTAB && op <= LAST_NORM_OPTAB
          && optab_handler (op, TYPE_MODE (TREE_TYPE (type))) != CODE_FOR_nothing)
        {
-         tree slhs = make_ssa_name (TREE_TYPE (srhs1));
+         tree slhs = make_ssa_name (TREE_TYPE (TREE_TYPE (lhs)));
          gimple *repl = gimple_build_assign (slhs, code, srhs1, srhs2);
          gsi_insert_before (gsi, repl, GSI_SAME_STMT);
          gimple_assign_set_rhs_from_tree (gsi,