From f07013eb07cfe45ef2d67ce9ddce7cea5883e5ac Mon Sep 17 00:00:00 2001 From: Alexander Monakov Date: Thu, 14 Jan 2010 14:16:02 +0300 Subject: sel-sched.c (maybe_emit_renaming_copy): Exit early when expression to rename is not separable. 2010-01-14 Alexander Monakov * sel-sched.c (maybe_emit_renaming_copy): Exit early when expression to rename is not separable. Otherwise check that its LHS is not NULL. From-SVN: r155898 --- gcc/sel-sched.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'gcc/sel-sched.c') diff --git a/gcc/sel-sched.c b/gcc/sel-sched.c index bdc7f9c..a1a0ec0 100644 --- a/gcc/sel-sched.c +++ b/gcc/sel-sched.c @@ -5823,14 +5823,19 @@ maybe_emit_renaming_copy (rtx insn, moveop_static_params_p params) { bool insn_emitted = false; - rtx cur_reg = expr_dest_reg (params->c_expr); + rtx cur_reg; - gcc_assert (!cur_reg || (params->dest && REG_P (params->dest))); + /* Bail out early when expression can not be renamed at all. */ + if (!EXPR_SEPARABLE_P (params->c_expr)) + return false; + + cur_reg = expr_dest_reg (params->c_expr); + gcc_assert (cur_reg && params->dest && REG_P (params->dest)); /* If original operation has expr and the register chosen for that expr is not original operation's dest reg, substitute operation's right hand side with the register chosen. */ - if (cur_reg != NULL_RTX && REGNO (params->dest) != REGNO (cur_reg)) + if (REGNO (params->dest) != REGNO (cur_reg)) { insn_t reg_move_insn, reg_move_insn_rtx; -- cgit v1.1