Commit 95ac8e67 by Richard Kenner

(smax, smin, umax, umin): Add define_splits.

From-SVN: r2169
parent df3d94ed
...@@ -271,7 +271,8 @@ ...@@ -271,7 +271,8 @@
;; For SMIN, SMAX, UMIN, and UMAX, we use DEFINE_EXPAND's that involve a doz[i] ;; For SMIN, SMAX, UMIN, and UMAX, we use DEFINE_EXPAND's that involve a doz[i]
;; instruction and some auxiliary computations. Then we just have a single ;; instruction and some auxiliary computations. Then we just have a single
;; DEFINE_INSN for doz[i]. ;; DEFINE_INSN for doz[i] and the define_splits to make them if made by
;; combine.
(define_expand "sminsi3" (define_expand "sminsi3"
[(set (match_dup 3) [(set (match_dup 3)
...@@ -285,6 +286,19 @@ ...@@ -285,6 +286,19 @@
" "
{ operands[3] = gen_reg_rtx (SImode); }") { operands[3] = gen_reg_rtx (SImode); }")
(define_split
[(set (match_operand:SI 0 "gpc_reg_operand" "")
(smin:SI (match_operand:SI 1 "gpc_reg_operand" "")
(match_operand:SI 2 "reg_or_short_operand" "")))
(clobber (match_operand:SI 3 "gpc_reg_operand" ""))]
""
[(set (match_dup 3)
(if_then_else:SI (gt:SI (match_dup 1) (match_dup 2))
(const_int 0)
(minus:SI (match_dup 2) (match_dup 1))))
(set (match_dup 0) (minus:SI (match_dup 2) (match_dup 3)))]
"")
(define_expand "smaxsi3" (define_expand "smaxsi3"
[(set (match_dup 3) [(set (match_dup 3)
(if_then_else:SI (gt:SI (match_operand:SI 1 "gpc_reg_operand" "") (if_then_else:SI (gt:SI (match_operand:SI 1 "gpc_reg_operand" "")
...@@ -297,6 +311,19 @@ ...@@ -297,6 +311,19 @@
" "
{ operands[3] = gen_reg_rtx (SImode); }") { operands[3] = gen_reg_rtx (SImode); }")
(define_split
[(set (match_operand:SI 0 "gpc_reg_operand" "")
(smax:SI (match_operand:SI 1 "gpc_reg_operand" "")
(match_operand:SI 2 "reg_or_short_operand" "")))
(clobber (match_operand:SI 3 "gpc_reg_operand" ""))]
""
[(set (match_dup 3)
(if_then_else:SI (gt:SI (match_dup 1) (match_dup 2))
(const_int 0)
(minus:SI (match_dup 2) (match_dup 1))))
(set (match_dup 0) (plus:SI (match_dup 3) (match_dup 1)))]
"")
(define_expand "uminsi3" (define_expand "uminsi3"
[(set (match_dup 3) (xor:SI (match_operand:SI 1 "gpc_reg_operand" "") [(set (match_dup 3) (xor:SI (match_operand:SI 1 "gpc_reg_operand" "")
(const_int -2147483648))) (const_int -2147483648)))
......
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