! This file created from test/mpi/f77/util/mtestf.f with f77tof90 ! -*- Mode: Fortran; -*- ! ! (C) 2003 by Argonne National Laboratory. ! See COPYRIGHT in top-level directory. ! subroutine MTest_Init( ierr ) ! Place the include first so that we can automatically create a ! Fortran 90 version that uses the mpi module instead. If ! the module is in a different place, the compiler can complain ! about out-of-order statements use mpi integer ierr logical flag logical dbgflag integer wrank common /mtest/ dbgflag, wrank call MPI_Initialized( flag, ierr ) if (.not. flag) then call MPI_Init( ierr ) endif dbgflag = .false. call MPI_Comm_rank( MPI_COMM_WORLD, wrank, ierr ) end ! subroutine MTest_Finalize( errs ) use mpi integer errs integer rank, toterrs, ierr call MPI_Comm_rank( MPI_COMM_WORLD, rank, ierr ) call MPI_Allreduce( errs, toterrs, 1, MPI_INTEGER, MPI_SUM, & & MPI_COMM_WORLD, ierr ) if (rank .eq. 0) then if (toterrs .gt. 0) then print *, " Found ", toterrs, " errors" else print *, " No Errors" endif endif end module array integer, dimension(:), allocatable :: myindex end module ! ! A simple get intracomm for now logical function MTestGetIntracomm( comm, min_size, qsmaller ) use array use mpi integer ierr integer comm, min_size, size, rank logical qsmaller integer status call mpi_comm_size( MPI_COMM_WORLD, size, ierr ) if(.not. allocated(myindex)) then allocate(myindex(size), STAT=status) call mpi_comm_rank( MPI_COMM_WORLD, rank, ierr ) myindex(rank+1)=0 endif !data myindex /0/ if (myindex(rank+1) .eq. 0) then comm = MPI_COMM_WORLD else if (myindex(rank+1) .eq. 1) then call mpi_comm_dup( MPI_COMM_WORLD, comm, ierr ) else if (myindex(rank+1) .eq. 2) then call mpi_comm_size( MPI_COMM_WORLD, size, ierr ) call mpi_comm_rank( MPI_COMM_WORLD, rank, ierr ) call mpi_comm_split( MPI_COMM_WORLD, 0, size - rank, comm, & & ierr ) else if (min_size .eq. 1 .and. myindex(rank+1) .eq. 3) then comm = MPI_COMM_SELF endif endif myindex(rank+1) = mod( myindex(rank+1), 4 ) + 1 MTestGetIntracomm = comm .ne. MPI_COMM_NULL qsmaller=.true. end ! subroutine MTestFreeComm( comm ) use mpi integer comm, ierr if (comm .ne. MPI_COMM_WORLD .and. & & comm .ne. MPI_COMM_SELF .and. & & comm .ne. MPI_COMM_NULL) then call mpi_comm_free( comm, ierr ) endif end ! subroutine MTestPrintError( errcode ) use mpi integer errcode integer errclass, slen, ierr character*(MPI_MAX_ERROR_STRING) string call MPI_Error_class( errcode, errclass, ierr ) call MPI_Error_string( errcode, string, slen, ierr ) print *, "Error class ", errclass, "(", string(1:slen), ")" end ! subroutine MTestPrintErrorMsg( msg, errcode ) use mpi character*(*) msg integer errcode integer errclass, slen, ierr character*(MPI_MAX_ERROR_STRING) string call MPI_Error_class( errcode, errclass, ierr ) call MPI_Error_string( errcode, string, slen, ierr ) print *, msg, ": Error class ", errclass, " & & (", string(1:slen), ")" end