JonChesterfield added inline comments.

================
Comment at: clang/lib/Headers/__clang_hip_cmath.h:29
+#ifdef __OPENMP_AMDGCN__
+#define __DEVICE__ static constexpr __attribute__((always_inline, nothrow))
+#define __constant__ __attribute__((constant))
----------------
scchan wrote:
> `__DEVICE__` should not imply constexpr.  It should be added to each function 
> separately.
iirc rocm does that with a macro called __DEVICE_NOCE__, perhaps we could go 
with __DEVICE_CONSTEXPR__. There's some interaction with overloading rules and 
different glibc versions, so it would be nice to tag exactly the same functions 
as constexpr on nvptx and amdgcn


================
Comment at: clang/lib/Headers/__clang_hip_math.h:29
+#else
 #define __DEVICE__ static __device__ inline __attribute__((always_inline))
+#endif
----------------
wonder if HIP would benefit from nothrow here


================
Comment at: clang/lib/Headers/__clang_hip_math.h:35
+#ifdef __OPENMP_AMDGCN__
+#define __RETURN_TYPE int
+#else
----------------
I'd expect openmp to match the cplusplus/c distinction here, as openmp works on 
C source


================
Comment at: 
clang/lib/Headers/openmp_wrappers/__clang_openmp_device_functions.h:93
+
+#define __device__ __attribute__((device))
+
----------------
i think this should be `#define __device__`


================
Comment at: clang/test/Headers/Inputs/include/cstdlib:15
 
+#ifndef __AMDGCN__
 namespace std
----------------
I think I'd expect builtin_labs et al to work on amdgcn, are we missing 
lowering for them?


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

Reply via email to