blob: fe5206daff8c997526ae51c064657e99d5151ec8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
/* { 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, z;
x.nan.negative = 1;
x.nan.exponent = 0x22;
x.nan.quiet_nan = 0;
x.nan.mant_high = 0x1234;
x.nan.mant_low = 0xabcdef;
z.value = __builtin_fabsf128 (x.value);
if (z.nan.negative != 0
|| z.nan.exponent != 0x22
|| z.nan.quiet_nan != 0
|| z.nan.mant_high != 0x1234
|| z.nan.mant_low != 0xabcdef)
abort ();
z.value = __builtin_fabsf128 (z.value);
if (z.nan.negative != 0
|| z.nan.exponent != 0x22
|| z.nan.quiet_nan != 0
|| z.nan.mant_high != 0x1234
|| z.nan.mant_low != 0xabcdef)
abort ();
return 0;
}
|