jdoerfert added a comment. OpenMP side looks reasonable.
================ Comment at: clang/lib/Headers/__clang_hip_cmath.h:96 +__DEVICE__ __CONSTEXPR__ bool isnan(float __x) { return ::__isnanf(__x); } +__DEVICE__ __CONSTEXPR__ bool isnan(double __x) { return ::__isnan(__x); } ---------------- ^ This is how OpenMP resolves the overload issue wrt. different return types. ================ Comment at: clang/lib/Headers/__clang_hip_math.h:35 +#ifdef __OPENMP_AMDGCN__ +#define __RETURN_TYPE int +#else ---------------- pdhaliwal wrote: > jdoerfert wrote: > > JonChesterfield wrote: > > > I'd expect openmp to match the cplusplus/c distinction here, as openmp > > > works on C source > > ^ Agreed. Though, we use a different trick because it's unfortunately not > > as straight forward always and can be decided based on the C vs C++. > This is somewhat tricky. Since declaration of `__finite/__isnan /__isinff` is > with int return type in standard library (and the corresponding methods in > C++ seems to be isfinite, isnan and isinf with bool return type), the > compiler fails to resolve these functions when using bool. I don't know how > HIP is working. > > __RETURN_TYPE macro is only being used with the following methods: > 1. __finite > 2. __isnan > 3. __isinf > 4. __signbit > > and with the corresponding float versions. I marked the code above that actually overloads these functions in OpenMP (or better the versions w/o underscores) such that the system can have either version and it should work fine. ================ Comment at: clang/test/Headers/Inputs/include/cstdlib:29 float fabs(float __x) { return __builtin_fabs(__x); } +#endif ---------------- That seems to be fundamentally broken then, but let's see, maybe it will somehow work anyway. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D104904/new/ https://reviews.llvm.org/D104904 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits