! This file created from test/mpi/f77/coll/alltoallvf.f with f77tof90
-! -*- Mode: Fortran; -*-
+! -*- Mode: Fortran; -*-
!
! (C) 2011 by Argonne National Laboratory.
! See COPYRIGHT in top-level directory.
integer sbuf(maxSize), rbuf(maxSize)
errs = 0
-
+
call mtest_init( ierr )
! Get a comm
call mpi_comm_size( comm, size, ierr )
endif
call mpi_comm_rank( comm, rank, ierr )
-!
+!
if (size .le. maxSize) then
! Initialize the data. Just use this as an all to all
! Use the same test as alltoallwf.c , except displacements are in units of
rbuf(i) = -1
enddo
call mpi_alltoallv( sbuf, scounts, sdispls, stypes, &
- & rbuf, rcounts, rdispls, rtypes, comm, ierr )
+ & rbuf, rcounts, rdispls, rtypes, comm, ierr )
!
! check rbuf(i) = data from the ith location of the ith send buf, or
-! rbuf(i) = (i-1) * size + i
+! rbuf(i) = (i-1) * size + i
do i=1, size
ans = (i-1) * size + rank + 1
if (rbuf(i) .ne. ans) then
sbuf(1+displ) = rank
displ = displ + 1
if (rank .lt. size-1) then
- scounts(1+rank+1) = 1
+ scounts(1+rank+1) = 1
rcounts(1+rank+1) = 1
sdispls(1+rank+1) = displ
rdispls(1+rank+1) = rank+1
call mtest_finalize( errs )
call mpi_finalize( ierr )
end
-
+