i386: Improve basic vectorized V2SFmode operations [PR95046]
authorUros Bizjak <ubizjak@gmail.com>
Mon, 11 May 2020 14:37:19 +0000 (16:37 +0200)
committerUros Bizjak <ubizjak@gmail.com>
Mon, 11 May 2020 14:38:54 +0000 (16:38 +0200)
Use plain "v" constraint for AVX alternatives and add "prefix" attribute.

gcc/ChangeLog:

PR target/95046
* config/i386/mmx.md (mmx_addv2sf3): Use "v" constraint
instead of "Yv" for AVX alternatives.  Add "prefix" attribute.
(*mmx_addv2sf3): Ditto.
(*mmx_subv2sf3): Ditto.
(*mmx_mulv2sf3): Ditto.
(*mmx_<code>v2sf3): Ditto.
(mmx_ieee_<ieee_maxmin>v2sf3): Ditto.

gcc/ChangeLog
gcc/config/i386/mmx.md

index ae022d5cf52e94706710e4cfcdbbdc773a6ed977..acf6da24c3268cbe5853e2892755e733dc297418 100644 (file)
        (*csinv3_uxtw_insn3): New.
        * config/aarch64/iterators.md (neg_not_cs): New.
 
+2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>
+
+       PR target/95046
+       * config/i386/mmx.md (mmx_addv2sf3): Use "v" constraint
+       instead of "Yv" for AVX alternatives.  Add "prefix" attribute.
+       (*mmx_addv2sf3): Ditto.
+       (*mmx_subv2sf3): Ditto.
+       (*mmx_mulv2sf3): Ditto.
+       (*mmx_<code>v2sf3): Ditto.
+       (mmx_ieee_<ieee_maxmin>v2sf3): Ditto.
+
 2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>
 
        PR target/95046
index d3e0004d3a060eb3583cbf1d5c77dcf706352031..7d76c631a770b7ce7799665b2e9ec19f8bf120e4 100644 (file)
   "ix86_fixup_binary_operands_no_copy (PLUS, V2SFmode, operands);")
 
 (define_insn "*mmx_addv2sf3"
-  [(set (match_operand:V2SF 0 "register_operand" "=y,x,Yv")
+  [(set (match_operand:V2SF 0 "register_operand" "=y,x,v")
        (plus:V2SF
-         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,Yv")
-         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,Yv")))]
+         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,v")
+         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,v")))]
   "(TARGET_3DNOW || TARGET_MMX_WITH_SSE)
    && ix86_binary_operator_ok (PLUS, V2SFmode, operands)"
   "@
    (set_attr "mmx_isa" "native,*,*")
    (set_attr "type" "mmxadd,sseadd,sseadd")
    (set_attr "prefix_extra" "1,*,*")
+   (set_attr "prefix" "*,orig,vex")
    (set_attr "mode" "V2SF,V4SF,V4SF")])
 
 (define_expand "mmx_subv2sf3"
   "ix86_fixup_binary_operands_no_copy (MINUS, V2SFmode, operands);")
 
 (define_insn "*mmx_subv2sf3"
-  [(set (match_operand:V2SF 0 "register_operand" "=y,y,x,Yv")
+  [(set (match_operand:V2SF 0 "register_operand" "=y,y,x,v")
         (minus:V2SF
-         (match_operand:V2SF 1 "register_mmxmem_operand" "0,ym,0,Yv")
-         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,0,x,Yv")))]
+         (match_operand:V2SF 1 "register_mmxmem_operand" "0,ym,0,v")
+         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,0,x,v")))]
   "(TARGET_3DNOW || TARGET_MMX_WITH_SSE)
    && !(MEM_P (operands[0]) && MEM_P (operands[1]))"
   "@
    (set_attr "mmx_isa" "native,native,*,*")
    (set_attr "type" "mmxadd,mmxadd,sseadd,sseadd")
    (set_attr "prefix_extra" "1,1,*,*")
+   (set_attr "prefix" "*,*,orig,vex")
    (set_attr "mode" "V2SF,V2SF,V4SF,V4SF")])
 
 (define_expand "mmx_mulv2sf3"
   "ix86_fixup_binary_operands_no_copy (MULT, V2SFmode, operands);")
 
 (define_insn "*mmx_mulv2sf3"
-  [(set (match_operand:V2SF 0 "register_operand" "=y,x,Yv")
+  [(set (match_operand:V2SF 0 "register_operand" "=y,x,v")
        (mult:V2SF
-         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,Yv")
-         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,Yv")))]
+         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,v")
+         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,v")))]
   "(TARGET_3DNOW || TARGET_MMX_WITH_SSE)
    && ix86_binary_operator_ok (MULT, V2SFmode, operands)"
   "@
   [(set_attr "isa" "*,sse2_noavx,avx")
    (set_attr "mmx_isa" "native,*,*")
    (set_attr "type" "mmxmul,ssemul,ssemul")
-   (set_attr "prefix_extra" "1,*,*")
    (set_attr "btver2_decode" "*,direct,double")
+   (set_attr "prefix_extra" "1,*,*")
+   (set_attr "prefix" "*,orig,vex")
    (set_attr "mode" "V2SF,V4SF,V4SF")])
 
 (define_expand "mmx_<code>v2sf3"
 ;; are undefined in this condition, we're certain this is correct.
 
 (define_insn "*mmx_<code>v2sf3"
-  [(set (match_operand:V2SF 0 "register_operand" "=y,x,Yv")
+  [(set (match_operand:V2SF 0 "register_operand" "=y,x,v")
         (smaxmin:V2SF
-         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,Yv")
-         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,Yv")))]
+         (match_operand:V2SF 1 "register_mmxmem_operand" "%0,0,v")
+         (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,v")))]
   "(TARGET_3DNOW || TARGET_MMX_WITH_SSE)
    && ix86_binary_operator_ok (<CODE>, V2SFmode, operands)"
   "@
    (set_attr "type" "mmxadd,sseadd,sseadd")
    (set_attr "btver2_sse_attr" "*,maxmin,maxmin")
    (set_attr "prefix_extra" "1,*,*")
+   (set_attr "prefix" "*,orig,vex")
    (set_attr "mode" "V2SF,V4SF,V4SF")])
 
 ;; These versions of the min/max patterns implement exactly the operations
 ;; presence of -0.0 and NaN.
 
 (define_insn "mmx_ieee_<ieee_maxmin>v2sf3"
-  [(set (match_operand:V2SF 0 "register_operand" "=y,x,Yv")
+  [(set (match_operand:V2SF 0 "register_operand" "=y,x,v")
         (unspec:V2SF
-         [(match_operand:V2SF 1 "register_operand" "0,0,Yv")
-          (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,Yv")]
+         [(match_operand:V2SF 1 "register_operand" "0,0,v")
+          (match_operand:V2SF 2 "register_mmxmem_operand" "ym,x,v")]
          IEEE_MAXMIN))]
   "TARGET_3DNOW || TARGET_MMX_WITH_SSE"
   "@
    (set_attr "type" "mmxadd,sseadd,sseadd")
    (set_attr "btver2_sse_attr" "*,maxmin,maxmin")
    (set_attr "prefix_extra" "1,*,*")
+   (set_attr "prefix" "*,orig,vex")
    (set_attr "mode" "V2SF,V4SF,V4SF")])
 
 (define_insn "mmx_rcpv2sf2"