diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 063cc013aa0..5ffe57ddaf7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2019-11-21 Richard Biener + + PR tree-optimization/92596 + * tree-vect-slp.c (vect_build_slp_tree): Fix pasto. + 2019-11-21 Jan Hubicka * ipa-fnsummary.c (evaluate_conditions_for_known_args): Be diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5af1de3f1e8..8197698dd4f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-11-21 Richard Biener + + PR tree-optimization/92596 + * gcc.dg/torture/pr92596-1.c: New testcase. + 2019-11-21 Tamar Christina * gcc.dg/torture/fp-int-convert-timode-1.c: Add check for FE_TONEAREST. diff --git a/gcc/testsuite/gcc.dg/torture/pr92596-1.c b/gcc/testsuite/gcc.dg/torture/pr92596-1.c new file mode 100644 index 00000000000..9d2a223ac43 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr92596-1.c @@ -0,0 +1,20 @@ +/* { dg-do compile } */ +/* { dg-additional-options "-ftree-slp-vectorize" } */ + +typedef struct { + long n[5]; +} secp256k1_fe; + +void *a, *b; +int c; +static void +fn1(secp256k1_fe *p1, int p2) +{ + p1->n[2] = p1->n[3] = p1->n[4] = p2; +} +void +fn2() +{ + fn1(b, !c); + fn1(a, !c); +} diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c index dfbde1a3c77..a94d2d42491 100644 --- a/gcc/tree-vect-slp.c +++ b/gcc/tree-vect-slp.c @@ -1247,7 +1247,8 @@ vect_build_slp_tree (vec_info *vinfo, return *leader; } poly_uint64 this_max_nunits = 1; - slp_tree res = vect_build_slp_tree_2 (vinfo, stmts, group_size, max_nunits, + slp_tree res = vect_build_slp_tree_2 (vinfo, stmts, group_size, + &this_max_nunits, matches, npermutes, tree_size, bst_map); if (res) {