59 lines
1.1 KiB
C
59 lines
1.1 KiB
C
/* { dg-do run { target { powerpc64*-*-* && vsx_hw } } } */
|
|
/* { dg-options "-mfloat128 -mvsx" } */
|
|
|
|
void abort ();
|
|
|
|
typedef unsigned long long int uint64_t;
|
|
|
|
typedef union
|
|
{
|
|
__float128 value;
|
|
|
|
struct
|
|
{
|
|
#if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
|
|
unsigned negative:1;
|
|
unsigned exponent:15;
|
|
unsigned quiet_nan:1;
|
|
uint64_t mant_high:47;
|
|
uint64_t mant_low:64;
|
|
#else
|
|
uint64_t mant_low:64;
|
|
uint64_t mant_high:47;
|
|
unsigned quiet_nan:1;
|
|
unsigned exponent:15;
|
|
unsigned negative:1;
|
|
#endif
|
|
} nan;
|
|
|
|
} ieee854_float128;
|
|
|
|
int
|
|
main (int argc, int *argv[])
|
|
{
|
|
ieee854_float128 x, y, z;
|
|
|
|
x.nan.negative = 0;
|
|
x.nan.exponent = 0x22;
|
|
x.nan.quiet_nan = 0;
|
|
x.nan.mant_high = 0x1234;
|
|
x.nan.mant_low = 0xabcdef;
|
|
|
|
y.nan.negative = 1;
|
|
y.nan.exponent = 0;
|
|
y.nan.quiet_nan = 0;
|
|
y.nan.mant_high = 0;
|
|
y.nan.mant_low = 0;
|
|
|
|
z.value = __builtin_copysignq (x.value, y.value);
|
|
|
|
if (z.nan.negative != 1
|
|
|| z.nan.exponent != 0x22
|
|
|| z.nan.quiet_nan != 0
|
|
|| z.nan.mant_high != 0x1234
|
|
|| z.nan.mant_low != 0xabcdef)
|
|
abort ();
|
|
|
|
return 0;
|
|
}
|