diff options
| author | bonzini <bonzini@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-08-10 08:38:29 +0000 |
|---|---|---|
| committer | bonzini <bonzini@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-08-10 08:38:29 +0000 |
| commit | 47954a5b952bb68d0cbe2ef72d07ec20feb7496f (patch) | |
| tree | 186eb1816065a4f6b4cffad79c1dd08dff6c1d84 /gcc/expr.c | |
| parent | ad16cb2cf13a235425acaea0eb065e676687e9d3 (diff) | |
| download | ppe42-gcc-47954a5b952bb68d0cbe2ef72d07ec20feb7496f.tar.gz ppe42-gcc-47954a5b952bb68d0cbe2ef72d07ec20feb7496f.zip | |
2004-08-09 Paolo Bonzini <bonzini@gnu.org>
* expr.c (expand_expr_real_1): Add back code that was not dead.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@85742 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/expr.c')
| -rw-r--r-- | gcc/expr.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/expr.c b/gcc/expr.c index 7334c59ca39..607115b01b6 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -7778,6 +7778,32 @@ expand_expr_real_1 (tree exp, rtx target, enum machine_mode tmode, return temp; } + /* If no set-flag instruction, must generate a conditional store + into a temporary variable. Drop through and handle this + like && and ||. */ + + if (! ignore + && (target == 0 + || modifier == EXPAND_STACK_PARM + || ! safe_from_p (target, exp, 1) + /* Make sure we don't have a hard reg (such as function's return + value) live across basic blocks, if not optimizing. */ + || (!optimize && REG_P (target) + && REGNO (target) < FIRST_PSEUDO_REGISTER))) + target = gen_reg_rtx (tmode != VOIDmode ? tmode : mode); + + if (target) + emit_move_insn (target, const0_rtx); + + op1 = gen_label_rtx (); + jumpifnot (exp, op1); + + if (target) + emit_move_insn (target, const1_rtx); + + emit_label (op1); + return ignore ? const0_rtx : target; + case TRUTH_NOT_EXPR: if (modifier == EXPAND_STACK_PARM) target = 0; |

