2016-01-15 02:02:23 +08:00
|
|
|
/*! \file
|
|
|
|
*
|
|
|
|
* Main header file for the Parallel C API.
|
|
|
|
*
|
2010-06-07 19:25:58 +08:00
|
|
|
* Copyright 2010 University Corporation for Atmospheric
|
|
|
|
* Research/Unidata. See COPYRIGHT file for more info.
|
|
|
|
*
|
|
|
|
* This header file is for the parallel I/O functions of netCDF.
|
2016-01-15 02:02:23 +08:00
|
|
|
*
|
2017-11-08 18:33:44 +08:00
|
|
|
* \author Ed Hartnett
|
2010-06-07 19:25:58 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NETCDF_PAR_H
|
|
|
|
#define NETCDF_PAR_H 1
|
|
|
|
|
|
|
|
#include <mpi.h>
|
|
|
|
|
2012-01-18 12:46:09 +08:00
|
|
|
#if defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2017-11-08 18:33:44 +08:00
|
|
|
/** Use with nc_var_par_access() to set parallel access to independent. */
|
2010-06-07 19:25:58 +08:00
|
|
|
#define NC_INDEPENDENT 0
|
2017-11-08 18:33:44 +08:00
|
|
|
/** Use with nc_var_par_access() to set parallel access to collective. */
|
2010-06-07 19:25:58 +08:00
|
|
|
#define NC_COLLECTIVE 1
|
|
|
|
|
|
|
|
/* Create a file and enable parallel I/O. */
|
|
|
|
extern int
|
|
|
|
nc_create_par(const char *path, int cmode, MPI_Comm comm, MPI_Info info,
|
|
|
|
int *ncidp);
|
|
|
|
|
|
|
|
/* Open a file and enable parallel I/O. */
|
|
|
|
extern int
|
|
|
|
nc_open_par(const char *path, int mode, MPI_Comm comm, MPI_Info info,
|
|
|
|
int *ncidp);
|
|
|
|
|
|
|
|
/* Change a variable from independent (the default) to collective
|
|
|
|
* access. */
|
|
|
|
extern int
|
|
|
|
nc_var_par_access(int ncid, int varid, int par_access);
|
|
|
|
|
|
|
|
extern int
|
2016-01-15 02:02:23 +08:00
|
|
|
nc_create_par_fortran(const char *path, int cmode, int comm,
|
2010-06-07 19:25:58 +08:00
|
|
|
int info, int *ncidp);
|
|
|
|
extern int
|
2016-01-15 02:02:23 +08:00
|
|
|
nc_open_par_fortran(const char *path, int mode, int comm,
|
2010-06-07 19:25:58 +08:00
|
|
|
int info, int *ncidp);
|
|
|
|
|
2012-01-18 12:46:09 +08:00
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-06-07 19:25:58 +08:00
|
|
|
#endif /* NETCDF_PAR_H */
|