From 1e6e2c303b65dc3aab3a3bd8e63416a585de88b2 Mon Sep 17 00:00:00 2001 From: John David Anglin Date: Sat, 24 Feb 2007 19:16:45 +0000 Subject: [PATCH] pa.md (muldi3): Force subregs to registers in 64-bit expander. * pa.md (muldi3): Force subregs to registers in 64-bit expander. From-SVN: r122294 --- gcc/ChangeLog | 4 ++++ gcc/config/pa/pa.md | 8 ++++---- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 84e83e40844..58980dcd200 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2007-02-24 John David Anglin + + * pa.md (muldi3): Force subregs to registers in 64-bit expander. + 2007-02-24 Jan Hubicka * cgraphunit.c (decide_is_function_needed): Honor diff --git a/gcc/config/pa/pa.md b/gcc/config/pa/pa.md index d686cb82b57..720bf150122 100644 --- a/gcc/config/pa/pa.md +++ b/gcc/config/pa/pa.md @@ -5771,10 +5771,10 @@ GEN_INT (32))); emit_move_insn (op2shifted, gen_rtx_LSHIFTRT (DImode, operands[2], GEN_INT (32))); - op1r = gen_rtx_SUBREG (SImode, operands[1], 4); - op2r = gen_rtx_SUBREG (SImode, operands[2], 4); - op1l = gen_rtx_SUBREG (SImode, op1shifted, 4); - op2l = gen_rtx_SUBREG (SImode, op2shifted, 4); + op1r = force_reg (SImode, gen_rtx_SUBREG (SImode, operands[1], 4)); + op2r = force_reg (SImode, gen_rtx_SUBREG (SImode, operands[2], 4)); + op1l = force_reg (SImode, gen_rtx_SUBREG (SImode, op1shifted, 4)); + op2l = force_reg (SImode, gen_rtx_SUBREG (SImode, op2shifted, 4)); /* Emit multiplies for the cross products. */ emit_insn (gen_umulsidi3 (cross_product1, op2r, op1l)); -- 2.30.2