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