diff --git a/clang/lib/Headers/__clang_cuda_cmath.h b/clang/lib/Headers/__clang_cuda_cmath.h --- a/clang/lib/Headers/__clang_cuda_cmath.h +++ b/clang/lib/Headers/__clang_cuda_cmath.h @@ -57,15 +57,24 @@ __DEVICE__ const double abs(const double __x) { return ::fabs((double)__x); } #endif __DEVICE__ float acos(float __x) { return ::acosf(__x); } +__DEVICE__ float acosh(float __x) { return ::acoshf(__x); } __DEVICE__ float asin(float __x) { return ::asinf(__x); } +__DEVICE__ float asinh(float __x) { return ::asinhf(__x); } __DEVICE__ float atan(float __x) { return ::atanf(__x); } +__DEVICE__ float atanh(float __x) { return ::atanhf(__x); } __DEVICE__ float atan2(float __x, float __y) { return ::atan2f(__x, __y); } +__DEVICE__ float cbrt(float __x) { return ::cbrtf(__x); } __DEVICE__ float ceil(float __x) { return ::ceilf(__x); } __DEVICE__ float cos(float __x) { return ::cosf(__x); } __DEVICE__ float cosh(float __x) { return ::coshf(__x); } +__DEVICE__ float erf(float __x) { return ::erff(__x); } +__DEVICE__ float erfc(float __x) { return ::erfcf(__x); } __DEVICE__ float exp(float __x) { return ::expf(__x); } +__DEVICE__ float exp2(float __x) { return ::exp2f(__x); } +__DEVICE__ float expm1(float __x) { return ::expm1f(__x); } __DEVICE__ float fabs(float __x) __NOEXCEPT { return ::fabsf(__x); } __DEVICE__ float floor(float __x) { return ::floorf(__x); } +__DEVICE__ float fdim(float __x, float __y) { return ::fdimf(__x, __y); } __DEVICE__ float fmod(float __x, float __y) { return ::fmodf(__x, __y); } // TODO: remove when variant is supported #ifndef _OPENMP @@ -82,6 +91,8 @@ return ::frexpf(__arg, __exp); } +__DEVICE__ float hypot(float __x, float __y) { return ::hypotf(__x, __y); } +__DEVICE__ int ilogb(float __x) { return ::ilogbf(__x); } // For inscrutable reasons, the CUDA headers define these functions for us on // Windows. #ifndef _MSC_VER @@ -137,9 +148,18 @@ __DEVICE__ float ldexp(float __arg, int __exp) { return ::ldexpf(__arg, __exp); } +__DEVICE__ float lgamma(float __x) { return ::lgammaf(__x); } +__DEVICE__ long long int llrint(float __x) { return ::llrintf(__x); } +__DEVICE__ long long int llround(float __x) { return ::llroundf(__x); } __DEVICE__ float log(float __x) { return ::logf(__x); } __DEVICE__ float log10(float __x) { return ::log10f(__x); } +__DEVICE__ float log1p(float __x) { return ::log1pf(__x); } +__DEVICE__ float log2(float __x) { return ::log2f(__x); } +__DEVICE__ float logb(float __x) { return ::logbf(__x); } +__DEVICE__ long int lrint(float __x) { return ::lrintf(__x); } +__DEVICE__ long int lround(float __x) { return ::lroundf(__x); } __DEVICE__ float modf(float __x, float *__iptr) { return ::modff(__x, __iptr); } +__DEVICE__ float nextafter(float __x, float __y) { return ::nextafterf(__x, __y); } __DEVICE__ float pow(float __base, float __exp) { return ::powf(__base, __exp); } @@ -149,6 +169,9 @@ __DEVICE__ double pow(double __base, int __iexp) { return ::powi(__base, __iexp); } +__DEVICE__ float remainder(float __x, float __y) { return ::remainderf(__x, __y); } +__DEVICE__ float scalbln(float __x, long int __y) { return ::scalblnf(__x, __y); } +__DEVICE__ float scalbn(float __x, int __y) { return ::scalbnf(__x, __y); } __DEVICE__ bool signbit(float __x) { return ::__signbitf(__x); } __DEVICE__ bool signbit(double __x) { return ::__signbitd(__x); } __DEVICE__ float sin(float __x) { return ::sinf(__x); } @@ -156,6 +179,7 @@ __DEVICE__ float sqrt(float __x) { return ::sqrtf(__x); } __DEVICE__ float tan(float __x) { return ::tanf(__x); } __DEVICE__ float tanh(float __x) { return ::tanhf(__x); } +__DEVICE__ float tgamma(float __x) { return ::tgammaf(__x); } // Notably missing above is nexttoward. We omit it because // libdevice doesn't provide an implementation, and we don't want to be in the