From d45d6318a97c2ee75dca665e3c9a3c145f91d622 Mon Sep 17 00:00:00 2001 From: dje Date: Fri, 14 Jul 2006 17:44:27 +0000 Subject: [PATCH] 2006-07-14 Eliot Dresselhaus PR target/27287 * config/rs6000/spe.md (frob_di_df_2): Add m->r alternative. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@115451 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 5 +++++ gcc/config/rs6000/spe.md | 10 ++++++---- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 4cdb0acd12b..c2abdff2238 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2006-07-14 Eliot Dresselhaus + + PR target/27287 + * config/rs6000/spe.md (frob_di_df_2): Add m->r alternative. + 2006-07-14 Ulrich Weigand * config/s390/linux-unwind.h (s390_fallback_frame_state): Detect diff --git a/gcc/config/rs6000/spe.md b/gcc/config/rs6000/spe.md index 8e636f8927a..930c48a090c 100644 --- a/gcc/config/rs6000/spe.md +++ b/gcc/config/rs6000/spe.md @@ -2211,11 +2211,13 @@ [(set_attr "length" "8")]) (define_insn "*frob_di_df_2" - [(set (subreg:DF (match_operand:DI 0 "register_operand" "=&r") 0) - (match_operand:DF 1 "register_operand" "r"))] + [(set (subreg:DF (match_operand:DI 0 "register_operand" "=&r,r") 0) + (match_operand:DF 1 "input_operand" "r,m"))] "TARGET_E500_DOUBLE" - "evmergehi %H0,%1,%1\;evmergelo %L0,%1,%1" - [(set_attr "length" "8")]) + "@ + evmergehi %H0,%1,%1\;evmergelo %L0,%1,%1 + evldd%X1 %0,%y1" + [(set_attr "length" "8,4")]) (define_insn "*mov_sidf_e500_subreg0" [(set (subreg:SI (match_operand:DF 0 "register_operand" "+r") 0) -- 2.11.0