//===-- Implementation of rintf16 function --------------------------------===// // // 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 // //===----------------------------------------------------------------------===// #include "src/math/rintf16.h" #include "src/__support/FPUtil/NearestIntegerOperations.h" #include "src/__support/FPUtil/cast.h" #include "src/__support/common.h" #include "src/__support/macros/config.h" #include "src/__support/macros/properties/cpu_features.h" namespace LIBC_NAMESPACE_DECL { LLVM_LIBC_FUNCTION(float16, rintf16, (float16 x)) { #if defined(__LIBC_USE_BUILTIN_CEIL_FLOOR_RINT_TRUNC) && \ defined(LIBC_TARGET_CPU_HAS_FAST_FLOAT16_OPS) return fputil::cast(__builtin_rintf(x)); #else return fputil::round_using_current_rounding_mode(x); #endif } } // namespace LIBC_NAMESPACE_DECL