Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge latest PIO2 master #407

Merged
merged 214 commits into from
Aug 16, 2016
Merged
Changes from 1 commit
Commits
Show all changes
214 commits
Select commit Hold shift + click to select a range
22fdf30
Merge pull request #4 from NCAR/master
Katetc Jan 11, 2016
820aeda
Merge pull request #5 from NCAR/master
Katetc Mar 15, 2016
81ccf39
now duplicate MPI communicators in init_intracomm
edhartnett Mar 18, 2016
238583a
added comments
edhartnett Mar 18, 2016
5712329
free MPI group
edhartnett Mar 29, 2016
a7ce0fa
Merge pull request #61 from NCAR/ejh_24
jedwards4b Mar 29, 2016
c3f5a1d
changes to pioperformance.F90 to support the PIO1 library.
Katetc Mar 29, 2016
d5a24c0
Changes to pioperformance.F90 to get it to build and run with PIO1. A…
Katetc Apr 4, 2016
467cb31
Merge pull request #62 from Katetc/master
jedwards4b Apr 4, 2016
17da322
Added a catch for NC_EINVAL errors on file opening (in this case, try…
Katetc Apr 15, 2016
04db212
added documentation to iosystem_desc_t
edhartnett May 4, 2016
648b350
changed example data size, added valgrind suppression file
edhartnett May 4, 2016
a4cdd06
changing in pio_file.c to support async
edhartnett May 4, 2016
aebdcdd
change in response to review feedback
edhartnett May 4, 2016
4b825ba
Merge pull request #64 from NCAR/ejh_doc
jedwards4b May 5, 2016
32228f5
Merge pull request #65 from NCAR/ejh_example_valgrind
jedwards4b May 5, 2016
0c4cbe6
Merge pull request #66 from NCAR/ejh_pio_file_async
jedwards4b May 5, 2016
c854f34
changes to pioc.c to support async, also some temporary copies of cod…
edhartnett May 5, 2016
458a3fa
removed extra index for async ncids
edhartnett May 5, 2016
3faa0e9
Merge pull request #67 from NCAR/ejh_async_files
jedwards4b May 5, 2016
8e34e30
manually merged async changes from ejh_27
edhartnett May 5, 2016
b16142f
got non-async build working
edhartnett May 5, 2016
d2664af
got async option working
edhartnett May 5, 2016
badb925
got non-async build working again
edhartnett May 5, 2016
3b0ad26
got attribut put working
edhartnett May 6, 2016
aee5878
development of async inq functions
edhartnett May 9, 2016
90c689f
more inq functions working with async
edhartnett May 9, 2016
8600910
removed some unneeded msg constants
edhartnett May 10, 2016
b312291
added logging
edhartnett May 10, 2016
bb17ac4
rearranged order of functions, started to use LOG in pio_msg
edhartnett May 10, 2016
b16d251
cleaning up error handling
edhartnett May 10, 2016
af76675
further async development
edhartnett May 11, 2016
fc48722
better error handling
edhartnett May 11, 2016
90f714e
continued development of async
edhartnett May 11, 2016
fb378ca
added log message
edhartnett May 11, 2016
0783073
further development
edhartnett May 11, 2016
e2504bb
further development of async
edhartnett May 11, 2016
2a77fe1
further development of async
edhartnett May 11, 2016
f028866
further development of async
edhartnett May 11, 2016
891b29c
further development of async
edhartnett May 11, 2016
8b46080
further development of async
edhartnett May 11, 2016
80a361f
further async development
edhartnett May 12, 2016
10b178a
code cleanup
edhartnett May 12, 2016
a0aaea9
further cleanup of async code
edhartnett May 12, 2016
96e7498
further cleanup of async code
edhartnett May 12, 2016
f788f6b
further cleanup of async code
edhartnett May 12, 2016
0a6fb4f
further cleanup of async code
edhartnett May 12, 2016
54c8287
further cleanup of async code
edhartnett May 12, 2016
19ea322
further development of async code
edhartnett May 12, 2016
8938469
further async development
edhartnett May 12, 2016
6e7e780
further async development
edhartnett May 12, 2016
cd4421f
further async development
edhartnett May 12, 2016
ae43f47
added PIOc_inq_type
edhartnett May 13, 2016
5912c2a
added PIOc_inq_type
edhartnett May 13, 2016
fed2d0f
further development of async get_att
edhartnett May 13, 2016
f5b581a
now get_att generalized by type
edhartnett May 13, 2016
1c35182
now get_att generalized by type
edhartnett May 13, 2016
e667561
now get_att generalized by type
edhartnett May 13, 2016
06b279e
got put_att working with async
edhartnett May 13, 2016
99632fd
further development of async code
edhartnett May 13, 2016
4866ec1
further development of async code
edhartnett May 13, 2016
9020e2d
moved logging code to pioc_support
edhartnett May 13, 2016
0337dbe
cleaning up call to netcdf layer in PIOc_nc_async
edhartnett May 14, 2016
ddaa30a
cleaning up call to netcdf layer in PIOc_nc_async
edhartnett May 14, 2016
16e3799
got inq_format working with async
edhartnett May 14, 2016
2a250cf
got inq_attname working with async
edhartnett May 14, 2016
5b14021
got inq_attid working for async
edhartnett May 14, 2016
10ff143
got inq_attid working for async
edhartnett May 14, 2016
6c0ee7b
got rename_dim working
edhartnett May 14, 2016
f446718
got rename_var working with async
edhartnett May 14, 2016
0ce232f
got rename_var working with async
edhartnett May 14, 2016
36c065c
Changed Pnetcdf required version to 1.6.1 in documentation.
Katetc May 16, 2016
bc0d033
Merge pull request #6 from NCAR/master
Katetc May 16, 2016
a055a39
fixed rename_att function for async
edhartnett May 17, 2016
01679e5
more cleanup
edhartnett May 17, 2016
1728b3e
continued async development
edhartnett May 17, 2016
2e17460
continued async development
edhartnett May 17, 2016
f60fe96
continued async development
edhartnett May 17, 2016
149d94e
continued async development
edhartnett May 17, 2016
2810747
continued async development
edhartnett May 17, 2016
d9ef4b9
more async changes
edhartnett May 17, 2016
7417325
more async changes
edhartnett May 17, 2016
b3d7b94
more async changes
edhartnett May 17, 2016
a4be288
more async changes
edhartnett May 17, 2016
b61b5a3
more async changes
edhartnett May 17, 2016
a5d6df3
more async changes
edhartnett May 17, 2016
7ec0477
more async changes
edhartnett May 17, 2016
be7b7b4
more async changes
edhartnett May 17, 2016
cf375e1
more async changes
edhartnett May 17, 2016
7e01a84
got redef function working with async
edhartnett May 17, 2016
68c3068
created internal function because pnetcdf does not have inq_type()
edhartnett May 17, 2016
5f597a8
further development of async code
edhartnett May 17, 2016
46ba2cc
further development of async code
edhartnett May 17, 2016
ce91865
Added documentation for the Unit and Performance tests in PIO2. Fixed…
Katetc May 17, 2016
24a34ff
Merge pull request #68 from Katetc/master
Katetc May 17, 2016
cea8e39
first pass at PIOc_put_vars_tc()
edhartnett May 18, 2016
138876a
Merge branch 'master' into ejh_async2
edhartnett May 18, 2016
58b9466
put_vars with async
edhartnett May 18, 2016
fdd7d8b
more development of async code
edhartnett May 23, 2016
d6bfc03
more development of async changes
edhartnett May 23, 2016
32e3165
further development of async
edhartnett May 23, 2016
4d335b3
added file for varm functions
edhartnett May 23, 2016
7119c0b
return error for async use with varm
edhartnett May 23, 2016
2fe1f56
cleaned up put_var1 functions
edhartnett May 24, 2016
98eed4d
futher cleanup of var1 functions
edhartnett May 24, 2016
de1c4e7
got get_vars working
edhartnett May 26, 2016
e7eced0
got get_var/vara working
edhartnett May 26, 2016
696d403
got get_var1 working
edhartnett May 26, 2016
eecde10
Merge branch 'ejh_async2'
jedwards4b May 27, 2016
1ad2762
response to code review comments
edhartnett May 27, 2016
9ebc917
clean up
edhartnett May 27, 2016
3a205bb
turn on async for yellowstone
jedwards4b May 27, 2016
8a9e0e5
Merge pull request #70 from NCAR/ejh_async3
jedwards4b May 27, 2016
f1f9a06
removed use of MPI_Comm_create_group
edhartnett May 27, 2016
3671790
Merge pull request #71 from NCAR/ejh_async4
jedwards4b May 28, 2016
30e7878
took out log statement that was causing too much output
edhartnett May 29, 2016
a9c9029
took out logging statement
edhartnett May 30, 2016
30be388
trying to fix problem with put on some platforms
edhartnett May 31, 2016
751adee
took out use of log in fortran test
edhartnett May 31, 2016
5d1dba0
fixed error handling of MPI errors on transfer of parameter data to p…
edhartnett Jun 1, 2016
7b92cdb
more log messages to find bug
edhartnett Jun 2, 2016
0cd713c
added temporary mpi_intercomm_merge() function for MPI_SERIAL builds
edhartnett Jun 3, 2016
8585feb
temporarily turned off pnetcdf in test_intercomm.c
edhartnett Jun 3, 2016
b62a9bb
more logging statements
edhartnett Jun 3, 2016
4ff0a36
commented out extra declaration
edhartnett Jun 3, 2016
4e50dd0
changes to fix cdash tests, added logging to fortran
edhartnett Jun 4, 2016
e42ad0b
turned pnetcdf testing back on for test_intercomm.c
edhartnett Jun 4, 2016
2f2bb44
tryhing to isolate put problem
edhartnett Jun 6, 2016
378ac20
tryhing to isolate put problem
edhartnett Jun 6, 2016
b2f19be
tryhing to isolate put problem
edhartnett Jun 6, 2016
8a640f3
no longer run test_intercomm for serial builds
edhartnett Jun 6, 2016
5d0d400
changed type of num_elems from size_t to PIO_Offset
edhartnett Jun 6, 2016
611b76d
more logging to try and get enddef working on caldera
edhartnett Jun 7, 2016
5651c78
now MPI_abort does not overwrite ret_val
edhartnett Jun 7, 2016
c659512
clean up error handling
edhartnett Jun 7, 2016
5c49a3a
cleanup of error handling in file functions
edhartnett Jun 7, 2016
ab93ed0
cleanup of error handling in file functions
edhartnett Jun 7, 2016
e94b1fc
Merge pull request #72 from NCAR/ejh_test_error_handling
jedwards4b Jun 7, 2016
4a391ca
more logging statements to find bug
edhartnett Jun 8, 2016
07bf495
turned pnetcdf back on in test_intercomm
edhartnett Jun 8, 2016
26298e6
more log messages
edhartnett Jun 8, 2016
c871a94
more log messages
edhartnett Jun 8, 2016
7b4f744
more log messages
edhartnett Jun 8, 2016
7f17935
more log messages
edhartnett Jun 8, 2016
887f651
more log messages
edhartnett Jun 8, 2016
fcd502d
more log messages
edhartnett Jun 8, 2016
70238ae
more log messages
edhartnett Jun 8, 2016
f845325
more log messages
edhartnett Jun 8, 2016
abde5d2
more log messages
edhartnett Jun 8, 2016
09d5b65
more log messages
edhartnett Jun 8, 2016
08b7a7e
more log messages
edhartnett Jun 8, 2016
b3a83a3
more log messages
edhartnett Jun 8, 2016
50ab03b
more log messages
edhartnett Jun 8, 2016
386b641
compensate for poor handling of NULL for stride by pnetcdf
edhartnett Jun 8, 2016
612998f
more logging
edhartnett Jun 9, 2016
329777e
more logging
edhartnett Jun 9, 2016
be9af21
stopped faking the stride for puts
edhartnett Jun 9, 2016
985ba72
more log messages
edhartnett Jun 10, 2016
82d9faa
working on put issue
edhartnett Jun 10, 2016
617c65a
cleanup
edhartnett Jun 13, 2016
6c09c56
more cleanup
edhartnett Jun 13, 2016
1d705fc
Merge pull request #74 from NCAR/ejh_cleanup4
Katetc Jun 13, 2016
cadc332
breaking branch to test cdash building of branches
edhartnett Jun 13, 2016
995ebc5
more cleanup
edhartnett Jun 13, 2016
c1df0fb
more cleanup
edhartnett Jun 13, 2016
87e32a2
more cleanup
edhartnett Jun 13, 2016
bf1ed73
more cleanup
edhartnett Jun 13, 2016
cb8f4ee
Merge pull request #75 from NCAR/ejh_cleanup6
Katetc Jun 13, 2016
2559cf4
added logging statement to debug cdash problem
edhartnett Jun 14, 2016
1b7ffb6
Revert "Ejh cleanup6"
edhartnett Jun 14, 2016
046fc26
Merge pull request #76 from NCAR/revert-75-ejh_cleanup6
edhartnett Jun 14, 2016
08dc6ff
documentation and spacing cleanup
edhartnett Jun 15, 2016
ede6182
documentation fix
edhartnett Jun 15, 2016
a28ab94
Merge pull request #77 from NCAR/ejh_darray1
Katetc Jun 15, 2016
bce138f
starting to add darray test
edhartnett Jun 15, 2016
541a070
cleanout of test_darray
edhartnett Jun 15, 2016
0f1fe88
development of darray test
edhartnett Jun 15, 2016
4717e60
more work on darray test
edhartnett Jun 15, 2016
79de1e3
more work on darray test
edhartnett Jun 15, 2016
77152b4
more work on darray test
edhartnett Jun 15, 2016
e7dd43e
fixing problems when built without logging, took out unneeded msgs
edhartnett Jun 16, 2016
58cb4db
put messages back in until async build is the only build
edhartnett Jun 16, 2016
b7db2ac
getting non-async build to work
edhartnett Jun 16, 2016
6c968a0
Merge pull request #78 from NCAR/ejh_darray2
Katetc Jun 16, 2016
d827fa6
documentation and spacing changes
edhartnett Jun 20, 2016
5068c60
cleanup and documentation
edhartnett Jun 20, 2016
c902eb9
Merge pull request #81 from NCAR/ejh_darray3
edhartnett Jun 21, 2016
1e317dc
split off pio_darray_async.c
edhartnett Jun 21, 2016
80dfb55
added test_darray_async.c for async darray testing
edhartnett Jun 21, 2016
7cd49c1
added config.h include
edhartnett Jun 21, 2016
23b06b4
added some comments
edhartnett Jun 21, 2016
ecbc513
more documentation changes
edhartnett Jun 21, 2016
3114702
more comments, some code cleanup
edhartnett Jun 21, 2016
d6bd625
removed some dead code, improved comments
edhartnett Jun 21, 2016
ed31fb0
minor cleanup
edhartnett Jun 21, 2016
5831e9f
more comments
edhartnett Jun 21, 2016
7febfee
Merge pull request #84 from NCAR/ejh_darray4
Katetc Jun 22, 2016
ea39095
Merge pull request #7 from NCAR/master
Katetc Jul 28, 2016
004aeb9
Fixed doc build for async vs. non-async builds
edhartnett Aug 1, 2016
e51cceb
Comment and clean up
edhartnett Aug 1, 2016
469ae01
Merge pull request #87 from NCAR/ejh_docs
jedwards4b Aug 1, 2016
1c5f431
added PIOc_strerror() and test for it
edhartnett Aug 3, 2016
c0dd8dd
changed signature of PIOc_strerror()
edhartnett Aug 3, 2016
7f877f8
adding fortran interface to PIOc_strerror()
edhartnett Aug 3, 2016
86d23b9
added test for fortran pio_strerror
edhartnett Aug 3, 2016
1b6fff6
Merge pull request #88 from NCAR/ejh_strerr
Katetc Aug 4, 2016
65e731c
removed test that depended on changing netCDF error string
Aug 10, 2016
04f17b2
Merge pull request #91 from NCAR/ejh_fix_test_names
Katetc Aug 10, 2016
418c9ad
Merge pull request #8 from NCAR/master
Katetc Aug 12, 2016
941a4b8
Changes required for the new Hobart nag 6.1
Katetc Aug 12, 2016
81f373f
Merge pull request #92 from Katetc/master
Katetc Aug 12, 2016
4d798ad
Changes required for nightly cdash to work with new Hobart and Nag 6.1
Katetc Aug 12, 2016
1fe2631
Merge pull request #93 from Katetc/master
Katetc Aug 12, 2016
abfbee4
Merge branch 'ParallelIO_branch' (PIO2 master)
jayeshkrishna Aug 16, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
got inq_attid working for async
  • Loading branch information
edhartnett committed May 14, 2016
commit 5b140219be69862622ad1246fcba4bfe7ff308dd
55 changes: 55 additions & 0 deletions src/clib/pio_msg.c
Original file line number Diff line number Diff line change
@@ -411,6 +411,58 @@ int inq_attname_handler(iosystem_desc_t *ios)
return PIO_NOERR;
}

