diff options
author | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-09-01 13:28:46 +0000 |
---|---|---|
committer | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-09-01 13:28:46 +0000 |
commit | e077c79b708376f8e7823e4035206792bbd4a78d (patch) | |
tree | 49f5344b822f529a83c1f7785cefc66b2fc375d8 /gcc/gimplify.c | |
parent | 94a6cc8b4693edd0c6f84016290a832e99b959f6 (diff) | |
download | gcc-e077c79b708376f8e7823e4035206792bbd4a78d.tar.gz |
2010-09-01 Richard Guenther <rguenther@suse.de>
* alias.c (ao_ref_from_mem): Adjust.
* builtins.c (get_object_alignment): Likewise.
* cfgexpand.c (expand_debug_expr): Likewise.
* gimple.c (get_base_address): Likewise.
* tree-dfa.c (get_ref_base_and_extent): Likewise.
(get_addr_base_and_unit_offset): Likewise. Fix for
both TMR_SYMBOL and TMR_BASE being set.
* tree-eh.c (tree_could_trap_p): Likewise.
* gimplify.c (gimplify_expr): Do not attempt to gimplify
TMR_SYMBOL. Always gimplify TMR_BASE.
* tree-cfg.c (verify_types_in_gimple_reference): Verify
TMR_BASE if there is a TMR_SYMBOL.
* tree-pretty-print.c (dump_generic_node): Adjust.
* tree-ssa-address.c (addr_for_mem_ref): Likewise.
(tree_mem_ref_addr): Likewise.
(create_mem_ref_raw): Likewise.
(move_fixed_address_to_symbol): Likewise.
(create_mem_ref): Likewise.
(dump_mem_address): Likewise.
* tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Adjust.
Fix for both TMR_SYMBOL and TMR_BASE being set.
(indirect_refs_may_alias_p): Likewise.
* tree-ssa-operands.c (get_tmr_operands): Adjust.
* tree.def (TARGET_MEM_REF): Adjust documentation.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@163733 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gimplify.c')
-rw-r--r-- | gcc/gimplify.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/gcc/gimplify.c b/gcc/gimplify.c index b0468c6856b..bdb97ec9ba0 100644 --- a/gcc/gimplify.c +++ b/gcc/gimplify.c @@ -6978,9 +6978,14 @@ gimplify_expr (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p, enum gimplify_status r0 = GS_ALL_DONE, r1 = GS_ALL_DONE; if (TMR_SYMBOL (*expr_p)) - r0 = gimplify_expr (&TMR_SYMBOL (*expr_p), pre_p, - post_p, is_gimple_lvalue, fb_either); - else if (TMR_BASE (*expr_p)) + /* We can't gimplify the symbol part. Assert it is + already gimple instead. + ??? This isn't exactly the same as ADDR_EXPR + plus is_gimple_mem_ref_addr (), see fixed_address_object_p. */ + gcc_assert (TREE_CODE (TMR_SYMBOL (*expr_p)) == ADDR_EXPR + && (TREE_CODE (TREE_OPERAND (TMR_SYMBOL (*expr_p), 0)) + == VAR_DECL)); + if (TMR_BASE (*expr_p)) r0 = gimplify_expr (&TMR_BASE (*expr_p), pre_p, post_p, is_gimple_val, fb_either); if (TMR_INDEX (*expr_p)) |