From f74f6dadd3c1525184fb6ab0ffafd037a6c21b0f Mon Sep 17 00:00:00 2001 From: Paul Kent Date: Mon, 8 Feb 2021 14:02:32 -0500 Subject: [PATCH] Fix race conditions --- src/QMCHamiltonians/CudaCoulomb.cu | 18 ++++++++++++++++-- src/QMCHamiltonians/NLPP.cu | 1 + .../detail/CUDA_legacy/determinant_update.cu | 1 + 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/src/QMCHamiltonians/CudaCoulomb.cu b/src/QMCHamiltonians/CudaCoulomb.cu index f72bbc38df..0ccd307bd9 100644 --- a/src/QMCHamiltonians/CudaCoulomb.cu +++ b/src/QMCHamiltonians/CudaCoulomb.cu @@ -284,6 +284,7 @@ __global__ void coulomb_AA_PBC_kernel(TR** R, for (int i = 0; i < 3; i++) if ((3 * b + i) * BS + tid < 3 * N) r1[0][i * BS + tid] = myR[(3 * b + i) * BS + tid]; + __syncthreads(); int ptcl1 = b * BS + tid; if (ptcl1 < N) { @@ -308,12 +309,14 @@ __global__ void coulomb_AA_PBC_kernel(TR** R, } // Avoid double-counting on the diagonal blocks mysum *= 0.5; + __syncthreads(); // Now do off-diagonal blocks for (int b1 = 0; b1 < NB; b1++) { for (int i = 0; i < 3; i++) if ((3 * b1 + i) * BS + tid < 3 * N) r1[0][i * BS + tid] = myR[(3 * b1 + i) * BS + tid]; + __syncthreads(); int ptcl1 = b1 * BS + tid; if (ptcl1 < N) { @@ -322,6 +325,7 @@ __global__ void coulomb_AA_PBC_kernel(TR** R, for (int i = 0; i < 3; i++) if ((3 * b2 + i) * BS + tid < 3 * N) r2[0][i * BS + tid] = myR[(3 * b2 + i) * BS + tid]; + __syncthreads(); int end = ((b2 + 1) * BS < N) ? BS : (N - b2 * BS); for (int j = 0; j < end; j++) { @@ -368,6 +372,7 @@ __global__ void coulomb_AA_kernel(T** R, int N, T* sum) for (int i = 0; i < 3; i++) if ((3 * b + i) * BS + tid < 3 * N) r1[0][i * BS + tid] = myR[(3 * b + i) * BS + tid]; + __syncthreads(); int ptcl1 = b * BS + tid; if (ptcl1 < N) { @@ -388,12 +393,14 @@ __global__ void coulomb_AA_kernel(T** R, int N, T* sum) } // Avoid double-counting on the diagonal blocks mysum *= 0.5; + __syncthreads(); // Now do off-diagonal blocks for (int b1 = 0; b1 < NB; b1++) { for (int i = 0; i < 3; i++) if ((3 * b1 + i) * BS + tid < 3 * N) r1[0][i * BS + tid] = myR[(3 * b1 + i) * BS + tid]; + __syncthreads(); int ptcl1 = b1 * BS + tid; if (ptcl1 < N) { @@ -402,6 +409,7 @@ __global__ void coulomb_AA_kernel(T** R, int N, T* sum) for (int i = 0; i < 3; i++) if ((3 * b2 + i) * BS + tid < 3 * N) r2[0][i * BS + tid] = myR[(3 * b2 + i) * BS + tid]; + __syncthreads(); int end = ((b2 + 1) * BS < N) ? BS : (N - b2 * BS); for (int j = 0; j < end; j++) { @@ -544,6 +552,7 @@ __global__ void MPC_SR_kernel(T** R, int N, T* lattice, T* latticeInv, T* sum) } // Avoid double-counting on the diagonal blocks mysum *= 0.5; + __syncthreads(); // Now do off-diagonal blocks for (int b1 = 0; b1 < NB; b1++) { @@ -559,6 +568,7 @@ __global__ void MPC_SR_kernel(T** R, int N, T* lattice, T* latticeInv, T* sum) for (int i = 0; i < 3; i++) if ((3 * b2 + i) * BS + tid < 3 * N) r2[0][i * BS + tid] = myR[(3 * b2 + i) * BS + tid]; + __syncthreads(); int end = ((b2 + 1) * BS < N) ? BS : (N - b2 * BS); for (int j = 0; j < end; j++) { @@ -1074,6 +1084,7 @@ __global__ void eval_rhok_kernel(T** R, int numr, T* kpoints, int numk, T** rhok if ((i + 3 * rBlock) * BS + tid < 3 * numr) r[0][BS * i + tid] = myR[(i + 3 * rBlock) * BS + tid]; int end = ((rBlock + 1) * BS < numr) ? BS : (numr - rBlock * BS); + __syncthreads(); for (int j = 0; j < end; j++) { T phase = (k[tid][0] * r[j][0] + k[tid][1] * r[j][1] + k[tid][2] * r[j][2]); @@ -1122,6 +1133,7 @@ __global__ void eval_rhok_kernel(TR** R, int first, int last, T* kpoints, int nu for (int i = 0; i < 3; i++) if ((i + 3 * rBlock) * BS + tid < 3 * numr) r[0][BS * i + tid] = myR[3 * first + (i + 3 * rBlock) * BS + tid]; + __syncthreads(); int end = ((rBlock + 1) * BS < numr) ? BS : (numr - rBlock * BS); for (int j = 0; j < end; j++) { @@ -1234,18 +1246,19 @@ __global__ void vk_sum_kernel2(T** rhok1, T** rhok2, T* vk, int numk, T* sum) myrhok1 = rhok1[blockIdx.x]; myrhok2 = rhok2[blockIdx.x]; } - __syncthreads(); // Used to do coalesced global loads __shared__ T rhok_s1[2 * BS], rhok_s2[2 * BS]; int NB = numk / BS + ((numk % BS) ? 1 : 0); T mysum = 0.0f; for (int b = 0; b < NB; b++) { + __syncthreads(); if (2 * b * BS + tid < 2 * numk) { rhok_s1[tid] = myrhok1[2 * b * BS + tid]; rhok_s2[tid] = myrhok2[2 * b * BS + tid]; } + __syncthreads(); if ((2 * b + 1) * BS + tid < 2 * numk) { rhok_s1[BS + tid] = myrhok1[(2 * b + 1) * BS + tid]; @@ -1313,18 +1326,19 @@ __global__ void vk_sum_kernel2(T** rhok1, T* rhok2, T* vk, int numk, T* sum) __shared__ T* myrhok1; if (tid == 0) myrhok1 = rhok1[blockIdx.x]; - __syncthreads(); // Used to do coalesced global loads __shared__ T rhok_s1[2 * BS], rhok_s2[2 * BS]; int NB = numk / BS + ((numk % BS) ? 1 : 0); T mysum = 0.0f; for (int b = 0; b < NB; b++) { + __syncthreads(); if (2 * b * BS + tid < 2 * numk) { rhok_s1[tid] = myrhok1[2 * b * BS + tid]; rhok_s2[tid] = rhok2[2 * b * BS + tid]; } + __syncthreads(); if ((2 * b + 1) * BS + tid < 2 * numk) { rhok_s1[BS + tid] = myrhok1[(2 * b + 1) * BS + tid]; diff --git a/src/QMCHamiltonians/NLPP.cu b/src/QMCHamiltonians/NLPP.cu index ab5defc6ce..93b09459ab 100644 --- a/src/QMCHamiltonians/NLPP.cu +++ b/src/QMCHamiltonians/NLPP.cu @@ -312,6 +312,7 @@ __global__ void find_core_electrons_PBC_kernel(T** R, disp[tid][1] = r[tid][1] - i[ion][1]; disp[tid][2] = r[tid][2] - i[ion][2]; dist[tid] = min_dist(disp[tid][0], disp[tid][1], disp[tid][2], L, Linv); + __syncthreads(); for (int elec = 0; elec < elecEnd; elec++) { __syncthreads(); diff --git a/src/QMCWaveFunctions/detail/CUDA_legacy/determinant_update.cu b/src/QMCWaveFunctions/detail/CUDA_legacy/determinant_update.cu index 0e18a92001..7685a08e31 100644 --- a/src/QMCWaveFunctions/detail/CUDA_legacy/determinant_update.cu +++ b/src/QMCWaveFunctions/detail/CUDA_legacy/determinant_update.cu @@ -1412,6 +1412,7 @@ __global__ void calc_ratio_grad_lapl(T** Ainv_list, // ratio to make it w.r.t. new position if (tid < 4) ratio_prod[(tid + 1) * BS1] /= ratio_prod[0]; + __syncthreads(); if (tid < 5) ratio_grad_lapl[5 * blockIdx.x + tid] = ratio_prod[tid * BS1]; }