Commit 1c7b1b7e by Ulrich Weigand Committed by Ulrich Weigand

* config/s390/s390.md ("addti3", "subti3"): New insns and splitters.

From-SVN: r79793
parent f258e38b
2004-03-21 Ulrich Weigand <uweigand@de.ibm.com>
* config/s390/s390.md ("addti3", "subti3"): New insns and splitters.
2004-03-21 Ulrich Weigand <uweigand@de.ibm.com>
* expmed.c (choose_mult_variant): Pass MULT_COST as argument instead
of using register multiplication cost.
(expand_mult): Adapt choose_mult_variant call.
......
......@@ -3331,6 +3331,35 @@
;;
;
; addti3 instruction pattern(s).
;
(define_insn_and_split "addti3"
[(set (match_operand:TI 0 "register_operand" "=&d")
(plus:TI (match_operand:TI 1 "nonimmediate_operand" "%0")
(match_operand:TI 2 "general_operand" "do") ) )
(clobber (reg:CC 33))]
"TARGET_64BIT"
"#"
"&& reload_completed"
[(parallel
[(set (reg:CCL1 33)
(compare:CCL1 (plus:DI (match_dup 7) (match_dup 8))
(match_dup 7)))
(set (match_dup 6) (plus:DI (match_dup 7) (match_dup 8)))])
(parallel
[(set (match_dup 3) (plus:DI (plus:DI (match_dup 4) (match_dup 5))
(ltu:DI (reg:CCL1 33) (const_int 0))))
(clobber (reg:CC 33))])]
"operands[3] = operand_subword (operands[0], 0, 0, TImode);
operands[4] = operand_subword (operands[1], 0, 0, TImode);
operands[5] = operand_subword (operands[2], 0, 0, TImode);
operands[6] = operand_subword (operands[0], 1, 0, TImode);
operands[7] = operand_subword (operands[1], 1, 0, TImode);
operands[8] = operand_subword (operands[2], 1, 0, TImode);"
[(set_attr "op_type" "NN")])
;
; adddi3 instruction pattern(s).
;
......@@ -3826,6 +3855,35 @@
;;
;
; subti3 instruction pattern(s).
;
(define_insn_and_split "subti3"
[(set (match_operand:TI 0 "register_operand" "=&d")
(minus:TI (match_operand:TI 1 "register_operand" "0")
(match_operand:TI 2 "general_operand" "do") ) )
(clobber (reg:CC 33))]
"TARGET_64BIT"
"#"
"&& reload_completed"
[(parallel
[(set (reg:CCL2 33)
(compare:CCL2 (minus:DI (match_dup 7) (match_dup 8))
(match_dup 7)))
(set (match_dup 6) (minus:DI (match_dup 7) (match_dup 8)))])
(parallel
[(set (match_dup 3) (minus:DI (minus:DI (match_dup 4) (match_dup 5))
(gtu:DI (reg:CCL2 33) (const_int 0))))
(clobber (reg:CC 33))])]
"operands[3] = operand_subword (operands[0], 0, 0, TImode);
operands[4] = operand_subword (operands[1], 0, 0, TImode);
operands[5] = operand_subword (operands[2], 0, 0, TImode);
operands[6] = operand_subword (operands[0], 1, 0, TImode);
operands[7] = operand_subword (operands[1], 1, 0, TImode);
operands[8] = operand_subword (operands[2], 1, 0, TImode);"
[(set_attr "op_type" "NN")])
;
; subdi3 instruction pattern(s).
;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment