1 // RUN: %clang_builtins %s %librt -o %t && %run %t
2 // REQUIRES: librt_has_fixdfdi
7 // Returns: convert a to a signed long long, rounding toward zero.
9 // Assumption: double is a IEEE 64 bit floating point type
10 // su_int is a 32 bit integral type
11 // value in double is representable in di_int (no range checking performed)
13 // seee eeee eeee mmmm mmmm mmmm mmmm mmmm | mmmm mmmm mmmm mmmm mmmm mmmm mmmm mmmm
15 COMPILER_RT_ABI di_int
__fixdfdi(double a
);
17 int test__fixdfdi(double a
, di_int expected
)
19 di_int x
= __fixdfdi(a
);
21 printf("error in __fixdfdi(%A) = %llX, expected %llX\n", a
, x
, expected
);
25 char assumption_1
[sizeof(di_int
) == 2*sizeof(si_int
)] = {0};
26 char assumption_2
[sizeof(su_int
)*CHAR_BIT
== 32] = {0};
27 char assumption_3
[sizeof(double)*CHAR_BIT
== 64] = {0};
31 if (test__fixdfdi(0.0, 0))
34 if (test__fixdfdi(0.5, 0))
36 if (test__fixdfdi(0.99, 0))
38 if (test__fixdfdi(1.0, 1))
40 if (test__fixdfdi(1.5, 1))
42 if (test__fixdfdi(1.99, 1))
44 if (test__fixdfdi(2.0, 2))
46 if (test__fixdfdi(2.01, 2))
48 if (test__fixdfdi(-0.5, 0))
50 if (test__fixdfdi(-0.99, 0))
52 if (test__fixdfdi(-1.0, -1))
54 if (test__fixdfdi(-1.5, -1))
56 if (test__fixdfdi(-1.99, -1))
58 if (test__fixdfdi(-2.0, -2))
60 if (test__fixdfdi(-2.01, -2))
63 if (test__fixdfdi(0x1.FFFFFEp
+62, 0x7FFFFF8000000000LL
))
65 if (test__fixdfdi(0x1.FFFFFCp
+62, 0x7FFFFF0000000000LL
))
68 if (test__fixdfdi(-0x1.FFFFFEp
+62, 0x8000008000000000LL
))
70 if (test__fixdfdi(-0x1.FFFFFCp
+62, 0x8000010000000000LL
))
73 if (test__fixdfdi(0x1.FFFFFFFFFFFFFp
+62, 0x7FFFFFFFFFFFFC00LL
))
75 if (test__fixdfdi(0x1.FFFFFFFFFFFFEp
+62, 0x7FFFFFFFFFFFF800LL
))
78 if (test__fixdfdi(-0x1.FFFFFFFFFFFFFp
+62, 0x8000000000000400LL
))
80 if (test__fixdfdi(-0x1.FFFFFFFFFFFFEp
+62, 0x8000000000000800LL
))