]> gcc.gnu.org Git - gcc.git/commitdiff
Add define_split for sign-extended PLUS of a MULT of an SImode
authorRichard Kenner <kenner@gcc.gnu.org>
Fri, 27 May 1994 18:15:25 +0000 (14:15 -0400)
committerRichard Kenner <kenner@gcc.gnu.org>
Fri, 27 May 1994 18:15:25 +0000 (14:15 -0400)
comparison.

From-SVN: r7364

gcc/config/alpha/alpha.md

index 41fbe683a0b3015c170149dad1a41dc8cc204ae1..4d1a051484f776a9ec4018058de3a976a4e73da8 100644 (file)
    s%2subl %r1,%n3,%0"
   [(set_attr "type" "iaddlog")])
 
+(define_split
+  [(set (match_operand:DI 0 "register_operand" "")
+       (sign_extend:DI
+        (plus:SI (mult:SI (match_operator:SI 1 "comparison_operator"
+                                             [(match_operand 2 "" "")
+                                              (match_operand 3 "" "")])
+                          (match_operand:SI 4 "const48_operand" ""))
+                 (match_operand:SI 5 "add_operand" ""))))
+   (clobber (match_operand:DI 6 "register_operand" ""))]
+  ""
+  [(set (match_dup 6) (match_dup 7))
+   (set (match_dup 0)
+       (sign_extend:DI (plus:SI (mult:SI (match_dup 8) (match_dup 4))
+                                (match_dup 5))))]
+  "
+{
+  operands[7] = gen_rtx (GET_CODE (operands[1]), DImode,
+                        operands[2], operands[3]);
+  operands[8] = gen_lowpart (SImode, operands[6]);
+}")
+
 (define_insn ""
   [(set (match_operand:DI 0 "register_operand" "=r,r")
        (plus:DI (mult:DI (match_operand:DI 1 "reg_or_0_operand" "rJ,rJ")
This page took 0.066728 seconds and 5 git commands to generate.