The following fixes an omission, mangling the non-SLP and SLP simd-clone info.
Bootstrap and regtest running on x86_64-unknown-linux-gnu. * tree-vect-stmts.cc (vectorizable_simd_clone_call): Record to the correct simd_clone_info. --- gcc/tree-vect-stmts.cc | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/gcc/tree-vect-stmts.cc b/gcc/tree-vect-stmts.cc index b4c2ae31c92..ee89f47c468 100644 --- a/gcc/tree-vect-stmts.cc +++ b/gcc/tree-vect-stmts.cc @@ -4237,16 +4237,15 @@ vectorizable_simd_clone_call (vec_info *vinfo, stmt_vec_info stmt_info, case SIMD_CLONE_ARG_TYPE_LINEAR_CONSTANT_STEP: case SIMD_CLONE_ARG_TYPE_LINEAR_REF_CONSTANT_STEP: { - auto &clone_info = STMT_VINFO_SIMD_CLONE_INFO (stmt_info); - clone_info.safe_grow_cleared (i * 3 + 1, true); - clone_info.safe_push (arginfo[i].op); + simd_clone_info.safe_grow_cleared (i * 3 + 1, true); + simd_clone_info.safe_push (arginfo[i].op); tree lst = POINTER_TYPE_P (TREE_TYPE (arginfo[i].op)) ? size_type_node : TREE_TYPE (arginfo[i].op); tree ls = build_int_cst (lst, arginfo[i].linear_step); - clone_info.safe_push (ls); + simd_clone_info.safe_push (ls); tree sll = arginfo[i].simd_lane_linear ? boolean_true_node : boolean_false_node; - clone_info.safe_push (sll); + simd_clone_info.safe_push (sll); } break; case SIMD_CLONE_ARG_TYPE_MASK: -- 2.35.3