From 8e1e2862ad00842e7cd07d024e9044f0bdc7e6ee Mon Sep 17 00:00:00 2001 From: Richard Kenner Date: Wed, 27 Dec 1995 15:25:01 -0500 Subject: [PATCH] (emit_unop_insn): Don't do -fforce-mem for SIGN_EXTEND. From-SVN: r10872 --- gcc/optabs.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/gcc/optabs.c b/gcc/optabs.c index bb1b8398945..cae4c4e9bd0 100644 --- a/gcc/optabs.c +++ b/gcc/optabs.c @@ -2374,7 +2374,9 @@ emit_unop_insn (icode, target, op0, code) op0 = protect_from_queue (op0, 0); - if (flag_force_mem) + /* Sign extension from memory is often done specially on RISC + machines, so forcing into a register here can pessimize code. */ + if (flag_force_mem && code != SIGN_EXTEND) op0 = force_not_mem (op0); /* Now, if insn does not accept our operands, put them into pseudos. */