aboutsummaryrefslogtreecommitdiff
path: root/gcc/expr.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2014-04-24 08:55:05 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2014-04-24 08:55:05 +0000
commitd2d11532af9f96937ea48b2a8b3481ffc722a53c (patch)
tree9a4abfc96e33b6a2300a66dd509516259d20b4e4 /gcc/expr.c
parent8117ef9898d4a3d55e1fe64a1d4c0a6d0dfaa00c (diff)
downloadgcc-d2d11532af9f96937ea48b2a8b3481ffc722a53c.zip
gcc-d2d11532af9f96937ea48b2a8b3481ffc722a53c.tar.gz
gcc-d2d11532af9f96937ea48b2a8b3481ffc722a53c.tar.bz2
expr.c (expand_expr_real_1): Avoid gimple_assign_rhs_to_tree during TER and instead use the sepops interface...
2014-04-24 Richard Biener <rguenther@suse.de> * expr.c (expand_expr_real_1): Avoid gimple_assign_rhs_to_tree during TER and instead use the sepops interface for expanding non-GIMPLE_SINGLE_RHS. From-SVN: r209741
Diffstat (limited to 'gcc/expr.c')
-rw-r--r--gcc/expr.c33
1 files changed, 27 insertions, 6 deletions
diff --git a/gcc/expr.c b/gcc/expr.c
index 72e4401..825a244 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -9395,12 +9395,33 @@ expand_expr_real_1 (tree exp, rtx target, enum machine_mode tmode,
if (g)
{
rtx r;
- location_t saved_loc = curr_insn_location ();
-
- set_curr_insn_location (gimple_location (g));
- r = expand_expr_real (gimple_assign_rhs_to_tree (g), target,
- tmode, modifier, NULL, inner_reference_p);
- set_curr_insn_location (saved_loc);
+ ops.code = gimple_assign_rhs_code (g);
+ switch (get_gimple_rhs_class (ops.code))
+ {
+ case GIMPLE_TERNARY_RHS:
+ ops.op2 = gimple_assign_rhs3 (g);
+ /* Fallthru */
+ case GIMPLE_BINARY_RHS:
+ ops.op1 = gimple_assign_rhs2 (g);
+ /* Fallthru */
+ case GIMPLE_UNARY_RHS:
+ ops.op0 = gimple_assign_rhs1 (g);
+ ops.type = TREE_TYPE (gimple_assign_lhs (g));
+ ops.location = gimple_location (g);
+ r = expand_expr_real_2 (&ops, target, tmode, modifier);
+ break;
+ case GIMPLE_SINGLE_RHS:
+ {
+ location_t saved_loc = curr_insn_location ();
+ set_curr_insn_location (gimple_location (g));
+ r = expand_expr_real (gimple_assign_rhs1 (g), target,
+ tmode, modifier, NULL, inner_reference_p);
+ set_curr_insn_location (saved_loc);
+ break;
+ }
+ default:
+ gcc_unreachable ();
+ }
if (REG_P (r) && !REG_EXPR (r))
set_reg_attrs_for_decl_rtl (SSA_NAME_VAR (exp), r);
return r;