diff options
-rw-r--r-- | gcc/ChangeLog | 24 | ||||
-rw-r--r-- | gcc/cfgloop.h | 2 | ||||
-rw-r--r-- | gcc/function.h | 4 | ||||
-rw-r--r-- | gcc/lto-streamer-in.c | 4 | ||||
-rw-r--r-- | gcc/lto-streamer-out.c | 4 | ||||
-rw-r--r-- | gcc/omp-low.c | 8 | ||||
-rw-r--r-- | gcc/tree-cfg.c | 6 | ||||
-rw-r--r-- | gcc/tree-if-conv.c | 10 | ||||
-rw-r--r-- | gcc/tree-inline.c | 6 | ||||
-rw-r--r-- | gcc/tree-ssa-loop-ivcanon.c | 2 | ||||
-rw-r--r-- | gcc/tree-ssa-loop.c | 2 | ||||
-rw-r--r-- | gcc/tree-ssa-phiopt.c | 2 | ||||
-rw-r--r-- | gcc/tree-vect-loop.c | 2 | ||||
-rw-r--r-- | gcc/tree-vectorizer.c | 4 | ||||
-rw-r--r-- | gcc/tree-vectorizer.h | 2 |
15 files changed, 53 insertions, 29 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 026735907fd..e3e418036d0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,27 @@ +2014-04-14 Eric Botcazou <ebotcazou@adacore.com> + + * cfgloop.h (struct loop): Rename force_vect into force_vectorize. + * function.h (struct function): Rename has_force_vect_loops into + has_force_vectorize_loops. + * lto-streamer-in.c (input_cfg): Adjust for renaming. + (input_struct_function_base): Likewise. + * lto-streamer-out.c (output_cfg): Likewise. + (output_struct_function_base): Likewise. + * omp-low.c (expand_omp_simd): Likewise. + * tree-cfg.c (move_sese_region_to_fn): Likewise. + * tree-if-conv.c (ifcvt_can_use_mask_load_store): Likewise. + (version_loop_for_if_conversion): Likewise. + (tree_if_conversion): Likewise. + (main_tree_if_conversion): Likewise. + (gate_tree_if_conversion): Likewise. + * tree-inline.c (copy_loops): Likewise. + * tree-ssa-loop-ivcanon.c (tree_unroll_loops_completely_1): Likewise. + * tree-ssa-loop.c (tree_loop_vectorize): Likewise. + * tree-ssa-phiopt.c (tree_ssa_phiopt_worker): Likewise. + * tree-vect-loop.c (vect_estimate_min_profitable_iters): Likewise. + * tree-vectorizer.c (vectorize_loops): Likewise. + * tree-vectorizer.h (unlimited_cost_model): Likewise. + 2014-04-14 Richard Biener <rguenther@suse.de> PR lto/60720 diff --git a/gcc/cfgloop.h b/gcc/cfgloop.h index 4b7c3d3985a..2e160b202bb 100644 --- a/gcc/cfgloop.h +++ b/gcc/cfgloop.h @@ -174,7 +174,7 @@ struct GTY ((chain_next ("%h.next"))) loop { int safelen; /* True if we should try harder to vectorize this loop. */ - bool force_vect; + bool force_vectorize; /* True if this loop should never be vectorized. */ bool dont_vectorize; diff --git a/gcc/function.h b/gcc/function.h index 38a0fc4688d..0aa6c9a1545 100644 --- a/gcc/function.h +++ b/gcc/function.h @@ -661,8 +661,8 @@ struct GTY(()) function { unsigned int is_thunk : 1; /* Nonzero if the current function contains any loops with - loop->force_vect set. */ - unsigned int has_force_vect_loops : 1; + loop->force_vectorize set. */ + unsigned int has_force_vectorize_loops : 1; /* Nonzero if the current function contains any loops with nonzero value in loop->simduid. */ diff --git a/gcc/lto-streamer-in.c b/gcc/lto-streamer-in.c index e19b11558d9..c3fa7b62192 100644 --- a/gcc/lto-streamer-in.c +++ b/gcc/lto-streamer-in.c @@ -718,7 +718,7 @@ input_cfg (struct lto_input_block *ib, struct data_in *data_in, /* Read OMP SIMD related info. */ loop->safelen = streamer_read_hwi (ib); - loop->force_vect = streamer_read_hwi (ib); + loop->force_vectorize = streamer_read_hwi (ib); loop->simduid = stream_read_tree (ib, data_in); place_new_loop (fn, loop); @@ -884,7 +884,7 @@ input_struct_function_base (struct function *fn, struct data_in *data_in, fn->has_nonlocal_label = bp_unpack_value (&bp, 1); fn->calls_alloca = bp_unpack_value (&bp, 1); fn->calls_setjmp = bp_unpack_value (&bp, 1); - fn->has_force_vect_loops = bp_unpack_value (&bp, 1); + fn->has_force_vectorize_loops = bp_unpack_value (&bp, 1); fn->has_simduid_loops = bp_unpack_value (&bp, 1); fn->va_list_fpr_size = bp_unpack_value (&bp, 8); fn->va_list_gpr_size = bp_unpack_value (&bp, 8); diff --git a/gcc/lto-streamer-out.c b/gcc/lto-streamer-out.c index b193d730d75..cd324c162bb 100644 --- a/gcc/lto-streamer-out.c +++ b/gcc/lto-streamer-out.c @@ -1693,7 +1693,7 @@ output_cfg (struct output_block *ob, struct function *fn) /* Write OMP SIMD related info. */ streamer_write_hwi (ob, loop->safelen); - streamer_write_hwi (ob, loop->force_vect); + streamer_write_hwi (ob, loop->force_vectorize); stream_write_tree (ob, loop->simduid, true); } @@ -1788,7 +1788,7 @@ output_struct_function_base (struct output_block *ob, struct function *fn) bp_pack_value (&bp, fn->has_nonlocal_label, 1); bp_pack_value (&bp, fn->calls_alloca, 1); bp_pack_value (&bp, fn->calls_setjmp, 1); - bp_pack_value (&bp, fn->has_force_vect_loops, 1); + bp_pack_value (&bp, fn->has_force_vectorize_loops, 1); bp_pack_value (&bp, fn->has_simduid_loops, 1); bp_pack_value (&bp, fn->va_list_fpr_size, 8); bp_pack_value (&bp, fn->va_list_gpr_size, 8); diff --git a/gcc/omp-low.c b/gcc/omp-low.c index 11bb2d35a15..ed4e218571a 100644 --- a/gcc/omp-low.c +++ b/gcc/omp-low.c @@ -6843,8 +6843,8 @@ expand_omp_simd (struct omp_region *region, struct omp_for_data *fd) && flag_tree_loop_optimize && loop->safelen > 1) { - loop->force_vect = true; - cfun->has_force_vect_loops = true; + loop->force_vectorize = true; + cfun->has_force_vectorize_loops = true; } } } @@ -11487,9 +11487,9 @@ simd_clone_adjust (struct cgraph_node *node) /* Mostly annotate the loop for the vectorizer (the rest is done below). */ struct loop *loop = alloc_loop (); - cfun->has_force_vect_loops = true; + cfun->has_force_vectorize_loops = true; loop->safelen = node->simdclone->simdlen; - loop->force_vect = true; + loop->force_vectorize = true; loop->header = body_bb; add_bb_to_loop (incr_bb, loop); diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index 56b6c3595b8..2f250da23b6 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -6967,7 +6967,7 @@ move_sese_region_to_fn (struct function *dest_cfun, basic_block entry_bb, outer->num_nodes -= num_nodes; loop0->num_nodes -= bbs.length () - num_nodes; - if (saved_cfun->has_simduid_loops || saved_cfun->has_force_vect_loops) + if (saved_cfun->has_simduid_loops || saved_cfun->has_force_vectorize_loops) { struct loop *aloop; for (i = 0; vec_safe_iterate (loops->larray, i, &aloop); i++) @@ -6979,8 +6979,8 @@ move_sese_region_to_fn (struct function *dest_cfun, basic_block entry_bb, d.to_context); dest_cfun->has_simduid_loops = true; } - if (aloop->force_vect) - dest_cfun->has_force_vect_loops = true; + if (aloop->force_vectorize) + dest_cfun->has_force_vectorize_loops = true; } } diff --git a/gcc/tree-if-conv.c b/gcc/tree-if-conv.c index 0dc340f15aa..7ff21329cf1 100644 --- a/gcc/tree-if-conv.c +++ b/gcc/tree-if-conv.c @@ -728,7 +728,7 @@ ifcvt_can_use_mask_load_store (gimple stmt) basic_block bb = gimple_bb (stmt); bool is_load; - if (!(flag_tree_loop_vectorize || bb->loop_father->force_vect) + if (!(flag_tree_loop_vectorize || bb->loop_father->force_vectorize) || bb->loop_father->dont_vectorize || !gimple_assign_single_p (stmt) || gimple_has_volatile_ops (stmt)) @@ -1926,7 +1926,7 @@ version_loop_for_if_conversion (struct loop *loop) if (new_loop == NULL) return false; new_loop->dont_vectorize = true; - new_loop->force_vect = false; + new_loop->force_vectorize = false; gsi = gsi_last_bb (cond_bb); gimple_call_set_arg (g, 1, build_int_cst (integer_type_node, new_loop->num)); gsi_insert_before (&gsi, g, GSI_SAME_STMT); @@ -1950,7 +1950,7 @@ tree_if_conversion (struct loop *loop) goto cleanup; if (any_mask_load_store - && ((!flag_tree_loop_vectorize && !loop->force_vect) + && ((!flag_tree_loop_vectorize && !loop->force_vectorize) || loop->dont_vectorize)) goto cleanup; @@ -1998,7 +1998,7 @@ main_tree_if_conversion (void) FOR_EACH_LOOP (loop, 0) if (flag_tree_loop_if_convert == 1 || flag_tree_loop_if_convert_stores == 1 - || ((flag_tree_loop_vectorize || loop->force_vect) + || ((flag_tree_loop_vectorize || loop->force_vectorize) && !loop->dont_vectorize)) todo |= tree_if_conversion (loop); @@ -2018,7 +2018,7 @@ main_tree_if_conversion (void) static bool gate_tree_if_conversion (void) { - return (((flag_tree_loop_vectorize || cfun->has_force_vect_loops) + return (((flag_tree_loop_vectorize || cfun->has_force_vectorize_loops) && flag_tree_loop_if_convert != 0) || flag_tree_loop_if_convert == 1 || flag_tree_loop_if_convert_stores == 1); diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index 42932413856..7133c3cfc81 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -2354,10 +2354,10 @@ copy_loops (copy_body_data *id, dest_loop->simduid = remap_decl (src_loop->simduid, id); cfun->has_simduid_loops = true; } - if (src_loop->force_vect) + if (src_loop->force_vectorize) { - dest_loop->force_vect = true; - cfun->has_force_vect_loops = true; + dest_loop->force_vectorize = true; + cfun->has_force_vectorize_loops = true; } dest_loop->safelen = src_loop->safelen; diff --git a/gcc/tree-ssa-loop-ivcanon.c b/gcc/tree-ssa-loop-ivcanon.c index b475b067bb5..cdf1559906c 100644 --- a/gcc/tree-ssa-loop-ivcanon.c +++ b/gcc/tree-ssa-loop-ivcanon.c @@ -1129,7 +1129,7 @@ tree_unroll_loops_completely_1 (bool may_increase_size, bool unroll_outer, /* Don't unroll #pragma omp simd loops until the vectorizer attempts to vectorize those. */ - if (loop->force_vect) + if (loop->force_vectorize) return false; /* Try to unroll this loop. */ diff --git a/gcc/tree-ssa-loop.c b/gcc/tree-ssa-loop.c index e71519acf7b..4008b2bf439 100644 --- a/gcc/tree-ssa-loop.c +++ b/gcc/tree-ssa-loop.c @@ -157,7 +157,7 @@ tree_loop_vectorize (void) static bool gate_tree_loop_vectorize (void) { - return flag_tree_loop_vectorize || cfun->has_force_vect_loops; + return flag_tree_loop_vectorize || cfun->has_force_vectorize_loops; } namespace { diff --git a/gcc/tree-ssa-phiopt.c b/gcc/tree-ssa-phiopt.c index 95cf4d470a7..f1aa14d6eb7 100644 --- a/gcc/tree-ssa-phiopt.c +++ b/gcc/tree-ssa-phiopt.c @@ -350,7 +350,7 @@ tree_ssa_phiopt_worker (bool do_store_elim, bool do_hoist_loads) if (!do_store_elim) replace_conditional_negation = ((!optimize_size && optimize >= 2) - || (((flag_tree_loop_vectorize || cfun->has_force_vect_loops) + || (((flag_tree_loop_vectorize || cfun->has_force_vectorize_loops) && flag_tree_loop_if_convert != 0) || flag_tree_loop_if_convert == 1 || flag_tree_loop_if_convert_stores == 1)); diff --git a/gcc/tree-vect-loop.c b/gcc/tree-vect-loop.c index 1c78e114fe1..def3bc46174 100644 --- a/gcc/tree-vect-loop.c +++ b/gcc/tree-vect-loop.c @@ -2986,7 +2986,7 @@ vect_estimate_min_profitable_iters (loop_vec_info loop_vinfo, /* vector version will never be profitable. */ else { - if (LOOP_VINFO_LOOP (loop_vinfo)->force_vect) + if (LOOP_VINFO_LOOP (loop_vinfo)->force_vectorize) warning_at (vect_location, OPT_Wopenmp_simd, "vectorization " "did not happen for a simd loop"); diff --git a/gcc/tree-vectorizer.c b/gcc/tree-vectorizer.c index a051dce628e..765e38f689a 100644 --- a/gcc/tree-vectorizer.c +++ b/gcc/tree-vectorizer.c @@ -417,7 +417,7 @@ vectorize_loops (void) any_ifcvt_loops = true; else if ((flag_tree_loop_vectorize && optimize_loop_nest_for_speed_p (loop)) - || loop->force_vect) + || loop->force_vectorize) { loop_vec_info loop_vinfo; vect_location = find_loop_location (loop); @@ -477,7 +477,7 @@ vectorize_loops (void) num_vectorized_loops++; /* Now that the loop has been vectorized, allow it to be unrolled etc. */ - loop->force_vect = false; + loop->force_vectorize = false; if (loop->simduid) { diff --git a/gcc/tree-vectorizer.h b/gcc/tree-vectorizer.h index f2087e22383..035d654e7ad 100644 --- a/gcc/tree-vectorizer.h +++ b/gcc/tree-vectorizer.h @@ -958,7 +958,7 @@ known_alignment_for_access_p (struct data_reference *data_ref_info) static inline bool unlimited_cost_model (loop_p loop) { - if (loop != NULL && loop->force_vect + if (loop != NULL && loop->force_vectorize && flag_simd_cost_model != VECT_COST_MODEL_DEFAULT) return flag_simd_cost_model == VECT_COST_MODEL_UNLIMITED; return (flag_vect_cost_model == VECT_COST_MODEL_UNLIMITED); |