1 // RUN: %clang_builtins %s %librt -o %t && %run %t
2 // REQUIRES: librt_has_fixsfdi
7 // Returns: convert a to a signed long long, rounding toward zero.
9 // Assumption: float is a IEEE 32 bit floating point type
10 // su_int is a 32 bit integral type
11 // value in float is representable in di_int (no range checking performed)
13 // seee eeee emmm mmmm mmmm mmmm mmmm mmmm
15 COMPILER_RT_ABI di_int
__fixsfdi(float a
);
17 int test__fixsfdi(float a
, di_int expected
)
19 di_int x
= __fixsfdi(a
);
21 printf("error in __fixsfdi(%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(float)*CHAR_BIT
== 32] = {0};
31 if (test__fixsfdi(0.0F
, 0))
34 if (test__fixsfdi(0.5F
, 0))
36 if (test__fixsfdi(0.99F
, 0))
38 if (test__fixsfdi(1.0F
, 1))
40 if (test__fixsfdi(1.5F
, 1))
42 if (test__fixsfdi(1.99F
, 1))
44 if (test__fixsfdi(2.0F
, 2))
46 if (test__fixsfdi(2.01F
, 2))
48 if (test__fixsfdi(-0.5F
, 0))
50 if (test__fixsfdi(-0.99F
, 0))
52 if (test__fixsfdi(-1.0F
, -1))
54 if (test__fixsfdi(-1.5F
, -1))
56 if (test__fixsfdi(-1.99F
, -1))
58 if (test__fixsfdi(-2.0F
, -2))
60 if (test__fixsfdi(-2.01F
, -2))
63 if (test__fixsfdi(0x1.FFFFFEp
+62F
, 0x7FFFFF8000000000LL
))
65 if (test__fixsfdi(0x1.FFFFFCp
+62F
, 0x7FFFFF0000000000LL
))
68 if (test__fixsfdi(-0x1.FFFFFEp
+62F
, 0x8000008000000000LL
))
70 if (test__fixsfdi(-0x1.FFFFFCp
+62F
, 0x8000010000000000LL
))
73 if (test__fixsfdi(-0x8000000000000000.0p
+0F
, 0x8000000000000000LL
))