1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
!
! Copyright (C) by Argonne National Laboratory
! See COPYRIGHT in top-level directory
!
program main
use mpi_f08
integer errs, err
integer rank, size, rsize, i
integer np
integer errcodes(2)
type(MPI_Comm) parentcomm, intercomm
type(MPI_Status) status
integer ierr
integer can_spawn
errs = 0
np = 2
call MTest_Init( ierr )
call MTestSpawnPossible( can_spawn, errs )
if ( can_spawn .eq. 0 ) then
call MTest_Finalize( errs )
goto 300
endif
call MPI_Comm_get_parent( parentcomm, ierr )
if (parentcomm .eq. MPI_COMM_NULL) then
! Create 2 more processes
call MPI_Comm_spawn( "./spawnf90", MPI_ARGV_NULL, np, &
& MPI_INFO_NULL, 0, MPI_COMM_WORLD, intercomm, errcodes &
& ,ierr )
else
intercomm = parentcomm
endif
! We now have a valid intercomm
call MPI_Comm_remote_size( intercomm, rsize, ierr )
call MPI_Comm_size( intercomm, size, ierr )
call MPI_Comm_rank( intercomm, rank, ierr )
if (parentcomm .eq. MPI_COMM_NULL) then
! Parent
if (rsize .ne. np) then
errs = errs + 1
print *, "Did not create ", np, " processes (got ", rsize, &
& ")"
endif
if (rank .eq. 0) then
do i=0,rsize-1
call MPI_Send( i, 1, MPI_INTEGER, i, 0, intercomm, ierr &
& )
enddo
! We could use intercomm reduce to get the errors from the
! children, but we'll use a simpler loop to make sure that
! we get valid data
do i=0, rsize-1
call MPI_Recv( err, 1, MPI_INTEGER, i, 1, intercomm, &
& MPI_STATUS_IGNORE, ierr )
errs = errs + err
enddo
endif
else
! Child
if (size .ne. np) then
errs = errs + 1
print *, "(Child) Did not create ", np, " processes (got " &
& ,size, ")"
endif
call MPI_Recv( i, 1, MPI_INTEGER, 0, 0, intercomm, status, &
& ierr )
if (i .ne. rank) then
errs = errs + 1
print *, "Unexpected rank on child ", rank, "(",i,")"
endif
! Send the errs back to the parent process
call MPI_Ssend( errs, 1, MPI_INTEGER, 0, 1, intercomm, ierr )
endif
! It isn't necessary to free the intercomm, but it should not hurt
call MPI_Comm_free( intercomm, ierr )
! Note that the MTest_Finalize get errs only over COMM_WORLD
! Note also that both the parent and child will generate "No
! Errors" if both call MTest_Finalize
if (parentcomm .eq. MPI_COMM_NULL) then
call MTest_Finalize( errs )
else
call MPI_Finalize( ierr )
endif
300 continue
end
|