/** Handle attribute inquiry operations. This code only runs on IO
* tasks.
*
* @param ios pointer to the iosystem_desc_t.
* @param msg the message sent my the comp root task.
* @return PIO_NOERR for success, error code otherwise.
*/
int inq_attid_handler(iosystem_desc_t *ios)
{
int ncid;
int varid;
int attnum;
char *name;
int namelen;
int id, *idp = NULL;
char id_present;
int mpierr;
int ret;

LOG((1, "inq_attid_handler"));

/* Get the parameters for this function that the the comp master
* task is broadcasting. */
if ((mpierr = MPI_Bcast(&ncid, 1, MPI_INT, 0, ios->intercomm)))
return PIO_EIO;
if ((mpierr = MPI_Bcast(&varid, 1, MPI_INT, 0, ios->intercomm)))
return PIO_EIO;
if ((mpierr = MPI_Bcast(&namelen, 1, MPI_INT, ios->compmaster, ios->intercomm)))
return PIO_EIO;
if (!(name = malloc((namelen + 1) * sizeof(char))))
return PIO_ENOMEM;
if ((mpierr = MPI_Bcast(name, namelen + 1, MPI_CHAR, ios->compmaster, ios->intercomm)))
return PIO_EIO;
if ((mpierr = MPI_Bcast(&id_present, 1, MPI_CHAR, 0, ios->intercomm)))
return PIO_EIO;
LOG((2, "inq_attid_handler got ncid = %d varid = %d attnum = %d id_present = %d",
ncid, varid, attnum, id_present));

/* Match NULLs in collective function call. */
if (id_present)
idp = &id;

/* Call the function to learn about the attribute. */
if ((ret = PIOc_inq_attid(ncid, varid, name, idp)))
return ret;

/* Free resources. */
free(name);

return PIO_NOERR;
}

