1 //===-- fixunsdfdi_test.c - Test __fixunsdfdi -----------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file tests __fixunsdfdi for the compiler_rt library.
12 //===----------------------------------------------------------------------===//
17 // Returns: convert a to a unsigned long long, rounding toward zero.
18 // Negative values all become zero.
20 // Assumption: double is a IEEE 64 bit floating point type
21 // du_int is a 64 bit integral type
22 // value in double is representable in du_int or is negative
23 // (no range checking performed)
25 // seee eeee eeee mmmm mmmm mmmm mmmm mmmm | mmmm mmmm mmmm mmmm mmmm mmmm mmmm mmmm
27 du_int
__fixunsdfdi(double a
);
29 int test__fixunsdfdi(double a
, du_int expected
)
31 du_int x
= __fixunsdfdi(a
);
33 printf("error in __fixunsdfdi(%A) = %llX, expected %llX\n", a
, x
, expected
);
37 char assumption_1
[sizeof(du_int
) == 2*sizeof(su_int
)] = {0};
38 char assumption_2
[sizeof(su_int
)*CHAR_BIT
== 32] = {0};
39 char assumption_3
[sizeof(double)*CHAR_BIT
== 64] = {0};
43 if (test__fixunsdfdi(0.0, 0))
46 if (test__fixunsdfdi(0.5, 0))
48 if (test__fixunsdfdi(0.99, 0))
50 if (test__fixunsdfdi(1.0, 1))
52 if (test__fixunsdfdi(1.5, 1))
54 if (test__fixunsdfdi(1.99, 1))
56 if (test__fixunsdfdi(2.0, 2))
58 if (test__fixunsdfdi(2.01, 2))
60 if (test__fixunsdfdi(-0.5, 0))
62 if (test__fixunsdfdi(-0.99, 0))
65 if (test__fixunsdfdi(-1.0, 0)) // libgcc ignores "returns 0 for negative input" spec
67 if (test__fixunsdfdi(-1.5, 0))
69 if (test__fixunsdfdi(-1.99, 0))
71 if (test__fixunsdfdi(-2.0, 0))
73 if (test__fixunsdfdi(-2.01, 0))
77 if (test__fixunsdfdi(0x1.FFFFFEp
+62, 0x7FFFFF8000000000LL
))
79 if (test__fixunsdfdi(0x1.FFFFFCp
+62, 0x7FFFFF0000000000LL
))
83 if (test__fixunsdfdi(-0x1.FFFFFEp
+62, 0))
85 if (test__fixunsdfdi(-0x1.FFFFFCp
+62, 0))
89 if (test__fixunsdfdi(0x1.FFFFFFFFFFFFFp
+63, 0xFFFFFFFFFFFFF800LL
))
91 if (test__fixunsdfdi(0x1.0000000000000p
+63, 0x8000000000000000LL
))
93 if (test__fixunsdfdi(0x1.FFFFFFFFFFFFFp
+62, 0x7FFFFFFFFFFFFC00LL
))
95 if (test__fixunsdfdi(0x1.FFFFFFFFFFFFEp
+62, 0x7FFFFFFFFFFFF800LL
))
99 if (test__fixunsdfdi(-0x1.FFFFFFFFFFFFFp
+62, 0))
101 if (test__fixunsdfdi(-0x1.FFFFFFFFFFFFEp
+62, 0))