📄 spawnargvf90.f90
字号:
! This file created from test/mpi/f77/spawn/spawnargvf.f with f77tof90! -*- Mode: Fortran; -*- !! (C) 2003 by Argonne National Laboratory.! See COPYRIGHT in top-level directory.!! This is a special test that requires an getarg/iargc routine ! program main use mpi integer errs, err integer rank, size, rsize, i integer np integer errcodes(2) integer parentcomm, intercomm integer status(MPI_STATUS_SIZE) character*(10) inargv(6), outargv(6) character*(80) argv(64) integer argc data inargv /"a", "b=c", "d e", "-pf", " Ss", " " / data outargv /"a", "b=c", "d e", "-pf", " Ss", " " / errs = 0 np = 2 call MTest_Init( ierr ) call MPI_Comm_get_parent( parentcomm, ierr ) if (parentcomm .eq. MPI_COMM_NULL) then! Create 2 more processes call MPI_Comm_spawn( "./spawnargvf90", inargv, 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! Master if (rsize .ne. np) then errs = errs + 1 print *, "Did not create ", np, " processes (got & & ", rsize, ")" endif 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 else ! Child ! FIXME: This assumes that stdout is handled for the children! (the error count will still be reported to the parent) argc = iargc() do i=1, argc call getarg( i, argv(i) ) enddo 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! Check the command line do i=1, argc if (outargv(i) .eq. " ") then errs = errs + 1 print *, "Wrong number of arguments (", argc, ")" goto 200 endif if (argv(i) .ne. outargv(i)) then errs = errs + 1 print *, "Found arg ", argv(i), " but expected ", & & outargv(i) endif enddo 200 continue if (outargv(i) .ne. " ") then! We had too few args in the spawned command errs = errs + 1 print *, "Too few arguments to spawned command" endif! Send the errs back to the master 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 if (parentcomm .eq. MPI_COMM_NULL) then call MTest_Finalize( errs ) endif call MPI_Finalize( ierr ) end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -