2005-01-18 16:15:55 +00:00
|
|
|
#! /bin/sh
|
|
|
|
|
2005-08-24 02:11:02 +00:00
|
|
|
. "$1/fortran_kinds.sh"
|
2005-01-18 16:15:55 +00:00
|
|
|
|
|
|
|
procedure='MPI_Sendrecv_replace'
|
|
|
|
|
|
|
|
rank=0
|
|
|
|
for kind in $lkinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DL${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " logical(kind=MPI_INTEGER${kind}_KIND), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
rank=0
|
|
|
|
for kind in $ikinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DI${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " integer(kind=MPI_INTEGER${kind}_KIND), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
rank=0
|
|
|
|
for kind in $rkinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DR${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " real(kind=MPI_REAL${kind}_KIND), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
rank=0
|
|
|
|
for kind in $ckinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DC${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " complex(kind=MPI_REAL${kind}_KIND), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
for rank in $ranks
|
|
|
|
do
|
|
|
|
case "$rank" in 1) dim=':' ; esac
|
|
|
|
case "$rank" in 2) dim=':,:' ; esac
|
|
|
|
case "$rank" in 3) dim=':,:,:' ; esac
|
|
|
|
case "$rank" in 4) dim=':,:,:,:' ; esac
|
|
|
|
case "$rank" in 5) dim=':,:,:,:,:' ; esac
|
|
|
|
case "$rank" in 6) dim=':,:,:,:,:,:' ; esac
|
|
|
|
case "$rank" in 7) dim=':,:,:,:,:,:,:' ; esac
|
|
|
|
|
|
|
|
for kind in $lkinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DL${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " logical(kind=MPI_INTEGER${kind}_KIND), dimension(${dim}), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
for kind in $ikinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DI${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " integer(kind=MPI_INTEGER${kind}_KIND), dimension(${dim}), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
for kind in $rkinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DR${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " real(kind=MPI_REAL${kind}_KIND), dimension(${dim}), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
|
|
|
|
for kind in $ckinds
|
|
|
|
do
|
|
|
|
proc="${procedure}${rank}DC${kind}"
|
|
|
|
echo "subroutine ${proc}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
echo " use mpi_kinds"
|
|
|
|
echo " complex(kind=MPI_REAL${kind}_KIND), dimension(${dim}), intent(inout) :: buf"
|
|
|
|
echo " integer, intent(in) :: count"
|
|
|
|
echo " integer, intent(in) :: datatype"
|
|
|
|
echo " integer, intent(in) :: dest"
|
|
|
|
echo " integer, intent(in) :: sendtag"
|
|
|
|
echo " integer, intent(in) :: source"
|
|
|
|
echo " integer, intent(in) :: recvtag"
|
|
|
|
echo " integer, intent(in) :: comm"
|
|
|
|
echo " integer, dimension(MPI_STATUS_SIZE), intent(inout) :: status"
|
|
|
|
echo " integer, intent(out) :: ierr"
|
|
|
|
echo " call ${procedure}(buf, count, datatype, dest, sendtag, &
|
|
|
|
source, recvtag, comm, status, ierr)"
|
|
|
|
|
|
|
|
echo "end subroutine ${proc}"
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
done
|
|
|
|
echo
|
|
|
|
echo
|
|
|
|
|