vect.md (vec_extractv2sf_1): Fix cut-and-paste error; the shift is always required.
authorRichard Henderson <rth@redhat.com>
Sun, 19 Jun 2005 16:36:46 +0000 (09:36 -0700)
committerRichard Henderson <rth@gcc.gnu.org>
Sun, 19 Jun 2005 16:36:46 +0000 (09:36 -0700)
        * config/ia64/vect.md (vec_extractv2sf_1): Fix cut-and-paste error;
        the shift is always required.

From-SVN: r101186

gcc/ChangeLog
gcc/config/ia64/vect.md

index 460489b..678b0c5 100644 (file)
@@ -1,5 +1,10 @@
 2005-06-19  Richard Henderson  <rth@redhat.com>
 
+       * config/ia64/vect.md (vec_extractv2sf_1): Fix cut-and-paste error;
+       the shift is always required.
+
+2005-06-19  Richard Henderson  <rth@redhat.com>
+
        * config/ia64/ia64-modes.def (V4SF): Add.
        * config/ia64/ia64.c (ia64_legitimate_constant_p): Handle CONST_VECTOR.
        * config/ia64/ia64.h (CANNOT_CHANGE_MODE_CLASS): Allow vector to 
index c9dcf08..c2f8a1a 100644 (file)
 })
 
 (define_insn_and_split "*vec_extractv2sf_1"
-  [(set (match_operand:SF 0 "register_operand" "=rf")
+  [(set (match_operand:SF 0 "register_operand" "=r")
        (unspec:SF [(match_operand:V2SF 1 "register_operand" "r")
                    (const_int 1)]
                   UNSPEC_VECT_EXTR))]
   "reload_completed"
   [(const_int 0)]
 {
-  if (FR_REGNO_P (REGNO (operands[0])))
-    {
-      operands[1] = gen_rtx_REG (SFmode, REGNO (operands[1]));
-      emit_move_insn (operands[0], operands[1]);
-    }
-  else
-    {
-      operands[0] = gen_rtx_REG (DImode, REGNO (operands[0]));
-      operands[1] = gen_rtx_REG (DImode, REGNO (operands[1]));
-      emit_insn (gen_lshrdi3 (operands[0], operands[1], GEN_INT (32)));
-    }
+  operands[0] = gen_rtx_REG (DImode, REGNO (operands[0]));
+  operands[1] = gen_rtx_REG (DImode, REGNO (operands[1]));
+  emit_insn (gen_lshrdi3 (operands[0], operands[1], GEN_INT (32)));
   DONE;
 })