2004-07-21 05:41:44 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
2007-02-07 22:56:24 +08:00
|
|
|
* Copyright by The HDF Group. *
|
2004-07-21 05:41:44 +08:00
|
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
|
|
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
2004-07-21 05:41:44 +08:00
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
|
|
|
#include "testphdf5.h"
|
2004-07-23 04:46:27 +08:00
|
|
|
#include "H5Dprivate.h"
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
#define HYPER 1
|
|
|
|
#define POINT 2
|
2020-04-21 07:12:00 +08:00
|
|
|
#define ALL 3
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2004-07-23 04:46:27 +08:00
|
|
|
/* some commonly used routines for collective chunk IO tests*/
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2004-12-29 22:26:20 +08:00
|
|
|
static void ccslab_set(int mpi_rank,int mpi_size,hsize_t start[],hsize_t count[],
|
2005-10-18 04:48:16 +08:00
|
|
|
hsize_t stride[],hsize_t block[],int mode);
|
2004-07-23 04:46:27 +08:00
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
static void ccdataset_fill(hsize_t start[],hsize_t count[],
|
2014-03-08 03:12:20 +08:00
|
|
|
hsize_t stride[],hsize_t block[],DATATYPE*dataset,
|
|
|
|
int mem_selection);
|
2004-07-23 04:46:27 +08:00
|
|
|
|
2004-12-29 22:26:20 +08:00
|
|
|
static void ccdataset_print(hsize_t start[],hsize_t block[],DATATYPE*dataset);
|
2004-07-23 04:46:27 +08:00
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
static int ccdataset_vrfy(hsize_t start[], hsize_t count[], hsize_t stride[],
|
2014-03-08 03:12:20 +08:00
|
|
|
hsize_t block[], DATATYPE *dataset, DATATYPE *original,
|
|
|
|
int mem_selection);
|
2004-07-23 04:46:27 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
static void coll_chunktest(const char* filename, int chunk_factor, int select_factor,
|
|
|
|
int api_option, int file_selection, int mem_selection, int mode);
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk1
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2005-10-18 04:48:16 +08:00
|
|
|
selection with a single chunk
|
2004-07-21 05:41:44 +08:00
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
2005-10-18 04:48:16 +08:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: One big singluar selection inside one chunk
|
2008-09-16 23:52:51 +08:00
|
|
|
* Two dimensions,
|
2005-10-18 04:48:16 +08:00
|
|
|
*
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* dim1 = SPACE_DIM1(5760)*mpi_size
|
2005-10-18 04:48:16 +08:00
|
|
|
* dim2 = SPACE_DIM2(3)
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* count0 = SPACE_DIM1(5760)
|
2005-10-18 04:48:16 +08:00
|
|
|
* count1 = SPACE_DIM2(3)
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
2005-10-18 04:48:16 +08:00
|
|
|
* start1 = 0
|
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
void
|
2004-07-23 04:46:27 +08:00
|
|
|
coll_chunk1(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_CONT, API_NONE, POINT, HYPER, IN_ORDER);
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk2
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular DISJOINT
|
2005-10-18 04:48:16 +08:00
|
|
|
selection with a single chunk
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: many disjoint selections inside one chunk
|
2008-09-16 23:52:51 +08:00
|
|
|
* Two dimensions,
|
2005-10-18 04:48:16 +08:00
|
|
|
*
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* dim1 = SPACE_DIM1*mpi_size(5760)
|
2005-10-18 04:48:16 +08:00
|
|
|
* dim2 = SPACE_DIM2(3)
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 3 for all dimensions
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* count0 = SPACE_DIM1/stride0(5760/3)
|
2005-10-18 04:48:16 +08:00
|
|
|
* count1 = SPACE_DIM2/stride(3/3 = 1)
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
2005-10-18 04:48:16 +08:00
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2005-10-18 04:48:16 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
2004-07-21 05:41:44 +08:00
|
|
|
void
|
2004-07-23 04:46:27 +08:00
|
|
|
coll_chunk2(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_DISCONT, API_NONE, POINT, HYPER, IN_ORDER);
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk3
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2005-10-18 04:48:16 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
2005-10-18 04:48:16 +08:00
|
|
|
* dim2 = SPACE_DIM2(3)
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* chunk_dim1 = SPACE_DIM1
|
2005-10-18 04:48:16 +08:00
|
|
|
* chunk_dim2 = dim2/2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* count0 = SPACE_DIM1
|
2005-10-18 04:48:16 +08:00
|
|
|
* count1 = SPACE_DIM2(3)
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
2005-10-18 04:48:16 +08:00
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2005-10-18 04:48:16 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
void
|
2004-07-23 04:46:27 +08:00
|
|
|
coll_chunk3(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
|
|
|
int mpi_size;
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2009-03-11 03:00:39 +08:00
|
|
|
MPI_Comm_size(MPI_COMM_WORLD, &mpi_size);
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, mpi_size, BYROW_CONT, API_NONE, POINT, HYPER, IN_ORDER);
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
|
2006-02-17 01:12:08 +08:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk4
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-02-17 01:12:08 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
2006-02-17 01:12:08 +08:00
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* count0 = SPACE_DIM1
|
2006-02-17 01:12:08 +08:00
|
|
|
* count1 = SPACE_DIM2(3)
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
2006-02-17 01:12:08 +08:00
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-02-17 01:12:08 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk4(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-02-17 01:12:08 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 1, BYROW_SELECTNONE, API_NONE, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk4
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-03-29 22:35:26 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk5(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_HARD, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk6
|
|
|
|
*
|
2012-10-31 00:28:17 +08:00
|
|
|
* Purpose: Test direct request for multi-chunk-io.
|
|
|
|
* Wrapper to test the collective chunk IO for regular JOINT
|
|
|
|
* selection with at least number of 2*mpi_size chunks
|
|
|
|
* Test for direct to Multi Chunk I/O.
|
2006-03-29 22:35:26 +08:00
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk6(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_HARD, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk7
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-03-29 22:35:26 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk7(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_TRUE, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk8
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-03-29 22:35:26 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk8(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_LINK_FALSE, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk9
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-03-29 22:35:26 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk9(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTUNBALANCE, API_MULTI_COLL, POINT, HYPER, IN_ORDER);
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunk10
|
|
|
|
*
|
2008-09-16 23:52:51 +08:00
|
|
|
* Purpose: Wrapper to test the collective chunk IO for regular JOINT
|
2006-03-29 22:35:26 +08:00
|
|
|
selection with at least number of 2*mpi_size chunks
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------
|
|
|
|
* Descriptions for the selection: one singular selection accross many chunks
|
|
|
|
* Two dimensions, Num of chunks = 2* mpi_size
|
|
|
|
*
|
|
|
|
* dim1 = SPACE_DIM1*mpi_size
|
|
|
|
* dim2 = SPACE_DIM2
|
|
|
|
* chunk_dim1 = dim1
|
|
|
|
* chunk_dim2 = dim2
|
|
|
|
* block = 1 for all dimensions
|
|
|
|
* stride = 1 for all dimensions
|
|
|
|
* count0 = SPACE_DIM1
|
|
|
|
* count1 = SPACE_DIM2(3)
|
|
|
|
* start0 = mpi_rank*SPACE_DIM1
|
|
|
|
* start1 = 0
|
2008-09-16 23:52:51 +08:00
|
|
|
*
|
2006-03-29 22:35:26 +08:00
|
|
|
* ------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
coll_chunk10(void)
|
|
|
|
{
|
2009-03-11 03:00:39 +08:00
|
|
|
const char *filename = GetTestParameters();
|
2006-03-29 22:35:26 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, HYPER, HYPER, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, HYPER, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, ALL, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, POINT, OUT_OF_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, HYPER, OUT_OF_ORDER);
|
|
|
|
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, ALL, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, POINT, IN_ORDER);
|
|
|
|
coll_chunktest(filename, 4, BYROW_SELECTINCHUNK, API_MULTI_IND, POINT, HYPER, IN_ORDER);
|
2006-02-17 01:12:08 +08:00
|
|
|
}
|
|
|
|
|
2005-07-13 03:26:26 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
* Function: coll_chunktest
|
|
|
|
*
|
|
|
|
* Purpose: The real testing routine for regular selection of collective
|
|
|
|
chunking storage
|
|
|
|
testing both write and read,
|
2008-09-16 23:52:51 +08:00
|
|
|
If anything fails, it may be read or write. There is no
|
2005-10-18 04:48:16 +08:00
|
|
|
separation test between read and write.
|
|
|
|
*
|
|
|
|
* Return: Success: 0
|
|
|
|
*
|
|
|
|
* Failure: -1
|
|
|
|
*
|
2012-10-31 00:28:17 +08:00
|
|
|
* Modifications:
|
|
|
|
* Remove invalid temporary property checkings for API_LINK_HARD and
|
|
|
|
* API_LINK_TRUE cases.
|
|
|
|
* Programmer: Jonathan Kim
|
|
|
|
* Date: 2012-10-10
|
|
|
|
*
|
2005-10-18 04:48:16 +08:00
|
|
|
* Programmer: Unknown
|
|
|
|
* July 12th, 2004
|
|
|
|
*
|
|
|
|
* Modifications:
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2004-07-23 04:46:27 +08:00
|
|
|
static void
|
2005-10-18 04:48:16 +08:00
|
|
|
coll_chunktest(const char* filename,
|
|
|
|
int chunk_factor,
|
2006-03-29 22:35:26 +08:00
|
|
|
int select_factor,
|
2014-03-08 03:12:20 +08:00
|
|
|
int api_option,
|
|
|
|
int file_selection,
|
|
|
|
int mem_selection,
|
|
|
|
int mode)
|
2009-03-11 03:00:39 +08:00
|
|
|
{
|
2014-03-08 03:12:20 +08:00
|
|
|
hid_t file, dataset, file_dataspace, mem_dataspace;
|
2004-07-21 05:41:44 +08:00
|
|
|
hid_t acc_plist,xfer_plist,crp_plist;
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
hsize_t dims[RANK], chunk_dims[RANK];
|
2005-08-14 04:53:35 +08:00
|
|
|
int* data_array1 = NULL;
|
2004-07-21 05:41:44 +08:00
|
|
|
int* data_origin1 = NULL;
|
2005-10-18 04:48:16 +08:00
|
|
|
|
|
|
|
hsize_t start[RANK],count[RANK],stride[RANK],block[RANK];
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
#ifdef H5_HAVE_INSTRUMENTED_LIBRARY
|
|
|
|
unsigned prop_value;
|
|
|
|
#endif /* H5_HAVE_INSTRUMENTED_LIBRARY */
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
int mpi_size,mpi_rank;
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
herr_t status;
|
|
|
|
MPI_Comm comm = MPI_COMM_WORLD;
|
|
|
|
MPI_Info info = MPI_INFO_NULL;
|
|
|
|
|
2014-03-11 02:03:35 +08:00
|
|
|
size_t num_points; /* for point selection */
|
|
|
|
hsize_t *coords = NULL; /* for point selection */
|
|
|
|
hsize_t current_dims; /* for point selection */
|
2014-03-08 03:12:20 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* set up MPI parameters */
|
2004-07-23 04:46:27 +08:00
|
|
|
MPI_Comm_size(comm,&mpi_size);
|
|
|
|
MPI_Comm_rank(comm,&mpi_rank);
|
2004-07-21 05:41:44 +08:00
|
|
|
|
|
|
|
/* Create the data space */
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2014-03-22 07:02:24 +08:00
|
|
|
acc_plist = create_faccess_plist(comm,info,facc_type);
|
2004-07-21 05:41:44 +08:00
|
|
|
VRFY((acc_plist >= 0),"");
|
|
|
|
|
|
|
|
file = H5Fcreate(filename,H5F_ACC_TRUNC,H5P_DEFAULT,acc_plist);
|
|
|
|
VRFY((file >= 0),"H5Fcreate succeeded");
|
|
|
|
|
|
|
|
status = H5Pclose(acc_plist);
|
|
|
|
VRFY((status >= 0),"");
|
|
|
|
|
|
|
|
/* setup dimensionality object */
|
2020-01-24 05:12:00 +08:00
|
|
|
dims[0] = (hsize_t)(SPACE_DIM1*mpi_size);
|
2005-10-18 04:48:16 +08:00
|
|
|
dims[1] = SPACE_DIM2;
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* allocate memory for data buffer */
|
2013-10-31 15:44:00 +08:00
|
|
|
data_array1 = (int *)HDmalloc(dims[0] * dims[1] * sizeof(int));
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((data_array1 != NULL), "data_array1 malloc succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* set up dimensions of the slab this process accesses */
|
|
|
|
ccslab_set(mpi_rank, mpi_size, start, count, stride, block, select_factor);
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
/* set up the coords array selection */
|
|
|
|
num_points = block[0] * block[1] * count[0] * count[1];
|
|
|
|
coords = (hsize_t *)HDmalloc(num_points * RANK * sizeof(hsize_t));
|
|
|
|
VRFY((coords != NULL), "coords malloc succeeded");
|
|
|
|
point_set(start, count, stride, block, num_points, coords, mode);
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
file_dataspace = H5Screate_simple(2, dims, NULL);
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
VRFY((file_dataspace >= 0), "file dataspace created succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
if(ALL != mem_selection) {
|
|
|
|
mem_dataspace = H5Screate_simple(2, dims, NULL);
|
|
|
|
VRFY((mem_dataspace >= 0), "mem dataspace created succeeded");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
current_dims = num_points;
|
|
|
|
mem_dataspace = H5Screate_simple (1, ¤t_dims, NULL);
|
|
|
|
VRFY((mem_dataspace >= 0), "mem_dataspace create succeeded");
|
|
|
|
}
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
crp_plist = H5Pcreate(H5P_DATASET_CREATE);
|
|
|
|
VRFY((crp_plist >= 0),"");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* Set up chunk information. */
|
2020-01-24 05:12:00 +08:00
|
|
|
chunk_dims[0] = dims[0]/(hsize_t)chunk_factor;
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* to decrease the testing time, maintain bigger chunk size */
|
|
|
|
(chunk_factor == 1) ? (chunk_dims[1] = SPACE_DIM2) : (chunk_dims[1] = SPACE_DIM2/2);
|
|
|
|
status = H5Pset_chunk(crp_plist, 2, chunk_dims);
|
|
|
|
VRFY((status >= 0),"chunk creation property list succeeded");
|
2005-07-13 03:26:26 +08:00
|
|
|
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
dataset = H5Dcreate2(file, DSET_COLLECTIVE_CHUNK_NAME, H5T_NATIVE_INT,
|
2014-03-08 03:12:20 +08:00
|
|
|
file_dataspace, H5P_DEFAULT, crp_plist, H5P_DEFAULT);
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((dataset >= 0),"dataset created succeeded");
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pclose(crp_plist);
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
VRFY((status >= 0), "");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/*put some trivial data in the data array */
|
2014-03-08 03:12:20 +08:00
|
|
|
ccdataset_fill(start, stride, count,block, data_array1, mem_selection);
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
MESG("data_array initialized");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
switch (file_selection) {
|
|
|
|
case HYPER:
|
|
|
|
status = H5Sselect_hyperslab(file_dataspace, H5S_SELECT_SET, start, stride, count, block);
|
|
|
|
VRFY((status >= 0),"hyperslab selection succeeded");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case POINT:
|
|
|
|
if (num_points) {
|
|
|
|
status = H5Sselect_elements(file_dataspace, H5S_SELECT_SET, num_points, coords);
|
|
|
|
VRFY((status >= 0),"Element selection succeeded");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
status = H5Sselect_none(file_dataspace);
|
|
|
|
VRFY((status >= 0),"none selection succeeded");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ALL:
|
|
|
|
status = H5Sselect_all(file_dataspace);
|
|
|
|
VRFY((status >= 0), "H5Sselect_all succeeded");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (mem_selection) {
|
|
|
|
case HYPER:
|
|
|
|
status = H5Sselect_hyperslab(mem_dataspace, H5S_SELECT_SET, start, stride, count, block);
|
|
|
|
VRFY((status >= 0),"hyperslab selection succeeded");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case POINT:
|
|
|
|
if (num_points) {
|
|
|
|
status = H5Sselect_elements(mem_dataspace, H5S_SELECT_SET, num_points, coords);
|
|
|
|
VRFY((status >= 0),"Element selection succeeded");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
status = H5Sselect_none(mem_dataspace);
|
|
|
|
VRFY((status >= 0),"none selection succeeded");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ALL:
|
|
|
|
status = H5Sselect_all(mem_dataspace);
|
|
|
|
VRFY((status >= 0), "H5Sselect_all succeeded");
|
|
|
|
break;
|
|
|
|
}
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* set up the collective transfer property list */
|
|
|
|
xfer_plist = H5Pcreate(H5P_DATASET_XFER);
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
VRFY((xfer_plist >= 0), "");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pset_dxpl_mpio(xfer_plist, H5FD_MPIO_COLLECTIVE);
|
|
|
|
VRFY((status>= 0),"MPIO collective transfer property succeeded");
|
2006-08-09 11:16:07 +08:00
|
|
|
if(dxfer_coll_type == DXFER_INDEPENDENT_IO) {
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
status = H5Pset_dxpl_mpio_collective_opt(xfer_plist, H5FD_MPIO_INDIVIDUAL_IO);
|
2006-08-09 11:16:07 +08:00
|
|
|
VRFY((status>= 0),"set independent IO collectively succeeded");
|
|
|
|
}
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
switch(api_option){
|
|
|
|
case API_LINK_HARD:
|
2006-06-04 02:40:47 +08:00
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt(xfer_plist,H5FD_MPIO_CHUNK_ONE_IO);
|
2006-03-29 22:35:26 +08:00
|
|
|
VRFY((status>= 0),"collective chunk optimization succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
case API_MULTI_HARD:
|
2006-06-04 02:40:47 +08:00
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt(xfer_plist,H5FD_MPIO_CHUNK_MULTI_IO);
|
2006-03-29 22:35:26 +08:00
|
|
|
VRFY((status>= 0),"collective chunk optimization succeeded ");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
case API_LINK_TRUE:
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_num(xfer_plist,2);
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk number succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
case API_LINK_FALSE:
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_num(xfer_plist,6);
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk number succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
case API_MULTI_COLL:
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_num(xfer_plist,8);/* make sure it is using multi-chunk IO */
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk number succeeded");
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_ratio(xfer_plist,50);
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk ratio succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
case API_MULTI_IND:
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_num(xfer_plist,8);/* make sure it is using multi-chunk IO */
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk number succeeded");
|
|
|
|
status = H5Pset_dxpl_mpio_chunk_opt_ratio(xfer_plist,100);
|
|
|
|
VRFY((status>= 0),"collective chunk optimization set chunk ratio succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
default:
|
2014-03-08 03:12:20 +08:00
|
|
|
;
|
2008-09-16 23:52:51 +08:00
|
|
|
}
|
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
#ifdef H5_HAVE_INSTRUMENTED_LIBRARY
|
|
|
|
if(facc_type == FACC_MPIO) {
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
switch(api_option) {
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_LINK_HARD:
|
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_LINK_HARD_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_HARD:
|
2008-09-16 23:52:51 +08:00
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_MULTI_HARD_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_LINK_TRUE:
|
2008-09-16 23:52:51 +08:00
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_LINK_NUM_TRUE_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_LINK_FALSE:
|
2008-09-16 23:52:51 +08:00
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_LINK_NUM_FALSE_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_COLL:
|
2008-09-16 23:52:51 +08:00
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_MULTI_RATIO_COLL_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_IND:
|
2008-09-16 23:52:51 +08:00
|
|
|
prop_value = H5D_XFER_COLL_CHUNK_DEF;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
status = H5Pinsert2(xfer_plist, H5D_XFER_COLL_CHUNK_MULTI_RATIO_IND_NAME, H5D_XFER_COLL_CHUNK_SIZE, &prop_value,
|
|
|
|
NULL, NULL, NULL, NULL, NULL, NULL);
|
2006-11-03 00:01:54 +08:00
|
|
|
VRFY((status >= 0),"testing property list inserted succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
default:
|
[svn-r14204] Description:
Move H5Pinsert() out of old "compat v1.6" section and into API
versioning, switching internal usage to H5Pinsert2().
Add regression test for H5Pinsert1()
Clean up some other minor warnings.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 09:29:45 +08:00
|
|
|
;
|
2008-09-16 23:52:51 +08:00
|
|
|
}
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
#endif
|
2008-09-16 23:52:51 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* write data collectively */
|
2014-03-08 03:12:20 +08:00
|
|
|
status = H5Dwrite(dataset, H5T_NATIVE_INT, mem_dataspace, file_dataspace,
|
2005-10-18 04:48:16 +08:00
|
|
|
xfer_plist, data_array1);
|
|
|
|
VRFY((status >= 0),"dataset write succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2006-03-29 22:35:26 +08:00
|
|
|
#ifdef H5_HAVE_INSTRUMENTED_LIBRARY
|
|
|
|
if(facc_type == FACC_MPIO) {
|
2006-11-03 00:01:54 +08:00
|
|
|
switch(api_option){
|
|
|
|
case API_LINK_HARD:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_LINK_HARD_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
2012-10-31 00:28:17 +08:00
|
|
|
VRFY((prop_value == 0),"API to set LINK COLLECTIVE IO directly succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_HARD:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_MULTI_HARD_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
2012-10-31 00:28:17 +08:00
|
|
|
VRFY((prop_value == 0),"API to set MULTI-CHUNK COLLECTIVE IO optimization succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_LINK_TRUE:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_LINK_NUM_TRUE_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
2012-10-31 00:28:17 +08:00
|
|
|
VRFY((prop_value == 0),"API to set LINK COLLECTIVE IO succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_LINK_FALSE:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_LINK_NUM_FALSE_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
|
|
|
VRFY((prop_value == 0),"API to set LINK IO transferring to multi-chunk IO succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_COLL:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_MULTI_RATIO_COLL_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
|
|
|
VRFY((prop_value == 0),"API to set MULTI-CHUNK COLLECTIVE IO with optimization succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
case API_MULTI_IND:
|
|
|
|
status = H5Pget(xfer_plist,H5D_XFER_COLL_CHUNK_MULTI_RATIO_IND_NAME,&prop_value);
|
|
|
|
VRFY((status >= 0),"testing property list get succeeded");
|
|
|
|
VRFY((prop_value == 0),"API to set MULTI-CHUNK IO transferring to independent IO succeeded");
|
2014-03-08 03:12:20 +08:00
|
|
|
break;
|
|
|
|
|
2006-11-03 00:01:54 +08:00
|
|
|
default:
|
|
|
|
;
|
2008-09-16 23:52:51 +08:00
|
|
|
}
|
2006-03-29 22:35:26 +08:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Dclose(dataset);
|
|
|
|
VRFY((status >= 0),"");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pclose(xfer_plist);
|
|
|
|
VRFY((status >= 0),"property list closed");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Sclose(file_dataspace);
|
|
|
|
VRFY((status >= 0),"");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
status = H5Sclose(mem_dataspace);
|
|
|
|
VRFY((status >= 0),"");
|
|
|
|
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Fclose(file);
|
|
|
|
VRFY((status >= 0),"");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
if (data_array1) HDfree(data_array1);
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* Use collective read to verify the correctness of collective write. */
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* allocate memory for data buffer */
|
2013-10-31 15:44:00 +08:00
|
|
|
data_array1 = (int *)HDmalloc(dims[0]*dims[1]*sizeof(int));
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((data_array1 != NULL), "data_array1 malloc succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* allocate memory for data buffer */
|
2013-10-31 15:44:00 +08:00
|
|
|
data_origin1 = (int *)HDmalloc(dims[0]*dims[1]*sizeof(int));
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((data_origin1 != NULL), "data_origin1 malloc succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-22 07:02:24 +08:00
|
|
|
acc_plist = create_faccess_plist(comm, info, facc_type);
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((acc_plist >= 0),"MPIO creation property list succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
file = H5Fopen(filename,H5F_ACC_RDONLY,acc_plist);
|
|
|
|
VRFY((file >= 0),"H5Fcreate succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pclose(acc_plist);
|
|
|
|
VRFY((status >= 0),"");
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* open the collective dataset*/
|
[svn-r14193] Description:
Make H5Dopen versioned and change all internal usage to use H5Dopen2
Add simple regression test for H5Dopen1
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-09 03:59:36 +08:00
|
|
|
dataset = H5Dopen2(file, DSET_COLLECTIVE_CHUNK_NAME, H5P_DEFAULT);
|
2005-10-18 04:48:16 +08:00
|
|
|
VRFY((dataset >= 0), "");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* set up dimensions of the slab this process accesses */
|
|
|
|
ccslab_set(mpi_rank, mpi_size, start, count, stride, block, select_factor);
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
/* obtain the file and mem dataspace*/
|
2005-10-18 04:48:16 +08:00
|
|
|
file_dataspace = H5Dget_space (dataset);
|
|
|
|
VRFY((file_dataspace >= 0), "");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
if (ALL != mem_selection) {
|
|
|
|
mem_dataspace = H5Dget_space (dataset);
|
|
|
|
VRFY((mem_dataspace >= 0), "");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
current_dims = num_points;
|
|
|
|
mem_dataspace = H5Screate_simple (1, ¤t_dims, NULL);
|
|
|
|
VRFY((mem_dataspace >= 0), "mem_dataspace create succeeded");
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (file_selection) {
|
|
|
|
case HYPER:
|
|
|
|
status = H5Sselect_hyperslab(file_dataspace, H5S_SELECT_SET, start, stride, count, block);
|
|
|
|
VRFY((status >= 0),"hyperslab selection succeeded");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case POINT:
|
|
|
|
if (num_points) {
|
|
|
|
status = H5Sselect_elements(file_dataspace, H5S_SELECT_SET, num_points, coords);
|
|
|
|
VRFY((status >= 0),"Element selection succeeded");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
status = H5Sselect_none(file_dataspace);
|
|
|
|
VRFY((status >= 0),"none selection succeeded");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ALL:
|
|
|
|
status = H5Sselect_all(file_dataspace);
|
|
|
|
VRFY((status >= 0), "H5Sselect_all succeeded");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (mem_selection) {
|
|
|
|
case HYPER:
|
|
|
|
status = H5Sselect_hyperslab(mem_dataspace, H5S_SELECT_SET, start, stride, count, block);
|
|
|
|
VRFY((status >= 0),"hyperslab selection succeeded");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case POINT:
|
|
|
|
if (num_points) {
|
|
|
|
status = H5Sselect_elements(mem_dataspace, H5S_SELECT_SET, num_points, coords);
|
|
|
|
VRFY((status >= 0),"Element selection succeeded");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
status = H5Sselect_none(mem_dataspace);
|
|
|
|
VRFY((status >= 0),"none selection succeeded");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ALL:
|
|
|
|
status = H5Sselect_all(mem_dataspace);
|
|
|
|
VRFY((status >= 0), "H5Sselect_all succeeded");
|
|
|
|
break;
|
|
|
|
}
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* fill dataset with test data */
|
2014-03-08 03:12:20 +08:00
|
|
|
ccdataset_fill(start, stride,count,block, data_origin1, mem_selection);
|
2005-10-18 04:48:16 +08:00
|
|
|
xfer_plist = H5Pcreate (H5P_DATASET_XFER);
|
|
|
|
VRFY((xfer_plist >= 0),"");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pset_dxpl_mpio(xfer_plist, H5FD_MPIO_COLLECTIVE);
|
|
|
|
VRFY((status>= 0),"MPIO collective transfer property succeeded");
|
2006-08-09 11:16:07 +08:00
|
|
|
if(dxfer_coll_type == DXFER_INDEPENDENT_IO) {
|
|
|
|
status = H5Pset_dxpl_mpio_collective_opt(xfer_plist,H5FD_MPIO_INDIVIDUAL_IO);
|
|
|
|
VRFY((status>= 0),"set independent IO collectively succeeded");
|
|
|
|
}
|
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
status = H5Dread(dataset, H5T_NATIVE_INT, mem_dataspace, file_dataspace,
|
2005-10-18 04:48:16 +08:00
|
|
|
xfer_plist, data_array1);
|
|
|
|
VRFY((status >=0),"dataset read succeeded");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* verify the read data with original expected data */
|
2014-03-08 03:12:20 +08:00
|
|
|
status = ccdataset_vrfy(start, count, stride, block, data_array1, data_origin1, mem_selection);
|
2005-10-18 04:48:16 +08:00
|
|
|
if (status) nerrors++;
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
status = H5Pclose(xfer_plist);
|
|
|
|
VRFY((status >= 0),"property list closed");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* close dataset collectively */
|
|
|
|
status=H5Dclose(dataset);
|
2014-03-08 03:12:20 +08:00
|
|
|
VRFY((status >= 0), "H5Dclose");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* release all IDs created */
|
2014-03-08 03:12:20 +08:00
|
|
|
status = H5Sclose(file_dataspace);
|
|
|
|
VRFY((status >= 0),"H5Sclose");
|
|
|
|
|
|
|
|
status = H5Sclose(mem_dataspace);
|
|
|
|
VRFY((status >= 0),"H5Sclose");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* close the file collectively */
|
2014-03-08 03:12:20 +08:00
|
|
|
status = H5Fclose(file);
|
|
|
|
VRFY((status >= 0),"H5Fclose");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* release data buffers */
|
2014-03-11 02:03:35 +08:00
|
|
|
if(coords) HDfree(coords);
|
|
|
|
if(data_array1) HDfree(data_array1);
|
|
|
|
if(data_origin1) HDfree(data_origin1);
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
/* Set up the selection */
|
2004-07-23 04:46:27 +08:00
|
|
|
static void
|
2008-09-16 23:52:51 +08:00
|
|
|
ccslab_set(int mpi_rank,
|
|
|
|
int mpi_size,
|
|
|
|
hsize_t start[],
|
2005-10-18 04:48:16 +08:00
|
|
|
hsize_t count[],
|
2008-09-16 23:52:51 +08:00
|
|
|
hsize_t stride[],
|
|
|
|
hsize_t block[],
|
2005-10-18 04:48:16 +08:00
|
|
|
int mode)
|
2004-07-21 05:41:44 +08:00
|
|
|
{
|
2006-03-24 05:18:02 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
switch (mode){
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
case BYROW_CONT:
|
|
|
|
/* Each process takes a slabs of rows. */
|
2005-10-18 04:48:16 +08:00
|
|
|
block[0] = 1;
|
|
|
|
block[1] = 1;
|
|
|
|
stride[0] = 1;
|
|
|
|
stride[1] = 1;
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
count[0] = SPACE_DIM1;
|
2005-10-18 04:48:16 +08:00
|
|
|
count[1] = SPACE_DIM2;
|
2020-01-24 05:12:00 +08:00
|
|
|
start[0] = (hsize_t)mpi_rank*count[0];
|
2005-10-18 04:48:16 +08:00
|
|
|
start[1] = 0;
|
2004-07-21 05:41:44 +08:00
|
|
|
|
|
|
|
break;
|
2005-10-18 04:48:16 +08:00
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
case BYROW_DISCONT:
|
|
|
|
/* Each process takes several disjoint blocks. */
|
2005-10-18 04:48:16 +08:00
|
|
|
block[0] = 1;
|
|
|
|
block[1] = 1;
|
2020-01-24 05:12:00 +08:00
|
|
|
stride[0] = 3;
|
|
|
|
stride[1] = 3;
|
|
|
|
count[0] = SPACE_DIM1/(stride[0]*block[0]);
|
|
|
|
count[1] = (SPACE_DIM2)/(stride[1]*block[1]);
|
|
|
|
start[0] = (hsize_t)SPACE_DIM1*(hsize_t)mpi_rank;
|
2005-10-18 04:48:16 +08:00
|
|
|
start[1] = 0;
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
break;
|
2006-02-17 01:12:08 +08:00
|
|
|
|
|
|
|
case BYROW_SELECTNONE:
|
|
|
|
/* Each process takes a slabs of rows, there are
|
|
|
|
no selections for the last process. */
|
|
|
|
block[0] = 1;
|
|
|
|
block[1] = 1;
|
|
|
|
stride[0] = 1;
|
|
|
|
stride[1] = 1;
|
[svn-r12142] Purpose:
change the array size of collective chunking features of parallel tests.
Description:
Previously array size for collective optimization tests
including
cchunk1,
cchunk2,
cchunk3,
cchunk4,
ccontw,
ccontr,
cschunkw,
cschunkr,
ccchunkw,
ccchunkr
are fixed,
They are only valid for some good number of processors(1,2,3,4,6,8,12,16,24,32,48 etc).
Recently there are more requests for parallel tests to be valid on some odd number of processes such as 5,7,11,13 etc.
Solution:
I change the array size to be dynamic rather than static. Now the fastest change array size is a function of mpi_size. dim2 = constant *mpi_size. After some tunings, theoretically the above tests should be valid for any number of processors. However, other parallel tests still need to be tuned.
To verify the correctness of these tests, using mpirun -np 5 ./testphdf5 -b cchunk1 at heping.
Platforms tested:
h5committest(shanti is refused to be connected)
at heping, 5 and 7 processes are used to verify the correctness.
Misc. update:
2006-03-23 10:50:09 +08:00
|
|
|
count[0] = ((mpi_rank >= MAX(1,(mpi_size-2)))?0:SPACE_DIM1);
|
2006-02-17 01:12:08 +08:00
|
|
|
count[1] = SPACE_DIM2;
|
2020-01-24 05:12:00 +08:00
|
|
|
start[0] = (hsize_t)mpi_rank*count[0];
|
2006-02-17 01:12:08 +08:00
|
|
|
start[1] = 0;
|
|
|
|
|
|
|
|
break;
|
2006-03-24 05:18:02 +08:00
|
|
|
|
|
|
|
case BYROW_SELECTUNBALANCE:
|
|
|
|
/* The first one-third of the number of processes only
|
|
|
|
select top half of the domain, The rest will select the bottom
|
2008-09-16 23:52:51 +08:00
|
|
|
half of the domain. */
|
2006-03-24 05:18:02 +08:00
|
|
|
|
|
|
|
block[0] = 1;
|
2020-01-24 05:12:00 +08:00
|
|
|
count[0] = 2;
|
|
|
|
stride[0] = (hsize_t)SPACE_DIM1*(hsize_t)mpi_size/4+1;
|
2006-03-24 05:18:02 +08:00
|
|
|
block[1] = SPACE_DIM2;
|
|
|
|
count[1] = 1;
|
|
|
|
start[1] = 0;
|
|
|
|
stride[1] = 1;
|
2020-01-24 05:12:00 +08:00
|
|
|
if((mpi_rank *3)<(mpi_size*2)) start[0] = (hsize_t)mpi_rank;
|
|
|
|
else start[0] = (hsize_t)(1 + SPACE_DIM1*mpi_size/2 + (mpi_rank-2*mpi_size/3));
|
2006-03-29 22:35:26 +08:00
|
|
|
break;
|
2008-09-16 23:52:51 +08:00
|
|
|
|
2006-03-24 05:18:02 +08:00
|
|
|
case BYROW_SELECTINCHUNK:
|
|
|
|
/* Each process will only select one chunk */
|
|
|
|
|
|
|
|
block[0] = 1;
|
|
|
|
count[0] = 1;
|
2020-01-24 05:12:00 +08:00
|
|
|
start[0] = (hsize_t)(mpi_rank*SPACE_DIM1);
|
2006-03-24 05:18:02 +08:00
|
|
|
stride[0]= 1;
|
|
|
|
block[1] = SPACE_DIM2;
|
|
|
|
count[1] = 1;
|
|
|
|
stride[1]= 1;
|
|
|
|
start[1] = 0;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
default:
|
|
|
|
/* Unknown mode. Set it to cover the whole dataset. */
|
2020-01-24 05:12:00 +08:00
|
|
|
block[0] = (hsize_t)SPACE_DIM1*(hsize_t)mpi_size;
|
2005-10-18 04:48:16 +08:00
|
|
|
block[1] = SPACE_DIM2;
|
2004-07-21 05:41:44 +08:00
|
|
|
stride[0] = block[0];
|
|
|
|
stride[1] = block[1];
|
2005-10-18 04:48:16 +08:00
|
|
|
count[0] = 1;
|
|
|
|
count[1] = 1;
|
|
|
|
start[0] = 0;
|
|
|
|
start[1] = 0;
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
break;
|
|
|
|
}
|
2005-10-18 04:48:16 +08:00
|
|
|
if (VERBOSE_MED){
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("start[]=(%lu,%lu), count[]=(%lu,%lu), stride[]=(%lu,%lu), block[]=(%lu,%lu), total datapoints=%lu\n",
|
2004-12-29 22:26:20 +08:00
|
|
|
(unsigned long)start[0], (unsigned long)start[1], (unsigned long)count[0], (unsigned long)count[1],
|
2004-07-21 05:41:44 +08:00
|
|
|
(unsigned long)stride[0], (unsigned long)stride[1], (unsigned long)block[0], (unsigned long)block[1],
|
|
|
|
(unsigned long)(block[0]*block[1]*count[0]*count[1]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Fill the dataset with trivial data for testing.
|
2005-10-18 04:48:16 +08:00
|
|
|
* Assume dimension rank is 2.
|
2004-07-21 05:41:44 +08:00
|
|
|
*/
|
2004-07-23 04:46:27 +08:00
|
|
|
static void
|
2008-09-16 23:52:51 +08:00
|
|
|
ccdataset_fill(hsize_t start[],
|
2005-10-18 04:48:16 +08:00
|
|
|
hsize_t stride[],
|
2008-09-16 23:52:51 +08:00
|
|
|
hsize_t count[],
|
|
|
|
hsize_t block[],
|
2014-03-08 03:12:20 +08:00
|
|
|
DATATYPE * dataset,
|
|
|
|
int mem_selection)
|
2004-07-21 05:41:44 +08:00
|
|
|
{
|
|
|
|
DATATYPE *dataptr = dataset;
|
2004-07-23 04:46:27 +08:00
|
|
|
DATATYPE *tmptr;
|
2014-03-08 03:12:20 +08:00
|
|
|
hsize_t i,j,k1,k2,k=0;
|
2004-07-21 05:41:44 +08:00
|
|
|
/* put some trivial data in the data_array */
|
|
|
|
tmptr = dataptr;
|
|
|
|
|
|
|
|
/* assign the disjoint block (two-dimensional)data array value
|
|
|
|
through the pointer */
|
|
|
|
|
2005-10-18 04:48:16 +08:00
|
|
|
for (k1 = 0; k1 < count[0]; k1++) {
|
|
|
|
for(i = 0; i < block[0]; i++) {
|
|
|
|
for(k2 = 0; k2 < count[1]; k2++) {
|
|
|
|
for(j = 0;j < block[1]; j++) {
|
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
if (ALL != mem_selection) {
|
|
|
|
dataptr = tmptr + ((start[0]+k1*stride[0]+i)*SPACE_DIM2+
|
|
|
|
start[1]+k2*stride[1]+j);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
dataptr = tmptr + k;
|
|
|
|
k++;
|
|
|
|
}
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
*dataptr = (DATATYPE)(k1+k2+i+j);
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
2005-10-18 04:48:16 +08:00
|
|
|
}
|
2005-08-14 04:53:35 +08:00
|
|
|
}
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Print the first block of the content of the dataset.
|
|
|
|
*/
|
2004-07-23 04:46:27 +08:00
|
|
|
static void
|
2008-09-16 23:52:51 +08:00
|
|
|
ccdataset_print(hsize_t start[],
|
|
|
|
hsize_t block[],
|
2005-10-18 04:48:16 +08:00
|
|
|
DATATYPE * dataset)
|
|
|
|
|
2004-07-21 05:41:44 +08:00
|
|
|
{
|
|
|
|
DATATYPE *dataptr = dataset;
|
|
|
|
hsize_t i, j;
|
|
|
|
|
|
|
|
/* print the column heading */
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("Print only the first block of the dataset\n");
|
|
|
|
HDprintf("%-8s", "Cols:");
|
2004-07-21 05:41:44 +08:00
|
|
|
for (j=0; j < block[1]; j++){
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("%3lu ", (unsigned long)(start[1]+j));
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("\n");
|
2004-07-21 05:41:44 +08:00
|
|
|
|
|
|
|
/* print the slab data */
|
|
|
|
for (i=0; i < block[0]; i++){
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("Row %2lu: ", (unsigned long)(i+start[0]));
|
2004-07-21 05:41:44 +08:00
|
|
|
for (j=0; j < block[1]; j++){
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("%03d ", *dataptr++);
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("\n");
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Print the content of the dataset.
|
|
|
|
*/
|
2004-07-23 04:46:27 +08:00
|
|
|
static int
|
2008-09-16 23:52:51 +08:00
|
|
|
ccdataset_vrfy(hsize_t start[],
|
|
|
|
hsize_t count[],
|
|
|
|
hsize_t stride[],
|
|
|
|
hsize_t block[],
|
|
|
|
DATATYPE *dataset,
|
2014-03-08 03:12:20 +08:00
|
|
|
DATATYPE *original,
|
|
|
|
int mem_selection)
|
2004-07-21 05:41:44 +08:00
|
|
|
{
|
2014-03-08 03:12:20 +08:00
|
|
|
hsize_t i, j,k1,k2,k=0;
|
2004-07-21 05:41:44 +08:00
|
|
|
int vrfyerrs;
|
|
|
|
DATATYPE *dataptr,*oriptr;
|
|
|
|
|
|
|
|
/* print it if VERBOSE_MED */
|
|
|
|
if (VERBOSE_MED) {
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("dataset_vrfy dumping:::\n");
|
|
|
|
HDprintf("start(%lu, %lu), count(%lu, %lu), stride(%lu, %lu), block(%lu, %lu)\n",
|
2004-12-29 22:26:20 +08:00
|
|
|
(unsigned long)start[0], (unsigned long)start[1], (unsigned long)count[0], (unsigned long)count[1],
|
2004-07-21 05:41:44 +08:00
|
|
|
(unsigned long)stride[0], (unsigned long)stride[1], (unsigned long)block[0], (unsigned long)block[1]);
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("original values:\n");
|
2004-07-21 05:41:44 +08:00
|
|
|
ccdataset_print(start, block, original);
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("compared values:\n");
|
2004-07-21 05:41:44 +08:00
|
|
|
ccdataset_print(start, block, dataset);
|
|
|
|
}
|
|
|
|
|
|
|
|
vrfyerrs = 0;
|
2005-08-14 04:53:35 +08:00
|
|
|
|
2014-03-08 03:12:20 +08:00
|
|
|
for (k1=0;k1<count[0];k1++) {
|
|
|
|
for(i=0;i<block[0];i++) {
|
|
|
|
for(k2=0; k2<count[1];k2++) {
|
|
|
|
for(j=0;j<block[1];j++) {
|
|
|
|
if (ALL != mem_selection) {
|
|
|
|
dataptr = dataset + ((start[0]+k1*stride[0]+i)*SPACE_DIM2+
|
|
|
|
start[1]+k2*stride[1]+j);
|
|
|
|
oriptr = original + ((start[0]+k1*stride[0]+i)*SPACE_DIM2+
|
|
|
|
start[1]+k2*stride[1]+j);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
dataptr = dataset + k;
|
|
|
|
oriptr = original + k;
|
|
|
|
k++;
|
|
|
|
}
|
|
|
|
if (*dataptr != *oriptr){
|
|
|
|
if (vrfyerrs++ < MAX_ERR_REPORT || VERBOSE_MED){
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("Dataset Verify failed at [%lu][%lu]: expect %d, got %d\n",
|
2014-03-08 03:12:20 +08:00
|
|
|
(unsigned long)i, (unsigned long)j,
|
2014-09-06 03:30:42 +08:00
|
|
|
*(oriptr), *(dataptr));
|
2014-03-08 03:12:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2004-07-21 05:41:44 +08:00
|
|
|
}
|
|
|
|
if (vrfyerrs > MAX_ERR_REPORT && !VERBOSE_MED)
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("[more errors ...]\n");
|
2004-07-21 05:41:44 +08:00
|
|
|
if (vrfyerrs)
|
2019-08-25 03:07:19 +08:00
|
|
|
HDprintf("%d errors found in ccdataset_vrfy\n", vrfyerrs);
|
2004-07-21 05:41:44 +08:00
|
|
|
return(vrfyerrs);
|
|
|
|
}
|