exchanged race condition prevention from waiting random amount of time to omp critical

This commit is contained in:
Martin Diehl 2014-05-14 13:57:25 +00:00
parent 142a72335e
commit 4da866b29b
1 changed files with 4 additions and 19 deletions

View File

@ -25,7 +25,6 @@ module CPFEM
logical, public, protected :: & logical, public, protected :: &
CPFEM_init_done = .false., & !< remember whether init has been done already CPFEM_init_done = .false., & !< remember whether init has been done already
CPFEM_init_inProgress = .false., & !< remember whether first ip is currently performing init
CPFEM_calc_done = .false. !< remember whether first ip has already calced the results CPFEM_calc_done = .false. !< remember whether first ip has already calced the results
integer(pInt), parameter, public :: & integer(pInt), parameter, public :: &
@ -77,19 +76,9 @@ subroutine CPFEM_initAll(temperature,el,ip)
integer(pInt), intent(in) :: el, & ! FE el number integer(pInt), intent(in) :: el, & ! FE el number
ip ! FE integration point number ip ! FE integration point number
real(pReal), intent(in) :: temperature ! temperature real(pReal), intent(in) :: temperature ! temperature
real(pReal) rnd
integer(pInt) i,n
! initialization step (three dimensional stress state check missing?)
!$OMP CRITICAL (init)
if (.not. CPFEM_init_done) then if (.not. CPFEM_init_done) then
call random_number(rnd)
do i=1,int(256.0*rnd)
n = n+1_pInt ! wasting random amount of time...
enddo ! ...to break potential race in multithreading
n = n+1_pInt
if (.not. CPFEM_init_inProgress) then ! yes my thread won!
CPFEM_init_inProgress = .true.
#ifdef Spectral #ifdef Spectral
call DAMASK_interface_init() ! Spectral solver is interfacing to commandline call DAMASK_interface_init() ! Spectral solver is interfacing to commandline
#endif #endif
@ -110,12 +99,8 @@ subroutine CPFEM_initAll(temperature,el,ip)
call DAMASK_interface_init() ! Spectral solver init is already done call DAMASK_interface_init() ! Spectral solver init is already done
#endif #endif
CPFEM_init_done = .true. CPFEM_init_done = .true.
CPFEM_init_inProgress = .false.
else ! loser, loser...
do while (CPFEM_init_inProgress)
enddo
endif
endif endif
!$OMP END CRITICAL (init)
end subroutine CPFEM_initAll end subroutine CPFEM_initAll