From 28daba6f2cf86e80ffa7fd691ec1029fe3418213 Mon Sep 17 00:00:00 2001 From: rguenth Date: Fri, 3 Sep 2010 09:50:17 +0000 Subject: 2010-09-03 Richard Guenther * tree.def (TARGET_MEM_REF): Merge TMR_SYMBOL and TMR_BASE. Move TMR_OFFSET to second operand. Add TMR_INDEX2. * tree.h (TMR_SYMBOL): Remove. (TMR_BASE, TMR_OFFSET): Adjust. (TMR_INDEX2): New. * alias.c (ao_ref_from_mem): Use TMR_BASE. * builtins.c (get_object_alignment): Merge TMR_BASE and TMR_SYMBOL handling. * cfgexpand.c (expand_debug_expr): Use TMR_BASE. * gimple.c (get_base_address): Merge MEM_REF and TARGET_MEM_REF handling. Also allow TARGET_MEM_REF as base address. (walk_stmt_load_store_addr_ops): TMR_BASE is always non-NULL. * gimplify.c (gimplify_expr): Gimplify TMR_BASE like MEM_REF base. Gimplify TMR_INDEX2. * tree-cfg.c (verify_types_in_gimple_reference): Adjust. * tree-dfa.c (get_ref_base_and_extent): Likewise. (get_addr_base_and_unit_offset): Likewise. * tree-eh.c (tree_could_trap_p): Likewise. * tree-pretty-print.c (dump_generic_node): Likewise. * tree-ssa-address.c (tree_mem_ref_addr): Simplify. Handle TMR_INDEX2. (create_mem_ref_raw): Merge symbol and base. Move 2ndary base to index2. (get_address_description): Reconstruct addres description from merged TMR_BASE and TMR_INDEX2. (maybe_fold_tmr): Fold propagated addresses. * tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Merge MEM_REF and TARGET_MEM_REF paths. (indirect_refs_may_alias_p): Likewise. * tree-ssa-live.c (mark_all_vars_used_1): Handle TMR_INDEX2 instead of TMR_SYMBOL. * tree-ssa-operands.c (get_tmr_operands): Simplify. * tree-ssa-pre.c (create_component_ref_by_pieces_1): Adjust according to changes ... * tree-ssa-sccvn.c (copy_reference_ops_from_ref): ... here. Split TARGET_MEM_REF into two fields plus the base. * tree.c (mem_ref_offset): Simplify. * tree-ssa-loop-im.c (for_each_index): Handle TMR_INDEX2. * tree-ssa-loop-ivopts.c (find_interesting_uses_address): Likewise. Strip NOPs when folding MEM_REF addresses. * tree-ssa-sink.c (is_hidden_global_store): Handle TARGET_MEM_REF. * gimple-fold.c (maybe_fold_reference): Fold TARGET_MEM_REF here ... (fold_gimple_assign): ... not here. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@163802 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/tree-ssa-alias.c | 49 +++---------------------------------------------- 1 file changed, 3 insertions(+), 46 deletions(-) (limited to 'gcc/tree-ssa-alias.c') diff --git a/gcc/tree-ssa-alias.c b/gcc/tree-ssa-alias.c index fe017d7a15e..a9f1c19f7ac 100644 --- a/gcc/tree-ssa-alias.c +++ b/gcc/tree-ssa-alias.c @@ -670,21 +670,7 @@ indirect_ref_may_alias_decl_p (tree ref1 ATTRIBUTE_UNUSED, tree base1, tree ptrtype1; HOST_WIDE_INT offset1p = offset1, offset2p = offset2; - if (TREE_CODE (base1) == TARGET_MEM_REF) - { - if (TMR_SYMBOL (base1)) - ptr1 = TMR_SYMBOL (base1); - else if (TMR_BASE (base1)) - { - if (!POINTER_TYPE_P (TREE_TYPE (TMR_BASE (base1)))) - return true; - ptr1 = TMR_BASE (base1); - } - else - return true; - } - else - ptr1 = TREE_OPERAND (base1, 0); + ptr1 = TREE_OPERAND (base1, 0); /* The offset embedded in MEM_REFs can be negative. Bias them so that the resulting offset adjustment is positive. */ @@ -812,37 +798,8 @@ indirect_refs_may_alias_p (tree ref1 ATTRIBUTE_UNUSED, tree base1, tree ptr2; tree ptrtype1, ptrtype2; - if (TREE_CODE (base1) == TARGET_MEM_REF) - { - if (TMR_SYMBOL (base1)) - ptr1 = TMR_SYMBOL (base1); - else if (TMR_BASE (base1)) - { - if (!POINTER_TYPE_P (TREE_TYPE (TMR_BASE (base1)))) - return true; - ptr1 = TMR_BASE (base1); - } - else - return true; - } - else - ptr1 = TREE_OPERAND (base1, 0); - - if (TREE_CODE (base2) == TARGET_MEM_REF) - { - if (TMR_SYMBOL (base2)) - ptr2 = TMR_SYMBOL (base2); - else if (TMR_BASE (base2)) - { - if (!POINTER_TYPE_P (TREE_TYPE (TMR_BASE (base2)))) - return true; - ptr2 = TMR_BASE (base2); - } - else - return true; - } - else - ptr2 = TREE_OPERAND (base2, 0); + ptr1 = TREE_OPERAND (base1, 0); + ptr2 = TREE_OPERAND (base2, 0); /* If both bases are based on pointers they cannot alias if they may not point to the same memory object or if they point to the same object -- cgit v1.2.1