tree-optimization/99947 - avoid v.safe_push (v[0])
authorRichard Biener <rguenther@suse.de>
Wed, 7 Apr 2021 08:02:07 +0000 (10:02 +0200)
committerRichard Biener <rguenther@suse.de>
Wed, 7 Apr 2021 08:04:20 +0000 (10:04 +0200)
This avoids (again) the C++ pitfall of pushing a reference to
sth being reallocated.

2021-04-07  Richard Biener  <rguenther@suse.de>

PR tree-optimization/99947
* tree-vect-loop.c (vectorizable_induction): Pre-allocate
steps vector to avoid pushing elements from the reallocated
vector.

* gcc.dg/torture/pr99947.c: New testcase.

gcc/testsuite/gcc.dg/torture/pr99947.c [new file with mode: 0644]
gcc/tree-vect-loop.c

diff --git a/gcc/testsuite/gcc.dg/torture/pr99947.c b/gcc/testsuite/gcc.dg/torture/pr99947.c
new file mode 100644 (file)
index 0000000..2cf3ec6
--- /dev/null
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+
+int a, b, d, e;
+short c;
+void f() {
+  for (; e; e++) {
+    int g = 6;
+    for (; g > 2; g--) {
+      int i = -8;
+      while (i < 20) {
+        i += 5;
+        a += b;
+      }
+      c *= d;
+    }
+    b--;
+  }
+}
index 4e928c6..93fa292 100644 (file)
@@ -8202,11 +8202,12 @@ vectorizable_induction (loop_vec_info loop_vinfo,
          /* Fill up to the number of vectors we need for the whole group.  */
          nivs = least_common_multiple (group_size,
                                        const_nunits) / const_nunits;
+         vec_steps.reserve (nivs-ivn);
          for (; ivn < nivs; ++ivn)
            {
              SLP_TREE_VEC_STMTS (slp_node)
                .quick_push (SLP_TREE_VEC_STMTS (slp_node)[0]);
-             vec_steps.safe_push (vec_steps[0]);
+             vec_steps.quick_push (vec_steps[0]);
            }
        }