exchanged race condition prevention from waiting random amount of time to omp critical
This commit is contained in:
parent
142a72335e
commit
4da866b29b
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue