diff --git a/src/binding/f90/getput_var.m4 b/src/binding/f90/getput_var.m4 index c8dc6a81c..65e428fd2 100644 --- a/src/binding/f90/getput_var.m4 +++ b/src/binding/f90/getput_var.m4 @@ -738,7 +738,7 @@ NBVAR(bput, 7, EightByteInt, integer, int8, `:,:,:,:,:,:,:', INTENTV) integer (kind=MPI_OFFSET_KIND), intent(out) :: buf_size integer :: nf90mpi_inq_buffer_size - nf90mpi_inq_buffer_size = nfmpi_inq_buffer_usage(ncid, buf_size) + nf90mpi_inq_buffer_size = nfmpi_inq_buffer_size(ncid, buf_size) end function nf90mpi_inq_buffer_size function nf90mpi_buffer_detach(ncid) diff --git a/test/nonblocking/test_bputf.f90 b/test/nonblocking/test_bputf.f90 index d9b47c50e..92a17b2cc 100644 --- a/test/nonblocking/test_bputf.f90 +++ b/test/nonblocking/test_bputf.f90 @@ -8,13 +8,13 @@ subroutine check(err, message) use mpi use pnetcdf implicit none - integer err + integer err, ierr character(len=*) message ! It is a good idea to check returned value for possible error if (err .NE. NF90_NOERR) then write(6,*) trim(message), trim(nf90mpi_strerror(err)) - call MPI_Abort(MPI_COMM_WORLD, -1, err) + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) end if end subroutine check @@ -23,17 +23,19 @@ program main use pnetcdf implicit none - logical verbose + logical verbose, using_bb integer i, j, ncid, varid, err, ierr, rank, nprocs, info - integer no_err, cmode, get_args + integer no_err, cmode, get_args, idx integer dimid(2), req(2), status(2) integer(kind=MPI_OFFSET_KIND) start(2) integer(kind=MPI_OFFSET_KIND) count(2) integer(kind=MPI_OFFSET_KIND) stride(2) integer(kind=MPI_OFFSET_KIND) imap(2) - integer(kind=MPI_OFFSET_KIND) bufsize + integer(kind=MPI_OFFSET_KIND) bufsize, inq_bufsize + integer(kind=MPI_OFFSET_KIND) usage, acc_usage real var(6,4) character(len=256) :: filename, cmd, msg + character(len=512) :: hints call MPI_INIT(ierr) call MPI_COMM_RANK(MPI_COMM_WORLD, rank, ierr) @@ -54,6 +56,12 @@ program main ' is designed to run on 1 process' endif + call getenv("PNETCDF_HINTS", hints) + idx = index(hints, "nc_burst_buf=enable") + + using_bb = .FALSE. + if (idx > 0) using_bb = .TRUE. + call MPI_Info_create(info, ierr) ! call MPI_Info_set(info, "romio_pvfs2_posix_write","enable",ierr) @@ -90,10 +98,29 @@ program main enddo enddo - ! bufsize must be max of data type converted before and after - bufsize = 4*6*8 - err = nf90mpi_buffer_attach(ncid, bufsize) - call check(err, 'Error at nf90mpi_buffer_attach ') + if (.NOT. using_bb) then + ! bufsize must be max of data type converted before and after + bufsize = 4*6*8 + acc_usage = 0 + err = nf90mpi_buffer_attach(ncid, bufsize) + call check(err, 'Error at nf90mpi_buffer_attach ') + + err = nf90mpi_inq_buffer_size(ncid, inq_bufsize) + call check(err, 'Error at nf90mpi_inq_buffer_size ') + + if (inq_bufsize .NE. bufsize) then + print*,"Error: expect bufsize ",bufsize,"but got ",inq_bufsize + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + + err = nf90mpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nf90mpi_inq_buffer_usage ') + + if (usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ",usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if ! write var to the NC variable in the matrix transposed way count(1) = 2 @@ -115,6 +142,18 @@ program main stride, imap) call check(err, 'Error at nf90mpi_bput_var ') + acc_usage = acc_usage + count(1) * count(2) * 8 + + if (.NOT. using_bb) then + err = nf90mpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nf90mpi_inq_buffer_usage ') + + if (usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ",usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + ! write the second two columns of the NC variable in the matrix transposed way start(1) = 3 start(2) = 1 @@ -122,9 +161,31 @@ program main stride, imap) call check(err, 'Error at nf90mpi_bput_var ') + acc_usage = acc_usage + count(1) * count(2) * 8 + + if (.NOT. using_bb) then + err = nf90mpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nf90mpi_inq_buffer_usage ') + + if (usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ",usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + err = nf90mpi_wait_all(ncid, 2, req, status) call check(err, 'Error at nf90mpi_wait_all ') + if (.NOT. using_bb) then + err = nf90mpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nf90mpi_inq_buffer_usage ') + + if (usage .NE. 0) then + print*,"Error: expect buf usage 0 but got ",usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + ! check each bput status do i = 1, 2 if (status(i) .ne. NF90_NOERR) then @@ -135,6 +196,12 @@ program main err = nf90mpi_buffer_detach(ncid) call check(err, 'Error at nf90mpi_buffer_detach ') + err = nf90mpi_inq_buffer_size(ncid, inq_bufsize) + if (err .NE. NF90_ENULLABUF) then + print*,"Error: unexpected error code ",err + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + ! the output from command "ncmpidump -v var test.nc" should be: ! var = ! 50, 56, 62, 68, diff --git a/test/nonblocking/test_bputf77.f b/test/nonblocking/test_bputf77.f index ff728478d..7d58e5aa1 100644 --- a/test/nonblocking/test_bputf77.f +++ b/test/nonblocking/test_bputf77.f @@ -19,13 +19,13 @@ subroutine check(err, message) implicit none include "mpif.h" include "pnetcdf.inc" - integer err + integer err, ierr character message*(*) ! It is a good idea to check returned value for possible error if (err .NE. NF_NOERR) then write(6,*) message//' '//nfmpi_strerror(err) - call MPI_Abort(MPI_COMM_WORLD, -1, err) + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) endif end ! subroutine check @@ -34,17 +34,19 @@ program main include "mpif.h" include "pnetcdf.inc" - logical verbose + logical verbose, using_bb integer i, j, ncid, varid, err, ierr, rank, nprocs, info - integer no_err, cmode, get_args, XTRIM + integer no_err, cmode, get_args, XTRIM, idx integer dimid(2), req(2), status(2) integer*8 start(2) integer*8 count(2) integer*8 stride(2) integer*8 imap(2) - integer*8 bufsize, dim_size + integer*8 dim_size, bufsize, inq_bufsize real var(6,4) character*256 filename, cmd, msg + integer*8 usage, acc_usage + character*512 hints call MPI_INIT(ierr) call MPI_COMM_RANK(MPI_COMM_WORLD, rank, ierr) @@ -66,6 +68,12 @@ program main + ' is designed to run on 1 process' endif + call getenv("PNETCDF_HINTS", hints) + idx = index(hints, "nc_burst_buf=enable") + + using_bb = .FALSE. + if (idx > 0) using_bb = .TRUE. + call MPI_Info_create(info, ierr) ! call MPI_Info_set(info, "romio_pvfs2_posix_write","enable",ierr) @@ -106,9 +114,30 @@ program main ! bufsize must be max of data type converted before and after bufsize = 4*6*8 + acc_usage = 0 err = nfmpi_buffer_attach(ncid, bufsize) call check(err, 'Error at nfmpi_buffer_attach ') + if (.NOT. using_bb) then + err = nfmpi_inq_buffer_size(ncid, inq_bufsize) + call check(err, 'Error at nfmpi_inq_buffer_size ') + + if (inq_bufsize .NE. bufsize) then + print*,"Error: expect bufsize ",bufsize,"but got ", + + inq_bufsize + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + + err = nfmpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nfmpi_inq_buffer_usage ') + + if (.NOT. using_bb .AND. usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ", + + usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + ! write var to the NC variable in the matrix transposed way count(1) = 2 count(2) = 6 @@ -129,6 +158,19 @@ program main + imap, var(1,1), req(1)) call check(err, 'Error at nfmpi_bput_varm_real ') + acc_usage = acc_usage + count(1) * count(2) * 8 + + if (.NOT. using_bb) then + err = nfmpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nfmpi_inq_buffer_usage ') + + if (usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ", + + usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + ! write the second two columns of the NC variable in the matrix transposed way start(1) = 3 start(2) = 1 @@ -136,9 +178,32 @@ program main + imap, var(1,3), req(2)) call check(err, 'Error at nfmpi_bput_varm_real ') + acc_usage = acc_usage + count(1) * count(2) * 8 + + if (.NOT. using_bb) then + err = nfmpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nfmpi_inq_buffer_usage ') + + if (usage .NE. acc_usage) then + print*,"Error: expect buf usage ",acc_usage," but got ", + + usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + err = nfmpi_wait_all(ncid, 2, req, status) call check(err, 'Error at nfmpi_wait_all ') + if (.NOT. using_bb) then + err = nfmpi_inq_buffer_usage(ncid, usage) + call check(err, 'Error at nfmpi_inq_buffer_usage ') + + if (usage .NE. 0) then + print*,"Error: expect buf usage 0 but got ",usage + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + end if + ! check each bput status do i = 1, 2 if (status(i) .ne. NF_NOERR) then @@ -149,6 +214,12 @@ program main err = nfmpi_buffer_detach(ncid) call check(err, 'Error at nfmpi_buffer_detach ') + err = nfmpi_inq_buffer_size(ncid, inq_bufsize) + if (err .NE. NF_ENULLABUF) then + print*,"Error: unexpected error code ",err + call MPI_Abort(MPI_COMM_WORLD, -1, ierr) + end if + ! the output from command "ncmpidump -v var test.nc" should be: ! var = ! 50, 56, 62, 68,