1 // RUN: %clang_builtins %s %librt -o %t && %run %t
2 // REQUIRES: librt_has_fixsfdi
3 //===-- fixsfdi_test.c - Test __fixsfdi -----------------------------------===//
5 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
6 // See https://llvm.org/LICENSE.txt for license information.
7 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
9 //===----------------------------------------------------------------------===//
11 // This file tests __fixsfdi for the compiler_rt library.
13 //===----------------------------------------------------------------------===//
18 // Returns: convert a to a signed long long, rounding toward zero.
20 // Assumption: float is a IEEE 32 bit floating point type
21 // su_int is a 32 bit integral type
22 // value in float is representable in di_int (no range checking performed)
24 // seee eeee emmm mmmm mmmm mmmm mmmm mmmm
26 COMPILER_RT_ABI di_int
__fixsfdi(float a
);
28 int test__fixsfdi(float a
, di_int expected
)
30 di_int x
= __fixsfdi(a
);
32 printf("error in __fixsfdi(%A) = %llX, expected %llX\n", a
, x
, expected
);
36 char assumption_1
[sizeof(di_int
) == 2*sizeof(si_int
)] = {0};
37 char assumption_2
[sizeof(su_int
)*CHAR_BIT
== 32] = {0};
38 char assumption_3
[sizeof(float)*CHAR_BIT
== 32] = {0};
42 if (test__fixsfdi(0.0F
, 0))
45 if (test__fixsfdi(0.5F
, 0))
47 if (test__fixsfdi(0.99F
, 0))
49 if (test__fixsfdi(1.0F
, 1))
51 if (test__fixsfdi(1.5F
, 1))
53 if (test__fixsfdi(1.99F
, 1))
55 if (test__fixsfdi(2.0F
, 2))
57 if (test__fixsfdi(2.01F
, 2))
59 if (test__fixsfdi(-0.5F
, 0))
61 if (test__fixsfdi(-0.99F
, 0))
63 if (test__fixsfdi(-1.0F
, -1))
65 if (test__fixsfdi(-1.5F
, -1))
67 if (test__fixsfdi(-1.99F
, -1))
69 if (test__fixsfdi(-2.0F
, -2))
71 if (test__fixsfdi(-2.01F
, -2))
74 if (test__fixsfdi(0x1.FFFFFEp
+62F
, 0x7FFFFF8000000000LL
))
76 if (test__fixsfdi(0x1.FFFFFCp
+62F
, 0x7FFFFF0000000000LL
))
79 if (test__fixsfdi(-0x1.FFFFFEp
+62F
, 0x8000008000000000LL
))
81 if (test__fixsfdi(-0x1.FFFFFCp
+62F
, 0x8000010000000000LL
))