1 //===-- fixdfdi_test.c - Test __fixdfdi -----------------------------------===//
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 __fixdfdi for the compiler_rt library.
12 //===----------------------------------------------------------------------===//
17 // Returns: convert a to a signed long long, rounding toward zero.
19 // Assumption: double is a IEEE 64 bit floating point type
20 // su_int is a 32 bit integral type
21 // value in double is representable in di_int (no range checking performed)
23 // seee eeee eeee mmmm mmmm mmmm mmmm mmmm | mmmm mmmm mmmm mmmm mmmm mmmm mmmm mmmm
25 di_int
__fixdfdi(double a
);
27 int test__fixdfdi(double a
, di_int expected
)
29 di_int x
= __fixdfdi(a
);
31 printf("error in __fixdfdi(%A) = %llX, expected %llX\n", a
, x
, expected
);
35 char assumption_1
[sizeof(di_int
) == 2*sizeof(si_int
)] = {0};
36 char assumption_2
[sizeof(su_int
)*CHAR_BIT
== 32] = {0};
37 char assumption_3
[sizeof(double)*CHAR_BIT
== 64] = {0};
41 if (test__fixdfdi(0.0, 0))
44 if (test__fixdfdi(0.5, 0))
46 if (test__fixdfdi(0.99, 0))
48 if (test__fixdfdi(1.0, 1))
50 if (test__fixdfdi(1.5, 1))
52 if (test__fixdfdi(1.99, 1))
54 if (test__fixdfdi(2.0, 2))
56 if (test__fixdfdi(2.01, 2))
58 if (test__fixdfdi(-0.5, 0))
60 if (test__fixdfdi(-0.99, 0))
62 if (test__fixdfdi(-1.0, -1))
64 if (test__fixdfdi(-1.5, -1))
66 if (test__fixdfdi(-1.99, -1))
68 if (test__fixdfdi(-2.0, -2))
70 if (test__fixdfdi(-2.01, -2))
73 if (test__fixdfdi(0x1.FFFFFEp
+62, 0x7FFFFF8000000000LL
))
75 if (test__fixdfdi(0x1.FFFFFCp
+62, 0x7FFFFF0000000000LL
))
78 if (test__fixdfdi(-0x1.FFFFFEp
+62, 0x8000008000000000LL
))
80 if (test__fixdfdi(-0x1.FFFFFCp
+62, 0x8000010000000000LL
))
83 if (test__fixdfdi(0x1.FFFFFFFFFFFFFp
+62, 0x7FFFFFFFFFFFFC00LL
))
85 if (test__fixdfdi(0x1.FFFFFFFFFFFFEp
+62, 0x7FFFFFFFFFFFF800LL
))
88 if (test__fixdfdi(-0x1.FFFFFFFFFFFFFp
+62, 0x8000000000000400LL
))
90 if (test__fixdfdi(-0x1.FFFFFFFFFFFFEp
+62, 0x8000000000000800LL
))