diff options
author | Richard Guenther <rguenther@suse.de> | 2007-10-28 16:14:44 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2007-10-28 16:14:44 +0000 |
commit | eee717aa54264d9a11d842c4545384620227f0e4 (patch) | |
tree | ad9578908d462a27a5795ed5dbda0412a831ec1b /gcc/tree-nrv.c | |
parent | e85b4fa7b56003e26a98c54247d79365b740bb6d (diff) | |
download | gcc-eee717aa54264d9a11d842c4545384620227f0e4.zip gcc-eee717aa54264d9a11d842c4545384620227f0e4.tar.gz gcc-eee717aa54264d9a11d842c4545384620227f0e4.tar.bz2 |
tree-flow.h (subvar_t): Make it a VEC.
2007-10-28 Richard Guenther <rguenther@suse.de>
* tree-flow.h (subvar_t): Make it a VEC.
(struct subvar): Remove.
(struct var_ann_d): Use VEC(tree,gc) to store subvars.
* tree-flow-inline.h (get_subvar_at): Adjust iterators over
variable subvars.
* tree-into-ssa.c (mark_sym_for_renaming): Likewise.
* tree-nrv.c (dest_safe_for_nrv_p): Likewise.
* tree-ssa-alias.c (mark_aliases_call_clobbered): Likewise.
(set_initial_properties): Likewise.
(setup_pointers_and_addressables): Likewise.
(new_type_alias): Likewise.
(create_overlap_variables_for): Likewise.
* tree-dfa.c (dump_subvars_for): Likewise.
* tree-ssa-operands.c (add_vars_for_offset): Likewise.
(get_expr_operands): Likewise.
(add_to_addressable_set): Likewise.
* tree-ssa-structalias.c (set_uids_in_ptset): Likewise.
* gcc.dg/tree-ssa/alias-15.c: Adjust pattern.
From-SVN: r129699
Diffstat (limited to 'gcc/tree-nrv.c')
-rw-r--r-- | gcc/tree-nrv.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/gcc/tree-nrv.c b/gcc/tree-nrv.c index 9acfb60..ef5ee67 100644 --- a/gcc/tree-nrv.c +++ b/gcc/tree-nrv.c @@ -249,7 +249,9 @@ struct tree_opt_pass pass_nrv = static bool dest_safe_for_nrv_p (tree dest) { - subvar_t subvar; + subvar_t sv; + unsigned int i; + tree subvar; while (handled_component_p (dest)) dest = TREE_OPERAND (dest, 0); @@ -262,9 +264,12 @@ dest_safe_for_nrv_p (tree dest) if (is_call_clobbered (dest)) return false; - for (subvar = get_subvars_for_var (dest); subvar; subvar = subvar->next) - if (is_call_clobbered (subvar->var)) + + sv = get_subvars_for_var (dest); + for (i = 0; VEC_iterate (tree, sv, i, subvar); ++i) + if (is_call_clobbered (subvar)) return false; + return true; } |