Skip to content

Commit

Permalink
Merge pull request #75 from NCAR/ejh_cleanup6
Browse files Browse the repository at this point in the history
Ejh cleanup6
  • Loading branch information
Katetc authored Jun 13, 2016
2 parents 1d705fc + bf1ed73 commit cb8f4ee
Show file tree
Hide file tree
Showing 2 changed files with 72 additions and 49 deletions.
117 changes: 70 additions & 47 deletions src/clib/pio_file.c
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
#include <pio.h>
#include <pio_internal.h>

/* Open an existing file using pio
/* Open an existing file using pio.
* @public
* @ingroup PIO_openfile
*
Expand Down Expand Up @@ -31,10 +31,7 @@ int PIOc_openfile(const int iosysid, int *ncidp, int *iotype,

/* Get the IO system info from the iosysid. */
if (!(ios = pio_get_iosystem_from_id(iosysid)))
{
LOG((0, "PIOc_openfile got bad iosysid %d",iosysid));
return PIO_EBADID;
}

/* Allocate space for the file info. */
if (!(file = (file_desc_t *) malloc(sizeof(*file))))
Expand Down Expand Up @@ -205,7 +202,6 @@ int PIOc_openfile(const int iosysid, int *ncidp, int *iotype,
* @param filename : The filename to open
* @param mode : The netcdf mode for the open operation
*/

int PIOc_createfile(const int iosysid, int *ncidp, int *iotype,
const char filename[], const int mode)
{
Expand Down Expand Up @@ -452,14 +448,17 @@ int PIOc_closefile(int ncid)
* @param iosysid : a pio system handle
* @param filename : a filename
*/
int PIOc_deletefile(const int iosysid, const char filename[])
int PIOc_deletefile(const int iosysid, const char *filename)
{
iosystem_desc_t *ios; /** Pointer to io system information. */
file_desc_t *file; /** Pointer to file information. */
int ierr = PIO_NOERR; /** Return code from function calls. */
int deleted = 0; /** Becomes true when file is deleted. */
int mpierr = MPI_SUCCESS, mpierr2; /** Return code from MPI function codes. */
int msg = PIO_MSG_DELETE_FILE;
size_t len;

/* Filename must be provided. */
if (!filename || strlen(filename) > NC_MAX_NAME)
return PIO_EINVAL;

/* Get the IO system info from the id. */
if (!(ios = pio_get_iosystem_from_id(iosysid)))
Expand All @@ -470,35 +469,49 @@ int PIOc_deletefile(const int iosysid, const char filename[])
{
if (!ios->ioproc)
{
if(ios->comp_rank==0)
int msg = PIO_MSG_DELETE_FILE;
size_t len = strlen(filename);

if(ios->compmaster)
mpierr = MPI_Send(&msg, 1,MPI_INT, ios->ioroot, 1, ios->union_comm);

len = strlen(filename);
if (!mpierr)
mpierr = MPI_Bcast(&len, 1, MPI_INT, ios->compmaster, ios->intercomm);
if (!mpierr)
mpierr = MPI_Bcast((void *)filename, len + 1, MPI_CHAR, ios->compmaster, ios->intercomm);
}

/* Handle MPI errors. */
if ((mpierr2 = MPI_Bcast(&mpierr, 1, MPI_INT, ios->comproot, ios->my_comm)))
return check_mpi(file, mpierr2, __FILE__, __LINE__);
if (mpierr)
return check_mpi(file, mpierr, __FILE__, __LINE__);
}

/* If this is an IO task, then call the netCDF function. The
* barriers are needed to assure that no task is trying to operate
* on the file while it is being deleted. */
if(ios->ioproc){
if (ios->ioproc)
{
MPI_Barrier(ios->io_comm);
#ifdef _NETCDF
if(ios->io_rank==0)
if (ios->iomaster)
ierr = nc_delete(filename);
deleted++;
#else
#ifdef _PNETCDF
ierr = ncmpi_delete(filename, ios->info);
if (!deleted)
ierr = ncmpi_delete(filename, ios->info);
#endif
#endif
MPI_Barrier(ios->io_comm);
}

// Special case - always broadcast the return from the
MPI_Bcast(&ierr, 1, MPI_INT, ios->ioroot, ios->my_comm);
/* Broadcast and check the return code. */
if ((mpierr = MPI_Bcast(&ierr, 1, MPI_INT, ios->ioroot, ios->my_comm)))
return check_mpi(file, mpierr, __FILE__, __LINE__);
if (ierr)
return check_netcdf(file, ierr, __FILE__, __LINE__);

return ierr;
}
Expand Down Expand Up @@ -531,60 +544,70 @@ int PIOc_sync(int ncid)
{
int msg = PIO_MSG_SYNC;

if(ios->comp_rank == 0)
if (ios->compmaster)
mpierr = MPI_Send(&msg, 1,MPI_INT, ios->ioroot, 1, ios->union_comm);

mpierr = MPI_Bcast(&(file->fh),1, MPI_INT, ios->compmaster, ios->intercomm);

if (!mpierr)
mpierr = MPI_Bcast(&file->fh, 1, MPI_INT, ios->compmaster,
ios->intercomm);
if (mpierr)
return check_mpi(file, mpierr, __FILE__, __LINE__);
}

/* Handle MPI errors. */
/* if ((mpierr2 = MPI_Bcast(&mpierr, 1, MPI_INT, ios->comproot, ios->my_comm))) */
/* return check_mpi(file, mpierr2, __FILE__, __LINE__); */
/* if (mpierr) */
/* return check_mpi(file, mpierr, __FILE__, __LINE__); */
}

if (file->mode & PIO_WRITE)
{
// cn_buffer_report( *ios, true);
wmb = &(file->buffer);
while(wmb != NULL){
wmb = &file->buffer;
while(wmb)
{
// printf("%s %d %d %d\n",__FILE__,__LINE__,wmb->ioid, wmb->validvars);
if(wmb->validvars>0){
if (wmb->validvars > 0)
{
flush_buffer(ncid, wmb, true);
}
twmb = wmb;
wmb = wmb->next;
if(twmb == &(file->buffer)){
twmb->ioid=-1;
twmb->next=NULL;
}else{
if (twmb == &file->buffer)
{
twmb->ioid = -1;
twmb->next = NULL;
}
else
{
brel(twmb);
}
}
flush_output_buffer(file, true, 0);

if(ios->ioproc){
switch(file->iotype){
#ifdef _NETCDF
#ifdef _NETCDF4
case PIO_IOTYPE_NETCDF4P:
ierr = nc_sync(file->fh);;
break;
case PIO_IOTYPE_NETCDF4C:
#endif
case PIO_IOTYPE_NETCDF:
if(ios->io_rank==0){
ierr = nc_sync(file->fh);;
}
break;
#endif
/* If this is an IO task, then call the netCDF function. */
if (ios->ioproc)
{
#ifdef _PNETCDF
case PIO_IOTYPE_PNETCDF:
ierr = ncmpi_sync(file->fh);;
break;
#endif
default:
ierr = iotype_error(file->iotype,__FILE__,__LINE__);
}
if (file->iotype == PIO_IOTYPE_PNETCDF)
ierr = ncmpi_sync(file->fh);
#endif /* _PNETCDF */
#ifdef _NETCDF
if (file->iotype != PIO_IOTYPE_PNETCDF && file->do_io)
ierr = nc_sync(file->fh);
#endif /* _NETCDF */
}

ierr = check_netcdf(file, ierr, __FILE__,__LINE__);
}

/* Broadcast and check the return code. */
/* if ((mpierr = MPI_Bcast(&ierr, 1, MPI_INT, ios->ioroot, ios->my_comm))) */
/* return check_mpi(file, mpierr, __FILE__, __LINE__); */
/* if (ierr) */
/* return check_netcdf(file, ierr, __FILE__, __LINE__); */

return ierr;
}

4 changes: 2 additions & 2 deletions tests/unit/test_intercomm.c
Original file line number Diff line number Diff line change
Expand Up @@ -531,8 +531,8 @@ main(int argc, char **argv)
ERR(ret);

/* Now delete the file. */
/* if ((ret = PIOc_deletefile(iosysid, filename[fmt]))) */
/* ERR(ret); */
if ((ret = PIOc_deletefile(iosysid, filename[fmt])))
ERR(ret);
/* if ((ret = PIOc_openfile(iosysid, &ncid, &format[fmt], filename[fmt], */
/* NC_NOWRITE)) != PIO_ENFILE) */
/* ERR(ERR_AWFUL); */
Expand Down

0 comments on commit cb8f4ee

Please sign in to comment.