diff options
Diffstat (limited to 'contrib/llvm-project/compiler-rt/lib/builtins/floatuntisf.c')
-rw-r--r-- | contrib/llvm-project/compiler-rt/lib/builtins/floatuntisf.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/contrib/llvm-project/compiler-rt/lib/builtins/floatuntisf.c b/contrib/llvm-project/compiler-rt/lib/builtins/floatuntisf.c new file mode 100644 index 000000000000..997c1569acd6 --- /dev/null +++ b/contrib/llvm-project/compiler-rt/lib/builtins/floatuntisf.c @@ -0,0 +1,30 @@ +//===-- floatuntisf.c - Implement __floatuntisf ---------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// +// +// This file implements __floatuntisf for the compiler_rt library. +// +//===----------------------------------------------------------------------===// + +#include "int_lib.h" + +#ifdef CRT_HAS_128BIT + +#define SRC_U128 +#define DST_SINGLE +#include "int_to_fp_impl.inc" + +// Returns: convert a to a float, rounding toward even. + +// Assumption: float is a IEEE 32 bit floating point type +// tu_int is a 128 bit integral type + +// seee eeee emmm mmmm mmmm mmmm mmmm mmmm + +COMPILER_RT_ABI float __floatuntisf(tu_int a) { return __floatXiYf__(a); } + +#endif // CRT_HAS_128BIT |