Skip to content

Commit

Permalink
Define explicitly atomic add of float2 numbers and double2 numbers
Browse files Browse the repository at this point in the history
  • Loading branch information
PabloPalaciosAlonso committed Dec 1, 2023
1 parent 64e82c5 commit 3b838c2
Showing 1 changed file with 8 additions and 5 deletions.
13 changes: 8 additions & 5 deletions src/utils/atomics.cuh
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,6 @@ namespace uammd{
template<class T>
inline __device__ T atomicAdd(T* address, T val){ return ::atomicAdd(address, val);}


#ifndef SINGLE_PRECISION
#if !defined(__CUDA_ARCH__) || __CUDA_ARCH__ < 600
inline __device__ double atomicAdd(double* address, double val){
unsigned long long int* address_as_ull =
Expand All @@ -22,7 +20,6 @@ namespace uammd{
} while (assumed != old);
return __longlong_as_double(old);
}
#endif
#endif

inline __device__ real4 atomicAdd(real4* address, real4 val){
Expand All @@ -42,13 +39,19 @@ namespace uammd{
return newval;
}

inline __device__ real2 atomicAdd(real2* address, real2 val){
real2 newval;
inline __device__ float2 atomicAdd(float2* address, float2 val){
float2 newval;
if(val.x) newval.x = atomicAdd(&(*address).x, val.x);
if(val.y) newval.y = atomicAdd(&(*address).y, val.y);
return newval;
}

inline __device__ double2 atomicAdd(double2* address, double2 val){
double2 newval;
if(val.x) newval.x = atomicAdd(&(*address).x, val.x);
if(val.y) newval.y = atomicAdd(&(*address).y, val.y);
return newval;
}

template<class T, class T2>
inline __device__ T2 atomicAdd(T &ref, T2 val){
Expand Down

0 comments on commit 3b838c2

Please sign in to comment.