diff options
Diffstat (limited to 'contrib/llvm-project/compiler-rt/lib/builtins/floattisf.c')
-rw-r--r-- | contrib/llvm-project/compiler-rt/lib/builtins/floattisf.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/contrib/llvm-project/compiler-rt/lib/builtins/floattisf.c b/contrib/llvm-project/compiler-rt/lib/builtins/floattisf.c new file mode 100644 index 000000000000..77589902f544 --- /dev/null +++ b/contrib/llvm-project/compiler-rt/lib/builtins/floattisf.c @@ -0,0 +1,30 @@ +//===-- floattisf.c - Implement __floattisf -------------------------------===// +// +// 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 __floattisf for the compiler_rt library. +// +//===----------------------------------------------------------------------===// + +#include "int_lib.h" + +#ifdef CRT_HAS_128BIT + +#define SRC_I128 +#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 +// ti_int is a 128 bit integral type + +// seee eeee emmm mmmm mmmm mmmm mmmm mmmm + +COMPILER_RT_ABI float __floattisf(ti_int a) { return __floatXiYf__(a); } + +#endif // CRT_HAS_128BIT |