From 515f65ba843a66d9d9baeffd58928d55c9bf0686 Mon Sep 17 00:00:00 2001 From: Luke Drummond Date: Tue, 30 May 2023 21:45:18 +0100 Subject: [PATCH] Use __hip_atomic_fetch_sub Where available, `__hip_atomic_fetch_sub` can be used to implement the `atomicSub` family. Introduced in llvm e3fbede7f3f --- include/hip/amd_detail/amd_hip_atomic.h | 44 +++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/include/hip/amd_detail/amd_hip_atomic.h b/include/hip/amd_detail/amd_hip_atomic.h index 869f495c..c1e27d2d 100644 --- a/include/hip/amd_detail/amd_hip_atomic.h +++ b/include/hip/amd_detail/amd_hip_atomic.h @@ -230,49 +230,81 @@ double atomicAdd_system(double* address, double val) { __device__ inline int atomicSub(int* address, int val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#endif } __device__ inline int atomicSub_system(int* address, int val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__ inline unsigned int atomicSub(unsigned int* address, unsigned int val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#endif } __device__ inline unsigned int atomicSub_system(unsigned int* address, unsigned int val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__ inline unsigned long atomicSub(unsigned long* address, unsigned long val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#endif } __device__ inline unsigned long atomicSub_system(unsigned long* address, unsigned long val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__ inline unsigned long long atomicSub(unsigned long long* address, unsigned long long val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); +#endif } __device__ inline unsigned long long atomicSub_system(unsigned long long* address, unsigned long long val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__ @@ -280,15 +312,23 @@ inline float atomicSub(float* address, float val) { #if defined(__AMDGCN_UNSAFE_FP_ATOMICS__) return unsafeAtomicAdd(address, -val); +#else +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); #else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_AGENT); #endif +#endif } __device__ inline float atomicSub_system(float* address, float val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__ @@ -304,7 +344,11 @@ double atomicSub(double* address, double val) { __device__ inline double atomicSub_system(double* address, double val) { +#if __has_builtin(__hip_atomic_fetch_sub) + return __hip_atomic_fetch_sub(address, val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#else return __hip_atomic_fetch_add(address, -val, __ATOMIC_RELAXED, __HIP_MEMORY_SCOPE_SYSTEM); +#endif } __device__