xref: /openbsd-src/gnu/llvm/clang/lib/Headers/openmp_wrappers/cmath (revision a9ac8606c53d55cee9c3a39778b249c51df111ef)
1ec727ea7Spatrick/*===-- __clang_openmp_device_functions.h - OpenMP math declares ------ c++ -===
2e5dd7070Spatrick *
3e5dd7070Spatrick * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4e5dd7070Spatrick * See https://llvm.org/LICENSE.txt for license information.
5e5dd7070Spatrick * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6e5dd7070Spatrick *
7e5dd7070Spatrick *===-----------------------------------------------------------------------===
8e5dd7070Spatrick */
9e5dd7070Spatrick
10ec727ea7Spatrick#ifndef __CLANG_OPENMP_CMATH_H__
11ec727ea7Spatrick#define __CLANG_OPENMP_CMATH_H__
12e5dd7070Spatrick
13ec727ea7Spatrick#ifndef _OPENMP
14ec727ea7Spatrick#error "This file is for OpenMP compilation only."
15ec727ea7Spatrick#endif
16ec727ea7Spatrick
17e5dd7070Spatrick#include_next <cmath>
18ec727ea7Spatrick
19ec727ea7Spatrick// Make sure we include our math.h overlay, it probably happend already but we
20ec727ea7Spatrick// need to be sure.
21ec727ea7Spatrick#include <math.h>
22ec727ea7Spatrick
23ec727ea7Spatrick// We (might) need cstdlib because __clang_cuda_cmath.h below declares `abs`
24ec727ea7Spatrick// which might live in cstdlib.
25ec727ea7Spatrick#include <cstdlib>
26ec727ea7Spatrick
27*a9ac8606Spatrick// We need limits because __clang_cuda_cmath.h below uses `std::numeric_limit`.
28*a9ac8606Spatrick#include <limits>
29*a9ac8606Spatrick
30ec727ea7Spatrick#pragma omp begin declare variant match(                                       \
31*a9ac8606Spatrick    device = {arch(nvptx, nvptx64)}, implementation = {extension(match_any, allow_templates)})
32ec727ea7Spatrick
33ec727ea7Spatrick#define __CUDA__
34ec727ea7Spatrick#define __OPENMP_NVPTX__
35ec727ea7Spatrick#include <__clang_cuda_cmath.h>
36ec727ea7Spatrick#undef __OPENMP_NVPTX__
37ec727ea7Spatrick#undef __CUDA__
38ec727ea7Spatrick
39ec727ea7Spatrick// Overloads not provided by the CUDA wrappers but by the CUDA system headers.
40ec727ea7Spatrick// Since we do not include the latter we define them ourselves.
41ec727ea7Spatrick#define __DEVICE__ static constexpr __attribute__((always_inline, nothrow))
42ec727ea7Spatrick
43ec727ea7Spatrick__DEVICE__ float acosh(float __x) { return ::acoshf(__x); }
44ec727ea7Spatrick__DEVICE__ float asinh(float __x) { return ::asinhf(__x); }
45ec727ea7Spatrick__DEVICE__ float atanh(float __x) { return ::atanhf(__x); }
46ec727ea7Spatrick__DEVICE__ float cbrt(float __x) { return ::cbrtf(__x); }
47ec727ea7Spatrick__DEVICE__ float erf(float __x) { return ::erff(__x); }
48ec727ea7Spatrick__DEVICE__ float erfc(float __x) { return ::erfcf(__x); }
49ec727ea7Spatrick__DEVICE__ float exp2(float __x) { return ::exp2f(__x); }
50ec727ea7Spatrick__DEVICE__ float expm1(float __x) { return ::expm1f(__x); }
51ec727ea7Spatrick__DEVICE__ float fdim(float __x, float __y) { return ::fdimf(__x, __y); }
52ec727ea7Spatrick__DEVICE__ float hypot(float __x, float __y) { return ::hypotf(__x, __y); }
53ec727ea7Spatrick__DEVICE__ int ilogb(float __x) { return ::ilogbf(__x); }
54ec727ea7Spatrick__DEVICE__ float lgamma(float __x) { return ::lgammaf(__x); }
55ec727ea7Spatrick__DEVICE__ long long int llrint(float __x) { return ::llrintf(__x); }
56ec727ea7Spatrick__DEVICE__ long long int llround(float __x) { return ::llroundf(__x); }
57ec727ea7Spatrick__DEVICE__ float log1p(float __x) { return ::log1pf(__x); }
58ec727ea7Spatrick__DEVICE__ float log2(float __x) { return ::log2f(__x); }
59ec727ea7Spatrick__DEVICE__ float logb(float __x) { return ::logbf(__x); }
60ec727ea7Spatrick__DEVICE__ long int lrint(float __x) { return ::lrintf(__x); }
61ec727ea7Spatrick__DEVICE__ long int lround(float __x) { return ::lroundf(__x); }
62ec727ea7Spatrick__DEVICE__ float nextafter(float __x, float __y) {
63ec727ea7Spatrick  return ::nextafterf(__x, __y);
64ec727ea7Spatrick}
65ec727ea7Spatrick__DEVICE__ float remainder(float __x, float __y) {
66ec727ea7Spatrick  return ::remainderf(__x, __y);
67ec727ea7Spatrick}
68ec727ea7Spatrick__DEVICE__ float scalbln(float __x, long int __y) {
69ec727ea7Spatrick  return ::scalblnf(__x, __y);
70ec727ea7Spatrick}
71ec727ea7Spatrick__DEVICE__ float scalbn(float __x, int __y) { return ::scalbnf(__x, __y); }
72ec727ea7Spatrick__DEVICE__ float tgamma(float __x) { return ::tgammaf(__x); }
73ec727ea7Spatrick
74ec727ea7Spatrick#undef __DEVICE__
75ec727ea7Spatrick
76ec727ea7Spatrick#pragma omp end declare variant
77ec727ea7Spatrick
78*a9ac8606Spatrick#ifdef __AMDGCN__
79*a9ac8606Spatrick#pragma omp begin declare variant match(device = {arch(amdgcn)})
80*a9ac8606Spatrick
81*a9ac8606Spatrick#pragma push_macro("__constant__")
82*a9ac8606Spatrick#define __constant__ __attribute__((constant))
83*a9ac8606Spatrick#define __OPENMP_AMDGCN__
84*a9ac8606Spatrick
85*a9ac8606Spatrick#include <__clang_hip_cmath.h>
86*a9ac8606Spatrick
87*a9ac8606Spatrick#pragma pop_macro("__constant__")
88*a9ac8606Spatrick#undef __OPENMP_AMDGCN__
89*a9ac8606Spatrick
90*a9ac8606Spatrick// Define overloads otherwise which are absent
91*a9ac8606Spatrick#define __DEVICE__ static constexpr __attribute__((always_inline, nothrow))
92*a9ac8606Spatrick
93*a9ac8606Spatrick__DEVICE__ float acos(float __x) { return ::acosf(__x); }
94*a9ac8606Spatrick__DEVICE__ float acosh(float __x) { return ::acoshf(__x); }
95*a9ac8606Spatrick__DEVICE__ float asin(float __x) { return ::asinf(__x); }
96*a9ac8606Spatrick__DEVICE__ float asinh(float __x) { return ::asinhf(__x); }
97*a9ac8606Spatrick__DEVICE__ float atan(float __x) { return ::atanf(__x); }
98*a9ac8606Spatrick__DEVICE__ float atan2(float __x, float __y) { return ::atan2f(__x, __y); }
99*a9ac8606Spatrick__DEVICE__ float atanh(float __x) { return ::atanhf(__x); }
100*a9ac8606Spatrick__DEVICE__ float cbrt(float __x) { return ::cbrtf(__x); }
101*a9ac8606Spatrick__DEVICE__ float cosh(float __x) { return ::coshf(__x); }
102*a9ac8606Spatrick__DEVICE__ float erf(float __x) { return ::erff(__x); }
103*a9ac8606Spatrick__DEVICE__ float erfc(float __x) { return ::erfcf(__x); }
104*a9ac8606Spatrick__DEVICE__ float exp2(float __x) { return ::exp2f(__x); }
105*a9ac8606Spatrick__DEVICE__ float expm1(float __x) { return ::expm1f(__x); }
106*a9ac8606Spatrick__DEVICE__ float fdim(float __x, float __y) { return ::fdimf(__x, __y); }
107*a9ac8606Spatrick__DEVICE__ float hypot(float __x, float __y) { return ::hypotf(__x, __y); }
108*a9ac8606Spatrick__DEVICE__ int ilogb(float __x) { return ::ilogbf(__x); }
109*a9ac8606Spatrick__DEVICE__ float ldexp(float __arg, int __exp) {
110*a9ac8606Spatrick  return ::ldexpf(__arg, __exp);
111*a9ac8606Spatrick}
112*a9ac8606Spatrick__DEVICE__ float lgamma(float __x) { return ::lgammaf(__x); }
113*a9ac8606Spatrick__DEVICE__ float log1p(float __x) { return ::log1pf(__x); }
114*a9ac8606Spatrick__DEVICE__ float logb(float __x) { return ::logbf(__x); }
115*a9ac8606Spatrick__DEVICE__ float nextafter(float __x, float __y) {
116*a9ac8606Spatrick  return ::nextafterf(__x, __y);
117*a9ac8606Spatrick}
118*a9ac8606Spatrick__DEVICE__ float remainder(float __x, float __y) {
119*a9ac8606Spatrick  return ::remainderf(__x, __y);
120*a9ac8606Spatrick}
121*a9ac8606Spatrick__DEVICE__ float scalbn(float __x, int __y) { return ::scalbnf(__x, __y); }
122*a9ac8606Spatrick__DEVICE__ float sinh(float __x) { return ::sinhf(__x); }
123*a9ac8606Spatrick__DEVICE__ float tan(float __x) { return ::tanf(__x); }
124*a9ac8606Spatrick__DEVICE__ float tanh(float __x) { return ::tanhf(__x); }
125*a9ac8606Spatrick__DEVICE__ float tgamma(float __x) { return ::tgammaf(__x); }
126*a9ac8606Spatrick
127*a9ac8606Spatrick#undef __DEVICE__
128*a9ac8606Spatrick
129*a9ac8606Spatrick#pragma omp end declare variant
130*a9ac8606Spatrick#endif // __AMDGCN__
131*a9ac8606Spatrick
132e5dd7070Spatrick#endif
133