diff options
author | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-13 18:25:08 +0000 |
---|---|---|
committer | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-13 18:25:08 +0000 |
commit | e16f4c39b20659816dada504d359cb24b1f9dd6c (patch) | |
tree | 612dfb381152e5eb24ae56533da457fac8dfda06 /gcc/tree-ssa-ccp.c | |
parent | e126ac03d4781185f81c9d0adf58da9500ca0508 (diff) | |
download | gcc-e16f4c39b20659816dada504d359cb24b1f9dd6c.tar.gz |
2010-10-13 Richard Guenther <rguenther@suse.de>
PR objc/45878
* tree-ssa-ccpc (ccp_fold_stmt): Use gimple_fold_obj_type_ref.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165430 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-ssa-ccp.c')
-rw-r--r-- | gcc/tree-ssa-ccp.c | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/gcc/tree-ssa-ccp.c b/gcc/tree-ssa-ccp.c index 2fa4726e1ea..650494144cd 100644 --- a/gcc/tree-ssa-ccp.c +++ b/gcc/tree-ssa-ccp.c @@ -2267,6 +2267,7 @@ ccp_fold_stmt (gimple_stmt_iterator *gsi) tree lhs = gimple_call_lhs (stmt); tree val; tree argt; + tree callee; bool changed = false; unsigned i; @@ -2306,16 +2307,24 @@ ccp_fold_stmt (gimple_stmt_iterator *gsi) changed = true; } } - if (TREE_CODE (gimple_call_fn (stmt)) == OBJ_TYPE_REF) + + callee = gimple_call_fn (stmt); + if (TREE_CODE (callee) == OBJ_TYPE_REF + && TREE_CODE (OBJ_TYPE_REF_EXPR (callee)) == SSA_NAME) { - tree expr = OBJ_TYPE_REF_EXPR (gimple_call_fn (stmt)); - expr = valueize_op (expr); - if (TREE_CODE (expr) == ADDR_EXPR - && TREE_CODE (TREE_OPERAND (expr, 0)) == FUNCTION_DECL) - { - gimple_call_set_fn (stmt, expr); - changed = true; - } + tree expr = OBJ_TYPE_REF_EXPR (callee); + OBJ_TYPE_REF_EXPR (callee) = valueize_op (expr); + if (TREE_CODE (OBJ_TYPE_REF_EXPR (callee)) == ADDR_EXPR) + { + tree t; + t = gimple_fold_obj_type_ref (callee, NULL_TREE); + if (t) + { + gimple_call_set_fn (stmt, t); + changed = true; + } + } + OBJ_TYPE_REF_EXPR (callee) = expr; } return changed; |