mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-03 18:16:12 +01:00
77 lines
1.6 KiB
Fortran
77 lines
1.6 KiB
Fortran
BEGIN_PROVIDER [ logical, GASPI_is_initialized ]
|
|
&BEGIN_PROVIDER [ logical, has_gaspi ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! This is true when GASPI_Init has been called
|
|
END_DOC
|
|
|
|
has_gaspi = .False.
|
|
IRP_IF GASPI
|
|
use GASPI
|
|
integer(gaspi_return_t) :: res
|
|
res = gaspi_proc_init(GASPI_BLOCK)
|
|
if (res /= GASPI_SUCCESS) then
|
|
print *, res
|
|
print *, 'GASPI failed to initialize'
|
|
stop -1
|
|
endif
|
|
has_gaspi = .True.
|
|
IRP_ENDIF
|
|
GASPI_is_initialized = .True.
|
|
END_PROVIDER
|
|
|
|
|
|
BEGIN_PROVIDER [ integer, GASPI_rank ]
|
|
&BEGIN_PROVIDER [ integer, GASPI_size ]
|
|
&BEGIN_PROVIDER [ logical, is_GASPI_master ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! Usual GASPI variables
|
|
END_DOC
|
|
|
|
PROVIDE GASPI_is_initialized
|
|
|
|
IRP_IF GASPI
|
|
use GASPI
|
|
integer(gaspi_return_t) :: res
|
|
integer(gaspi_rank_t) :: n
|
|
res = gaspi_proc_num(n)
|
|
GASPI_size = n
|
|
if (res /= GASPI_SUCCESS) then
|
|
print *, res
|
|
print *, 'Unable to get GASPI_size'
|
|
stop -1
|
|
endif
|
|
res = gaspi_proc_rank(n)
|
|
GASPI_rank = n
|
|
if (res /= GASPI_SUCCESS) then
|
|
print *, res
|
|
print *, 'Unable to get GASPI_rank'
|
|
stop -1
|
|
endif
|
|
is_GASPI_master = (GASPI_rank == 0)
|
|
IRP_ELSE
|
|
GASPI_rank = 0
|
|
GASPI_size = 1
|
|
is_GASPI_master = .True.
|
|
IRP_ENDIF
|
|
|
|
|
|
END_PROVIDER
|
|
|
|
subroutine gaspi_finalize()
|
|
implicit none
|
|
PROVIDE GASPI_is_initialized
|
|
IRP_IF GASPI
|
|
use GASPI
|
|
integer(gaspi_return_t) :: res
|
|
res = gaspi_proc_term(GASPI_BLOCK)
|
|
if (res /= GASPI_SUCCESS) then
|
|
print *, res
|
|
print *, 'Unable to finalize GASPI'
|
|
stop -1
|
|
endif
|
|
IRP_ENDIF
|
|
end subroutine
|
|
|