diff mbox

[i386] : Fix PR56788, _mm_frcz_sd and _mm_frcz_ss ignore their second argument

Message ID CAFULd4bK2QmyjL7jBVVS1Mu7jPWbqTjx5dgyRn4AYHAt1+8fug@mail.gmail.com
State New
Headers show

Commit Message

Uros Bizjak Nov. 27, 2013, 6:10 p.m. UTC
On Wed, Nov 27, 2013 at 7:45 AM, Gopalasubramanian, Ganesh
<Ganesh.Gopalasubramanian@amd.com> wrote:
>> Hopefully someone from AMD will provide tests that are mysteriously missing from XOP testsuite.
>
> As pointed out by Marc, I added myself to the bug later.
> I was bit confused about the "internal insn representation" with "user-visible function".
> So, couldn't add test then and there. I could have solved that earlier. Sorry for that.
>
> Attached is the test that checks the (controversial) "frcz" functions.
>
> Uros could you please add this to your patch while committing.

Thanks, I have changed the patch slightly to skip runtime test on
non-xop machines.

2013-11-27  Uros Bizjak  <ubizjak@gmail.com>
        Ganesh Gopalasubramanian  <Ganesh.Gopalasubramanian@amd.com>

    PR target/56788
    * gcc.target/i386/xop-frczX.c: New test.

Tested on x86_64-pc-linux-gnu {,-m32} and committed to mainline SVN.

Uros.
diff mbox

Patch

Index: gcc.target/i386/xop-frczX.c
===================================================================
--- gcc.target/i386/xop-frczX.c	(revision 0)
+++ gcc.target/i386/xop-frczX.c	(working copy)
@@ -0,0 +1,60 @@ 
+/* { dg-do run } */
+/* { dg-require-effective-target xop } */
+/* { dg-options "-O2 -mxop" } */
+
+#include "xop-check.h"
+
+#include <x86intrin.h>
+
+void
+check_mm_vmfrcz_sd (__m128d __A, __m128d __B)
+{
+  union128d a, b, c;
+  double d[2];
+
+  a.x = __A;
+  b.x = __B;
+  c.x = _mm_frcz_sd (__A, __B);
+  d[0] = b.a[0] - (int)b.a[0] ;
+  d[1] = a.a[1];
+  if (check_union128d (c, d))
+    abort ();
+}
+
+void
+check_mm_vmfrcz_ss (__m128 __A, __m128 __B)
+{
+  union128 a, b, c;
+  float f[4];
+
+  a.x = __A;
+  b.x = __B;
+  c.x = _mm_frcz_ss (__A, __B);
+  f[0] = b.a[0] - (int)b.a[0] ;
+  f[1] = a.a[1];
+  f[2] = a.a[2];
+  f[3] = a.a[3];
+  if (check_union128 (c, f))
+    abort ();
+}
+
+static void
+xop_test (void)
+{
+  union128 a, b;
+  union128d c,d;
+  int i;
+
+  for (i = 0; i < 4; i++)
+    {
+       a.a[i] = i + 3.5;
+       b.a[i] = i + 7.9;
+    }
+  for (i = 0; i < 2; i++)
+    {
+       c.a[i] = i + 3.5;
+       d.a[i] = i + 7.987654321;
+    }
+  check_mm_vmfrcz_ss (a.x, b.x);
+  check_mm_vmfrcz_sd (c.x, d.x);
+}