i386: Add V2SFmode sqrt insn pattern [PR95046]
authorUros Bizjak <ubizjak@gmail.com>
Mon, 11 May 2020 18:12:14 +0000 (20:12 +0200)
committerUros Bizjak <ubizjak@gmail.com>
Mon, 11 May 2020 18:12:14 +0000 (20:12 +0200)
gcc/ChangeLog:

2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>

PR target/95046
* config/i386/mmx.md (sqrtv2sf2): New insn pattern.

testsuite/ChangeLog:

2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>

PR target/95046
* gcc.target/i386/pr95046-1.c (test_sqrt): Add.

gcc/ChangeLog
gcc/config/i386/mmx.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr95046-1.c

index 7933c2c3a6f8c5ad319189c60601c01cb0f19ecf..d9f96a564af66847e45b9cd6b5ce4034a4c240d5 100644 (file)
@@ -1,3 +1,8 @@
+2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>
+
+       PR target/95046
+       * config/i386/mmx.md (sqrtv2sf2): New insn pattern.
+
 2020-05-11  Kelvin Nilsen  <kelvin@gcc.gnu.org>
 
        * config/rs6000/altivec.h (vec_cfuge): New #define.
index 7d76c631a770b7ce7799665b2e9ec19f8bf120e4..a8f603b94f88c3b35c64ad86be34369759bc90de 100644 (file)
    (set_attr "prefix_extra" "1")
    (set_attr "mode" "V2SF")])
 
+(define_insn "sqrtv2sf2"
+  [(set (match_operand:V2SF 0 "register_operand" "=x,v")
+       (sqrt:V2SF (match_operand:V2SF 1 "register_operand" "0,v")))]
+  "TARGET_MMX_WITH_SSE"
+  "@
+   sqrtps\t{%1, %0|%0, %1}
+   vsqrtps\t{%1, %0|%0, %1}"
+  [(set_attr "isa" "noavx,avx")
+   (set_attr "type" "sse")
+   (set_attr "atom_sse_attr" "sqrt")
+   (set_attr "btver2_sse_attr" "sqrt")
+   (set_attr "prefix" "orig,vex")
+   (set_attr "mode" "V4SF")])
+
 (define_insn "mmx_rsqrtv2sf2"
   [(set (match_operand:V2SF 0 "register_operand" "=y")
        (unspec:V2SF [(match_operand:V2SF 1 "nonimmediate_operand" "ym")]
index 8bd3ef092afc3da04aff3a5ae2cb03683511fc4b..158cf3857baf6c9e5b5c5f08bd999cf80490e044 100644 (file)
@@ -1,3 +1,8 @@
+2020-05-11  Uroš Bizjak  <ubizjak@gmail.com>
+
+       PR target/95046
+       * gcc.target/i386/pr95046-1.c (test_sqrt): Add.
+
 2020-05-11  Kelvin Nilsen  <kelvin@gcc.gnu.org>
 
        * gcc.target/powerpc/vec-cfuged-0.c: New test.
index f93d9e1a50770eb83a9f248aad6ceecdc72176c4..7adc2069c53d41332acb1dcb519ae341688e4df5 100644 (file)
@@ -49,3 +49,14 @@ test_max (void)
 }
 
 /* { dg-final { scan-assembler "maxps" } } */
+
+float sqrtf (float);
+
+void
+test_sqrt (void)
+{
+  for (int i = 0; i < 2; i++)
+    r[i] = sqrtf (a[i]);
+}
+
+/* { dg-final { scan-assembler "sqrtps" } } */