]> git.ipfire.org Git - thirdparty/gcc.git/blobdiff - gcc/testsuite/gcc.target/powerpc/float128-hw.c
[gcc]
[thirdparty/gcc.git] / gcc / testsuite / gcc.target / powerpc / float128-hw.c
index 68e4c27aa5869cb38556c10e0bd0ee8f6ac1e314..929c6ddabe0e5e8bce0e29812b806a6274325269 100644 (file)
@@ -2,16 +2,58 @@
 /* { dg-require-effective-target powerpc_p9vector_ok } */
 /* { dg-options "-mpower9-vector -O2" } */
 
-__float128 f128_add (__float128 a, __float128 b) { return a+b; }
-__float128 f128_sub (__float128 a, __float128 b) { return a-b; }
-__float128 f128_mul (__float128 a, __float128 b) { return a*b; }
-__float128 f128_div (__float128 a, __float128 b) { return a/b; }
-__float128 f128_fma (__float128 a, __float128 b, __float128 c) { return (a*b)+c; }
-long f128_cmove (__float128 a, __float128 b, long c, long d) { return (a == b) ? c : d; }
+#ifndef TYPE
+#define TYPE _Float128
+#endif
+
+/* Test the code generation of the various _Float128 operations.  */
+TYPE f128_add (TYPE a, TYPE b) { return a+b; }
+TYPE f128_sub (TYPE a, TYPE b) { return a-b; }
+TYPE f128_mul (TYPE a, TYPE b) { return a*b; }
+TYPE f128_div (TYPE a, TYPE b) { return a/b; }
+TYPE f128_fma (TYPE a, TYPE b, TYPE c) { return (a*b)+c; }
+TYPE f128_fms (TYPE a, TYPE b, TYPE c) { return (a*b)-c; }
+TYPE f128_nfma (TYPE a, TYPE b, TYPE c) { return -((a*b)+c); }
+TYPE f128_nfms (TYPE a, TYPE b, TYPE c) { return -((a*b)-c); }
+TYPE f128_neg (TYPE a) { return -a; }
+
+long f128_cmove (TYPE a, TYPE b, long c, long d) { return (a == b) ? c : d; }
+
+double f128_to_double (TYPE a) { return (double)a; }
+float f128_to_float (TYPE a) { return (float)a; }
+long f128_to_long (TYPE a) { return (long)a; }
+unsigned long f128_to_ulong (TYPE a) { return (unsigned long)a; }
+int f128_to_int (TYPE a) { return (int)a; }
+unsigned int f128_to_uint (TYPE a) { return (unsigned int)a; }
+
+TYPE double_to_f128 (double a) { return (TYPE)a; }
+TYPE float_to_f128 (float a) { return (TYPE)a; }
+TYPE long_to_f128 (long a) { return (TYPE)a; }
+TYPE ulong_to_f128 (unsigned long a) { return (TYPE)a; }
+TYPE int_to_f128 (int a) { return (TYPE)a; }
+TYPE uint_to_f128 (unsigned int a) { return (TYPE)a; }
+
+/* { dg-final { scan-assembler     {\mmfvsrd\M}    } } */
+/* { dg-final { scan-assembler     {\mmfvsrwz\M}   } } */
+/* { dg-final { scan-assembler     {\mmtvsrd\M}    } } */
+/* { dg-final { scan-assembler     {\mmtvsrwa\M}   } } */
+/* { dg-final { scan-assembler            {\mxscmpuqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxscvdpqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxscvqpdp\M}  } } */
+/* { dg-final { scan-assembler            {\mxscvqpdpo\M} } } */
+/* { dg-final { scan-assembler            {\mxscvqpsdz\M} } } */
+/* { dg-final { scan-assembler            {\mxscvqpswz\M} } } */
+/* { dg-final { scan-assembler            {\mxscvqpudz\M} } } */
+/* { dg-final { scan-assembler            {\mxscvqpuwz\M} } } */
+/* { dg-final { scan-assembler            {\mxscvsdqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxscvudqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxsdivqp\M}   } } */
+/* { dg-final { scan-assembler            {\mxsmaddqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxsmsubqp\M}  } } */
+/* { dg-final { scan-assembler            {\mxsmulqp\M}   } } */
+/* { dg-final { scan-assembler            {\mxsnegqp\M}   } } */
+/* { dg-final { scan-assembler            {\mxsnmaddqp\M} } } */
+/* { dg-final { scan-assembler            {\mxsnmsubqp\M} } } */
+/* { dg-final { scan-assembler            {\mxssubqp\M}   } } */
+/* { dg-final { scan-assembler-not {\mbl\M}        } } */
 
-/* { dg-final { scan-assembler "xsaddqp"  } } */
-/* { dg-final { scan-assembler "xssubqp"  } } */
-/* { dg-final { scan-assembler "xsmulqp"  } } */
-/* { dg-final { scan-assembler "xsdivqp"  } } */
-/* { dg-final { scan-assembler "xsmaddqp" } } */
-/* { dg-final { scan-assembler "xscmpuqp" } } */