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-ssa-operands.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-ssa-operands.c')
-rw-r--r-- | gcc/tree-ssa-operands.c | 38 |
1 files changed, 22 insertions, 16 deletions
diff --git a/gcc/tree-ssa-operands.c b/gcc/tree-ssa-operands.c index 206c04b..1c4299f 100644 --- a/gcc/tree-ssa-operands.c +++ b/gcc/tree-ssa-operands.c @@ -1421,20 +1421,23 @@ add_vars_for_offset (tree full_ref, tree var, HOST_WIDE_INT offset, { bool added = false; subvar_t sv = get_subvars_for_var (SFT_PARENT_VAR (var)); - for (; sv; sv = sv->next) + unsigned int i; + tree subvar; + + for (i = 0; VEC_iterate (tree, sv, i, subvar); ++i) { /* Once we hit the end of the parts that could touch, stop looking. */ if (size != -1 - && SFT_OFFSET (var) + offset + size <= SFT_OFFSET (sv->var)) + && SFT_OFFSET (var) + offset + size <= SFT_OFFSET (subvar)) break; - if (overlap_subvar (SFT_OFFSET (var) + offset, size, sv->var, NULL)) + if (overlap_subvar (SFT_OFFSET (var) + offset, size, subvar, NULL)) { added = true; if (is_def) - append_vdef (sv->var); + append_vdef (subvar); else - append_vuse (sv->var); + append_vuse (subvar); } } return added; @@ -2092,9 +2095,10 @@ get_expr_operands (tree stmt, tree *expr_p, int flags) if (var_can_have_subvars (expr) && (svars = get_subvars_for_var (expr))) { - subvar_t sv; - for (sv = svars; sv; sv = sv->next) - add_stmt_operand (&sv->var, s_ann, flags); + unsigned int i; + tree subvar; + for (i = 0; VEC_iterate (tree, svars, i, subvar); ++i) + add_stmt_operand (&subvar, s_ann, flags); } else add_stmt_operand (expr_p, s_ann, flags); @@ -2137,18 +2141,19 @@ get_expr_operands (tree stmt, tree *expr_p, int flags) ref = get_ref_base_and_extent (expr, &offset, &size, &maxsize); if (SSA_VAR_P (ref) && get_subvars_for_var (ref)) { - subvar_t sv; subvar_t svars = get_subvars_for_var (ref); + unsigned int i; + tree subvar; - for (sv = svars; sv; sv = sv->next) + for (i = 0; VEC_iterate (tree, svars, i, subvar); ++i) { bool exact; - if (overlap_subvar (offset, maxsize, sv->var, &exact)) + if (overlap_subvar (offset, maxsize, subvar, &exact)) { int subvar_flags = flags; none = false; - add_stmt_operand (&sv->var, s_ann, subvar_flags); + add_stmt_operand (&subvar, s_ann, subvar_flags); } } @@ -2710,11 +2715,12 @@ add_to_addressable_set (tree ref, bitmap *addresses_taken) if (var_can_have_subvars (var) && (svars = get_subvars_for_var (var))) { - subvar_t sv; - for (sv = svars; sv; sv = sv->next) + unsigned int i; + tree subvar; + for (i = 0; VEC_iterate (tree, svars, i, subvar); ++i) { - bitmap_set_bit (*addresses_taken, DECL_UID (sv->var)); - TREE_ADDRESSABLE (sv->var) = 1; + bitmap_set_bit (*addresses_taken, DECL_UID (subvar)); + TREE_ADDRESSABLE (subvar) = 1; } } else |