/** Handle attribute operations. This code only runs on IO tasks.
*
* @param ios pointer to the iosystem_desc_t.
@@ -1104,6 +1156,9 @@ int pio_msg_handler(int io_rank, int component_count, iosystem_desc_t *iosys)
case PIO_MSG_INQ_ATTNAME:
inq_attname_handler(my_iosys);
break;
case PIO_MSG_INQ_ATTID:
inq_attid_handler(my_iosys);
break;
case PIO_MSG_INITDECOMP_DOF:
initdecomp_dof_handler(my_iosys);
break;
81 changes: 50 additions & 31 deletions src/clib/pio_nc_async.c
Original file line number Diff line number Diff line change
@@ -1042,47 +1042,66 @@ int PIOc_inq_attname(int ncid, int varid, int attnum, char *name)
* @param idp a pointer that will get the id of the variable or attribute.
* @return PIO_NOERR for success, error code otherwise. See PIOc_Set_File_Error_Handling
*/
int PIOc_inq_attid (int ncid, int varid, const char *name, int *idp)
int PIOc_inq_attid(int ncid, int varid, const char *name, int *idp)
{
int ierr = PIO_NOERR;
int msg = PIO_MSG_INQ_ATTID;
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 mpierr = MPI_SUCCESS, mpierr2; /** Return code from MPI function codes. */
iosystem_desc_t *ios;
file_desc_t *file;

/* User must provide name shorter than NC_MAX_NAME +1. */
if (!name || strlen(name) > NC_MAX_NAME)
return PIO_EINVAL;

LOG((1, "PIOc_inq_attid ncid = %d varid = %d name = %s", ncid, varid, name));

/* Find the info about this file. */
if (!(file = pio_get_file_from_id(ncid)))
return PIO_EBADID;
ios = file->iosystem;

if(ios->async_interface && ! ios->ioproc){
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 async is in use, and this is not an IO task, bcast the parameters. */
if (ios->async_interface)
{
if (!ios->ioproc)
{
int msg = PIO_MSG_INQ_ATTID;
int namelen = strlen(name);
char id_present = idp ? true : false;

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

if (!mpierr)
mpierr = MPI_Bcast(&file->fh, 1, MPI_INT, ios->compmaster, ios->intercomm);
if (!mpierr)
mpierr = MPI_Bcast(&varid, 1, MPI_INT, ios->compmaster, ios->intercomm);
if (!mpierr)
mpierr = MPI_Bcast(&namelen, 1, MPI_INT, ios->compmaster, ios->intercomm);
if (!mpierr)
mpierr = MPI_Bcast((char *)name, namelen + 1, MPI_CHAR, ios->compmaster, ios->intercomm);
if (!mpierr)
mpierr = MPI_Bcast(&id_present, 1, MPI_CHAR, ios->compmaster, ios->intercomm);
}

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

if(ios->ioproc){
switch(file->iotype){
#ifdef _NETCDF
#ifdef _NETCDF4
case PIO_IOTYPE_NETCDF4P:
ierr = nc_inq_attid(file->fh, varid, name, idp);;
break;
case PIO_IOTYPE_NETCDF4C:
#endif
case PIO_IOTYPE_NETCDF:
if(ios->io_rank==0){
ierr = nc_inq_attid(file->fh, varid, name, idp);;
}
break;
#endif
/* If this is an IO task, then call the netCDF function. */
if (ios->ioproc)
{
#ifdef _PNETCDF
case PIO_IOTYPE_PNETCDF:
if (file->iotype == PIO_IOTYPE_PNETCDF)
ierr = ncmpi_inq_attid(file->fh, varid, name, idp);;
break;
#endif
default:
ierr = iotype_error(file->iotype,__FILE__,__LINE__);
}
#endif /* _PNETCDF */
#ifdef _NETCDF
if (file->iotype != PIO_IOTYPE_PNETCDF && file->do_io)
ierr = nc_inq_attid(file->fh, varid, name, idp);;
#endif /* _NETCDF */
LOG((2, "PIOc_inq_attname netcdf call returned %d", ierr));
}

/* Handle MPI errors. */
@@ -1094,7 +1113,7 @@ int PIOc_inq_attid (int ncid, int varid, const char *name, int *idp)
if (!ierr)
{
if (idp)
if ((mpierr = MPI_Bcast(idp , 1, MPI_INT, ios->ioroot, ios->my_comm)))
if ((mpierr = MPI_Bcast(idp, 1, MPI_INT, ios->ioroot, ios->my_comm)))
check_mpi(file, mpierr, __FILE__, __LINE__);
}

5 changes: 5 additions & 0 deletions tests/unit/test_intercomm.c
Original file line number Diff line number Diff line change
@@ -184,6 +184,7 @@ check_file(int iosysid, int format, char *filename, int my_rank, int verbose)
nc_type atttype;
PIO_Offset attlen;
char myattname[NC_MAX_NAME + 1];
int myid;
if ((ret = PIOc_inq_att(ncid, NC_GLOBAL, ATT_NAME, &atttype, &attlen)))
ERR(ret);
if (atttype != NC_INT || attlen != 1)
@@ -196,6 +197,10 @@ check_file(int iosysid, int format, char *filename, int my_rank, int verbose)
ERR(ret);
if (strcmp(ATT_NAME, myattname))
ERR(ERR_WRONG);
if ((ret = PIOc_inq_attid(ncid, NC_GLOBAL, ATT_NAME, &myid)))
ERR(ret);
if (myid != 0)
ERR(ERR_WRONG);
if ((ret = PIOc_get_att_int(ncid, NC_GLOBAL, ATT_NAME, &att_data)))
ERR(ret);
if (verbose)