xref: /freebsd/contrib/llvm-project/libc/src/__support/math/frexpf128.h (revision bb722a7d0f1642bff6487f943ad0427799a6e5bf)
1 //===-- Implementation header for expf --------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_LIBC_SRC___SUPPORT_MATH_FREXPF128_H
10 #define LLVM_LIBC_SRC___SUPPORT_MATH_FREXPF128_H
11 
12 #include "include/llvm-libc-types/float128.h"
13 
14 #ifdef LIBC_TYPES_HAS_FLOAT128
15 
16 #include "src/__support/FPUtil/ManipulationFunctions.h"
17 #include "src/__support/common.h"
18 #include "src/__support/macros/config.h"
19 
20 namespace LIBC_NAMESPACE_DECL {
21 
22 namespace math {
23 
frexpf128(float128 x,int * exp)24 static constexpr float128 frexpf128(float128 x, int *exp) {
25   return fputil::frexp(x, *exp);
26 }
27 
28 } // namespace math
29 
30 } // namespace LIBC_NAMESPACE_DECL
31 
32 #endif // LIBC_TYPES_HAS_FLOAT128
33 
34 #endif // LLVM_LIBC_SRC___SUPPORT_MATH_FREXPF128_H
35