Commit 2629da83 by H.J. Lu Committed by H.J. Lu

i386: Emulate MMX mmx_eq/mmx_gt<mode>3 with SSE

Emulate MMX mmx_eq/mmx_gt<mode>3 with SSE.  Only SSE register source
operand is allowed.

	PR target/89021
	* config/i386/mmx.md (mmx_eq<mode>3): Also allow
	TARGET_MMX_WITH_SSE.
	(*mmx_eq<mode>3): Also allow TARGET_MMX_WITH_SSE.  Add SSE
	support.
	(mmx_gt<mode>3): Likewise.

From-SVN: r271224
parent df0e1979
2019-05-15 H.J. Lu <hongjiu.lu@intel.com> 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
PR target/89021 PR target/89021
* config/i386/mmx.md (mmx_eq<mode>3): Also allow
TARGET_MMX_WITH_SSE.
(*mmx_eq<mode>3): Also allow TARGET_MMX_WITH_SSE. Add SSE
support.
(mmx_gt<mode>3): Likewise.
2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
PR target/89021
* config/i386/mmx.md (mmx_andnot<mode>3): Also allow * config/i386/mmx.md (mmx_andnot<mode>3): Also allow
TARGET_MMX_WITH_SSE. Add SSE support. TARGET_MMX_WITH_SSE. Add SSE support.
......
...@@ -1042,30 +1042,39 @@ ...@@ -1042,30 +1042,39 @@
(define_expand "mmx_eq<mode>3" (define_expand "mmx_eq<mode>3"
[(set (match_operand:MMXMODEI 0 "register_operand") [(set (match_operand:MMXMODEI 0 "register_operand")
(eq:MMXMODEI (eq:MMXMODEI
(match_operand:MMXMODEI 1 "nonimmediate_operand") (match_operand:MMXMODEI 1 "register_mmxmem_operand")
(match_operand:MMXMODEI 2 "nonimmediate_operand")))] (match_operand:MMXMODEI 2 "register_mmxmem_operand")))]
"TARGET_MMX" "TARGET_MMX || TARGET_MMX_WITH_SSE"
"ix86_fixup_binary_operands_no_copy (EQ, <MODE>mode, operands);") "ix86_fixup_binary_operands_no_copy (EQ, <MODE>mode, operands);")
(define_insn "*mmx_eq<mode>3" (define_insn "*mmx_eq<mode>3"
[(set (match_operand:MMXMODEI 0 "register_operand" "=y") [(set (match_operand:MMXMODEI 0 "register_operand" "=y,x,Yv")
(eq:MMXMODEI (eq:MMXMODEI
(match_operand:MMXMODEI 1 "nonimmediate_operand" "%0") (match_operand:MMXMODEI 1 "register_mmxmem_operand" "%0,0,Yv")
(match_operand:MMXMODEI 2 "nonimmediate_operand" "ym")))] (match_operand:MMXMODEI 2 "register_mmxmem_operand" "ym,x,Yv")))]
"TARGET_MMX && ix86_binary_operator_ok (EQ, <MODE>mode, operands)" "(TARGET_MMX || TARGET_MMX_WITH_SSE)
"pcmpeq<mmxvecsize>\t{%2, %0|%0, %2}" && ix86_binary_operator_ok (EQ, <MODE>mode, operands)"
[(set_attr "type" "mmxcmp") "@
(set_attr "mode" "DI")]) pcmpeq<mmxvecsize>\t{%2, %0|%0, %2}
pcmpeq<mmxvecsize>\t{%2, %0|%0, %2}
vpcmpeq<mmxvecsize>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "mmx_isa" "native,x64_noavx,x64_avx")
(set_attr "type" "mmxcmp,ssecmp,ssecmp")
(set_attr "mode" "DI,TI,TI")])
(define_insn "mmx_gt<mode>3" (define_insn "mmx_gt<mode>3"
[(set (match_operand:MMXMODEI 0 "register_operand" "=y") [(set (match_operand:MMXMODEI 0 "register_operand" "=y,x,Yv")
(gt:MMXMODEI (gt:MMXMODEI
(match_operand:MMXMODEI 1 "register_operand" "0") (match_operand:MMXMODEI 1 "register_operand" "0,0,Yv")
(match_operand:MMXMODEI 2 "nonimmediate_operand" "ym")))] (match_operand:MMXMODEI 2 "register_mmxmem_operand" "ym,x,Yv")))]
"TARGET_MMX" "TARGET_MMX || TARGET_MMX_WITH_SSE"
"pcmpgt<mmxvecsize>\t{%2, %0|%0, %2}" "@
[(set_attr "type" "mmxcmp") pcmpgt<mmxvecsize>\t{%2, %0|%0, %2}
(set_attr "mode" "DI")]) pcmpgt<mmxvecsize>\t{%2, %0|%0, %2}
vpcmpgt<mmxvecsize>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "mmx_isa" "native,x64_noavx,x64_avx")
(set_attr "type" "mmxcmp,ssecmp,ssecmp")
(set_attr "mode" "DI,TI,TI")])
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; ;;
......
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