* Brings CMake updates from develop
* Brings reduction in pedantic casts from develop
* Purges UFAIL from the library (#637)
* Committing clang-format changes
* Purges UFAIL from the library
* H5HL_insert change requested in PR
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Removes gratuitous (double)x.yF casts (#632)
* Committing clang-format changes
* Removes gratuitous (double)x.yF casts
* Committing clang-format changes
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Committing clang-format changes
* Cleans up a const warning left over from previous constification (#633)
* Committing clang-format changes
* Adds consts to a few global variables
* Cleans up a const warning left over from previous constification
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Formatted source
* Bring over some VOL registration changes
* VOL cleanup
* H5VL_request_status_t substitutions
* H5F.c cleanup
* Minor API tweaks from develop
* Moves H5G package init/teardown to H5Gint.c
* H5G cleanup
* H5M cleanup
* H5SM cleanup
* H5T cleanup
* H5R cleanup
* H5Lpublic.h cleanup
* H5L cleanup
* H5O cleanup
* H5A, H5CS, and H5AC cleanup
* Moved H5A init/teardown code to H5Aint.c
* Moves H5D I/O functions to H5D.c
* H5D cleanup
* Misc minor cleanup
* H5P close cleanup
* H5Tpublic.h cleanup
* Fixes err_compat test
* H5PLpublic.h cleanup
* Updates H5Ppublic.h
* H5Fpublic.h updates
* H5A.c cleanup
* Brings over H5Aexists and related changes
* Brings CMake shell testing changes from develop
* Close callback changes
* H5R and H5Tcommit normalization
* err_compat test works now
* H5O tweaks
* Updates VOL registration code
* Brings over H5VL_create_object
* H5Tconv.c reformatting
* H5T.c tweaks
* Brings datatype and reference updates from develop
* Brings VOL plugin loading changes from develop
* Brings event sets from develop
* Brings async functions over
* Tools changes
* Brings over many tools changes from develop
* Brings VOL flags from develop
* Fixes h5dump double/float tests
* Updates h5repack tests
* Brings h5diff test changes from develop
* Last h5dump changes
* Brings test changes from develop
* Committing clang-format changes
* Tidied h5_testing()
* Brings chunk iteration code + misc from develop
* Updates vds test
* Enables external link parallel test
* Brings updated property lists from develop
* H5G changes from develop
* H5MF cleanup
* Brings vfd_swmr test back into CMake
* Updates threadsafe test
* Updates plist test
* Brings recent changes from develop
* Require a C++11 compiler to build the C++ wrappers (#693)
* Committing clang-format changes
* Requires a C++11 compiler to build the C++ wrappers
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Fix H5FD_mpio_Debug="rw" can report MPI_count instead of bytes (#699)
* Removes pre-C99 build and header cruft (#700)
* Assumes ANSI C headers exist
* Assumes stdbool.h, stdint.h, and inttypes.h are present
* Assumes the C++ compiler can handle stdint.h
* Removes all work-arounds for missing functionality, especially stdbool.h
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Updates release documents
* Brings parallel changes from develop
* Adds a VFD/parallel check program for the VFD SWMR shell test
* Updates MANIFEST
* Disable building VFD SWMR acceptance tests on CMake
* Removes err.h from genall5.c
* Partial cleanup of H5Cpkg.h
* Fixes printf specifiers in H5Cdbg.c
* Java and fortran cmake changes (#694)
* OESS-98 convert plugin option to FetchContent, add tests
* Fixes for pkcfg files because of plugin option
* OESS-98 fix tools test for plugins
* Keep doxygen comments under 100 chars long - format hint
* Whitespace
* HDFFV-11144 - Reclassify CMake messages
* HDFFV-11099/11100 added help text
* Reworked switch statement to compare string instead
* Fix typo
* Update CDash mode
* Correct name of threadsafe
* Correct option name
* Undo accidental commit
* Note LLVM 10 to 11 format default changes
* Update format plugin
* Undo clang-format version 11 changes
* One more correction
* Update supported platforms
* Revert whitespace changes
* Correct whitespace
* Changes from PR#3
* HDFFV-11213 added option to control gcc10 warnings diagnostics
* HDFFV-11212 Use the new references correctly in JNI utility and tests
* format source
* Fix typo
* Add new test file
* HDFFV-11212 - update test and remove unused arg
* Minor non-space formatting changes
* Use H5I_INVALID_ID instead of "-1"
* source formatting
* add missing testfile, update jni function
* Undo commit of debug code
* remove mislocated file
* Fix h5repack test for handling of fapls and id close
* Update h5diff test files usage text
* HDFFV-11212 add new ref tests for JNI export dataset
* src format update
* Remove blank line typo
* src format typo
* long double requires %Lg
* Another long double foramt specifer S.B. %Lg
* issue with t128bit test
* Windows issue with h5dump and type.
* Fix review issues
* refactor function nesting and fix error checks
* format fixes
* Remove untested functions and javadoc quiet comments
* Restore TRY block.
* Change string append errors to memory exception
* revert to H5_JNI_FATAL_ERROR - support functions need work
* Add assertion error for h5util functions
* remove duplicate function
* format fix
* Revert HD function error handling
* Update copyright comments
* GH #386 java folder copyright corrections
* Whitespace
* GH #359 implement and fix tools 1.6 API usage
* remove excessive comments
* Flip inits to correct ifdef section
* rework ifdef to be simpler
* format issue
* Reformat ifdef inits
* remove static attribute
* format compliance
* Update names
* Revert because logic relies on float not being int
* Changes noticed from creating merge of #412
* Double underscore change
* Correct compiler version variable used
* Remove header guard underscores
* Whitespace cleanup
* Split format source and commit changes on repo push
* remove pre-split setting
* Change windows TS to use older VS.
* correct window os name
* HDFFV-11212 JNI export util and Javadoc
* Suggested review changes
* Another change found
* Committing clang-format changes
* HDFFV-11113 long double in tools
* HDFFV-11113 add note
* Disable long double tests for now
* HDFFV-11228 remove arbitrary CMake warning groups.
* Make each flag a string
* Some Javadoc warning fixes
* Updated javadoc fixes
* # WARNING: head commit changed in the meantime
HDFFV-11229 Fix long double usage in tools and java
Changed h5dump and h5ls to just print 128-bit for long double type.
Added test and file for dataset and attributes with all three float
types.
* Committing clang-format changes
* HDFFV-11229 Add release note
* HDFFV-11229 windows testfile needed
* fix typo
* Remove non supported message text
* HDFFV-11229 - change ldouble test to check both native and general
* HDFFV-11229 add second file compare
* HDFFV-11229 fix reference file
* HDFFV-11229 autotools check two refs
* HDFFV-11229 revert back to removal of NATIVE_LDOUBLE in tools output
* Committing clang-format changes
* Update release note
* Update attribute type of ref file
* Change source of ninja for macs
* try port instead of brew
* Recommended is to use brew.
* Undo non long double changes
* remove unneeded file
* Fix perl and doxygen CMake code
* Add "option" command for clang options
* Rework CMake add_custom to use the BYPRODUCTS argument
* Add stamp files to BYPRODUCTS
* Only one copy of file exists
* Fix custom cmmand depends targets
* Fix fortran custom command DEPENDS
* Add LD_LIBRARY_PATH to tests
* Add custom target for DEPENDS
* Add h5detect conditionaly to generated target DEPENDS
* Correct DEPENDS targets
* Parallel builds need the mpi compiler for pkgconfig scripts.
* install only if MPI build
* Fortran target depends
* Remove incorrect source attribute
* doxygen adjustments
* doxygen build updates
* Correct version
* Correct function version - function has been merged to 1.12
* Correct version string for map functions
* Cleanup warnings for tools debug builds
* TRILAB-227 - fix indexing for h5diff selections
* Correct location of pos to index function call
* TRILAB-227 Enable test
* Quote subset args
* Use MATCHES because of AppleClang
* if blocks needed for build modes
* Update list of DT platforms
* VS2019 correctly displays float values
* revert VS2019 change
* Issue #669 remove version from pkgcfg filename
* remove version from h5cc script
* Java reference functions updated
enabled fortran in cmake gcc action yaml file
java reference test changed to correctly test refs
jni reference functions that create ids changed to use jni id logging
* Correct BYPRODUCTS argument
* Correct more genereated files BYPRODUCTS
* BYPRODUCTS must have unique locations
* Fix typo
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Removes alternative function enter/leave macro scheme (#678)
* Committing clang-format changes
* Converted BEGIN_FUNC, etc. macros to FUNC_ENTER
* Rips out the BEGIN_FUNC, etc. macros
* Removes 'end if', etc. comments from H5HL package
* Committing clang-format changes
* Fixes an H5EA iterate issue
* Fixes an issue in the H5FA iterator code
* Further cleanup in bin/trace after macro removal
* Iterator changes in H5EA and H5FA
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Split H5L.c internal code to H5Lint.c (#691)
* Committing clang-format changes
* Splits internal parts of H5L.c to H5Lint.c
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Clean up type size checks in configure.ac (#702)
* Committing clang-format changes
* C++ warning and build fixes (#707)
* Committing clang-format changes
* C++ build and warning updates
* Fixes all warnings on C++ (with gcc 9.3)
* Updates CMake and Autotools C++ builds
* Undo warning clobber
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Removes some DEC Alpha cruft from H5detect and H5private.h (#708)
* Cleans up hsize_t and haddr_t size guessing (#709)
* Cleans up definitions of haddr_t and hsize_t + cruft removal
* Formatted source
* Updates PGI C/C++ configurations (#715)
* Updates PGI C/C++ configurations
Tweaks some settings and configures pgc++ to use C++11
* Updated copyright information
* Adds an Intel C++ configuration file (#716)
* Adds an Intel C++ configuration file
* Committing clang-format changes
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Updates bin/trace script to correctly wrap H5TRACE macros near clang-format column limit (#719)
* Removes clang-format comments from H5O.c call
* Fixes bin/trace to correctly wrap lines near the clang-format limit
* Removed unused variable from bin/trace
* Fixes issue with ccmake that prevents building Fortran (#723)
ccmake runs iteratively, and the check_fortran_source_runs
macros were clobbering a single output file that did not
get updated on further configure iterations
* Updates CMake size_t and ssize_t checks for MacOS
* Moved a little boilerplate over from develop
* Fixes some warnings
* Committing clang-format changes
* Moves gcc warning macros from H5public.h to H5private.h (#724)
* Moves gcc warning suppression macros out of H5public.h
* Update RELEASE.txt
* Formatted source
* Adds __STDC_FORMAT_MACROS before including inttypes.h w/ C++ (#726)
* Adds __STDC_FORMAT_MACROS before including inttypes.h w/ C++
Allows C++ library to be built on older versions of gcc.
* Committing clang-format changes
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
* Moves H5PacketTable default ctor inside source file (#731)
* Brings (most) H5Xdevelop.h headers from develop
* Trivial H5F and H5O changes during normalization
* Renames buf_ptr back to page_buf to better align with develop
* Removed H5HGtrap.c
* Brings changes from develop
* Normalization (mainly cache) with develop
* Fix Direct VFD Testing in CMake (#742)
* Fixes C++ warnings when passing hsize_t values to printf in test code (#745)
* Organize and align compiler flags (#741)
* OESS-98 convert plugin option to FetchContent, add tests
* Fixes for pkcfg files because of plugin option
* OESS-98 fix tools test for plugins
* Keep doxygen comments under 100 chars long - format hint
* Whitespace
* HDFFV-11144 - Reclassify CMake messages
* HDFFV-11099/11100 added help text
* Reworked switch statement to compare string instead
* Fix typo
* Update CDash mode
* Correct name of threadsafe
* Correct option name
* Undo accidental commit
* Note LLVM 10 to 11 format default changes
* Update format plugin
* Undo clang-format version 11 changes
* One more correction
* Update supported platforms
* Revert whitespace changes
* Correct whitespace
* Changes from PR#3
* HDFFV-11213 added option to control gcc10 warnings diagnostics
* HDFFV-11212 Use the new references correctly in JNI utility and tests
* format source
* Fix typo
* Add new test file
* HDFFV-11212 - update test and remove unused arg
* Minor non-space formatting changes
* Use H5I_INVALID_ID instead of "-1"
* source formatting
* add missing testfile, update jni function
* Undo commit of debug code
* remove mislocated file
* Fix h5repack test for handling of fapls and id close
* Update h5diff test files usage text
* HDFFV-11212 add new ref tests for JNI export dataset
* src format update
* Remove blank line typo
* src format typo
* long double requires %Lg
* Another long double foramt specifer S.B. %Lg
* issue with t128bit test
* Windows issue with h5dump and type.
* Fix review issues
* refactor function nesting and fix error checks
* format fixes
* Remove untested functions and javadoc quiet comments
* Restore TRY block.
* Change string append errors to memory exception
* revert to H5_JNI_FATAL_ERROR - support functions need work
* Add assertion error for h5util functions
* remove duplicate function
* format fix
* Revert HD function error handling
* Update copyright comments
* GH #386 java folder copyright corrections
* Whitespace
* GH #359 implement and fix tools 1.6 API usage
* remove excessive comments
* Flip inits to correct ifdef section
* rework ifdef to be simpler
* format issue
* Reformat ifdef inits
* remove static attribute
* format compliance
* Update names
* Revert because logic relies on float not being int
* Changes noticed from creating merge of #412
* Double underscore change
* Correct compiler version variable used
* Remove header guard underscores
* Whitespace cleanup
* Split format source and commit changes on repo push
* remove pre-split setting
* Change windows TS to use older VS.
* correct window os name
* HDFFV-11212 JNI export util and Javadoc
* Suggested review changes
* Another change found
* Committing clang-format changes
* HDFFV-11113 long double in tools
* HDFFV-11113 add note
* Disable long double tests for now
* HDFFV-11228 remove arbitrary CMake warning groups.
* Make each flag a string
* Some Javadoc warning fixes
* Updated javadoc fixes
* # WARNING: head commit changed in the meantime
HDFFV-11229 Fix long double usage in tools and java
Changed h5dump and h5ls to just print 128-bit for long double type.
Added test and file for dataset and attributes with all three float
types.
* Committing clang-format changes
* HDFFV-11229 Add release note
* HDFFV-11229 windows testfile needed
* fix typo
* Remove non supported message text
* HDFFV-11229 - change ldouble test to check both native and general
* HDFFV-11229 add second file compare
* HDFFV-11229 fix reference file
* HDFFV-11229 autotools check two refs
* HDFFV-11229 revert back to removal of NATIVE_LDOUBLE in tools output
* Committing clang-format changes
* Update release note
* Update attribute type of ref file
* Change source of ninja for macs
* try port instead of brew
* Recommended is to use brew.
* Undo non long double changes
* remove unneeded file
* Fix perl and doxygen CMake code
* Add "option" command for clang options
* Rework CMake add_custom to use the BYPRODUCTS argument
* Add stamp files to BYPRODUCTS
* Only one copy of file exists
* Fix custom cmmand depends targets
* Fix fortran custom command DEPENDS
* Add LD_LIBRARY_PATH to tests
* Add custom target for DEPENDS
* Add h5detect conditionaly to generated target DEPENDS
* Correct DEPENDS targets
* Parallel builds need the mpi compiler for pkgconfig scripts.
* install only if MPI build
* Fortran target depends
* Remove incorrect source attribute
* doxygen adjustments
* doxygen build updates
* Correct version
* Correct function version - function has been merged to 1.12
* Correct version string for map functions
* Cleanup warnings for tools debug builds
* TRILAB-227 - fix indexing for h5diff selections
* Correct location of pos to index function call
* TRILAB-227 Enable test
* Quote subset args
* Use MATCHES because of AppleClang
* if blocks needed for build modes
* Update list of DT platforms
* VS2019 correctly displays float values
* revert VS2019 change
* Issue #669 remove version from pkgcfg filename
* remove version from h5cc script
* Java reference functions updated
enabled fortran in cmake gcc action yaml file
java reference test changed to correctly test refs
jni reference functions that create ids changed to use jni id logging
* Correct BYPRODUCTS argument
* Correct more genereated files BYPRODUCTS
* BYPRODUCTS must have unique locations
* Fix typo
* Fix fortran configure checks
* Rework H5_PAC_C_MAX_REAL_PRECISION setting logic
* Add note about fortran configure change
* Adds a quick for for some egregious chunk_info badness (#722)
* Fixes issue with ccmake that prevents building Fortran (#723)
ccmake runs iteratively, and the check_fortran_source_runs
macros were clobbering a single output file that did not
get updated on further configure iterations
* Fix conflicts with merge
* Move MAX_PRECISION back to HDF5UseFortran.cmake
* Use STREQUAL to test macro argument
* Move C language test to ConfigureChecks from HDF5UseFortran
* MAX_PRECISION defines must be defined
* Organize flags and align autotools and cmake
* Fix comment in no-error-general warnings files.
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Dana Robinson <43805+derobins@users.noreply.github.com>
* Committing clang-format changes
* Cache code tidying
* Constification of cache code
* Renaming of static calls in cache
* Fixes H5C mess made by git during merge
* Committing clang-format changes
* Fixes a printf format issue w/ parallel
* Revert "Committing clang-format changes"
This reverts commit 1265fe87fe.
* Turns off clang formatter in H5C while syncing with develop
* Adds a lot of HD prefixes and cleans up err.h usage
* Committing clang-format changes
* Brings cache skip list optimization from develop
* Brings recent changes from develop
Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
477 lines
15 KiB
C
477 lines
15 KiB
C
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* Copyright by The HDF Group. *
|
|
* All rights reserved. *
|
|
* *
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
* terms governing use, modification, and redistribution, is contained in *
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
|
* If you do not have access to either file, you may request a copy from *
|
|
* help@hdfgroup.org. *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
/*-------------------------------------------------------------------------
|
|
*
|
|
* Created: vfd_swmr_sparse_writer.c
|
|
* (copied and modified from swmr_sparse_writer.c)
|
|
*
|
|
* Purpose: Writes data to a randomly selected subset of the datasets
|
|
* in the VFD_SWMR test file.
|
|
*
|
|
* This program is intended to run concurrently with the
|
|
* vfd_swmr_sparse_reader program.
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
|
|
/***********/
|
|
/* Headers */
|
|
/***********/
|
|
|
|
#include "h5test.h"
|
|
#include "vfd_swmr_common.h"
|
|
#include "swmr_common.h"
|
|
|
|
#ifndef H5_HAVE_WIN32_API
|
|
|
|
#include <err.h>
|
|
|
|
/****************/
|
|
/* Local Macros */
|
|
/****************/
|
|
|
|
#ifdef OUT
|
|
#define BUSY_WAIT 100000
|
|
#endif /* OUT */
|
|
|
|
/********************/
|
|
/* Local Prototypes */
|
|
/********************/
|
|
|
|
static hid_t open_skeleton(const char *filename, unsigned verbose);
|
|
static int add_records(hid_t fid, unsigned verbose, unsigned long nrecords, unsigned long flush_count);
|
|
static void usage(void);
|
|
|
|
/*-------------------------------------------------------------------------
|
|
* Function: open_skeleton
|
|
*
|
|
* Purpose: Opens the SWMR HDF5 file and datasets.
|
|
*
|
|
* Parameters: const char *filename
|
|
* The filename of the SWMR HDF5 file to open
|
|
*
|
|
* unsigned verbose
|
|
* Whether or not to emit verbose console messages
|
|
*
|
|
* Return: Success: The file ID of the opened SWMR file
|
|
* The dataset IDs are stored in a global array
|
|
*
|
|
* Failure: -1
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
static hid_t
|
|
open_skeleton(const char *filename, unsigned verbose)
|
|
{
|
|
hid_t fid = -1; /* File ID for new HDF5 file */
|
|
hid_t fapl = -1; /* File access property list */
|
|
hid_t aid = -1; /* Attribute ID */
|
|
unsigned seed; /* Seed for random number generator */
|
|
unsigned u, v; /* Local index variable */
|
|
H5F_vfd_swmr_config_t *config = NULL; /* Configuration for VFD SWMR */
|
|
|
|
HDassert(filename);
|
|
|
|
/* Allocate memory for the configuration structure */
|
|
if ((config = (H5F_vfd_swmr_config_t *)HDcalloc(1, sizeof(H5F_vfd_swmr_config_t))) == NULL)
|
|
goto error;
|
|
|
|
/* config, tick_len, max_lag, writer, flush_raw_data, md_pages_reserved, md_file_path */
|
|
init_vfd_swmr_config(config, 4, 5, TRUE, FALSE, 128, "./rw-shadow");
|
|
|
|
/* use_latest_format, use_vfd_swmr, only_meta_page, config */
|
|
if ((fapl = vfd_swmr_create_fapl(TRUE, TRUE, FALSE, config)) < 0)
|
|
goto error;
|
|
|
|
/* Open the file */
|
|
if ((fid = H5Fopen(filename, H5F_ACC_RDWR, fapl)) < 0)
|
|
goto error;
|
|
|
|
/* Close file access property list */
|
|
if (H5Pclose(fapl) < 0)
|
|
goto error;
|
|
|
|
if (config)
|
|
HDfree(config);
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Opening datasets\n");
|
|
|
|
/* Seed the random number generator with the attribute in the file */
|
|
if ((aid = H5Aopen(fid, "seed", H5P_DEFAULT)) < 0)
|
|
goto error;
|
|
if (H5Aread(aid, H5T_NATIVE_UINT, &seed) < 0)
|
|
goto error;
|
|
if (H5Aclose(aid) < 0)
|
|
goto error;
|
|
HDsrandom(seed);
|
|
|
|
/* Open the datasets */
|
|
for (u = 0; u < NLEVELS; u++)
|
|
for (v = 0; v < symbol_count[u]; v++) {
|
|
if ((symbol_info[u][v].dsid = H5Dopen2(fid, symbol_info[u][v].name, H5P_DEFAULT)) < 0)
|
|
return (-1);
|
|
symbol_info[u][v].nrecords = 0;
|
|
} /* end for */
|
|
|
|
return fid;
|
|
|
|
error:
|
|
if (config)
|
|
HDfree(config);
|
|
|
|
H5E_BEGIN_TRY
|
|
{
|
|
for (u = 0; u < NLEVELS; u++)
|
|
for (v = 0; v < symbol_count[u]; v++)
|
|
H5Dclose(symbol_info[u][v].dsid);
|
|
H5Aclose(aid);
|
|
H5Pclose(fapl);
|
|
H5Fclose(fid);
|
|
}
|
|
H5E_END_TRY;
|
|
|
|
return -1;
|
|
|
|
} /* open_skeleton() */
|
|
|
|
/*-------------------------------------------------------------------------
|
|
* Function: add_records
|
|
*
|
|
* Purpose: Writes a specified number of records to random datasets in
|
|
* the SWMR test file.
|
|
*
|
|
* Parameters: hid_t fid
|
|
* The file ID of the SWMR HDF5 file
|
|
*
|
|
* unsigned verbose
|
|
* Whether or not to emit verbose console messages
|
|
*
|
|
* unsigned long nrecords
|
|
* # of records to write to the datasets
|
|
*
|
|
* unsigned long flush_count
|
|
* # of records to write before flushing the file to disk
|
|
*
|
|
* Return: Success: 0
|
|
* Failure: -1
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
static int
|
|
add_records(hid_t fid, unsigned verbose, unsigned long nrecords, unsigned long flush_count)
|
|
{
|
|
hid_t tid = -1; /* Datatype ID for records */
|
|
hid_t mem_sid = -1; /* Memory dataspace ID */
|
|
hid_t file_sid = -1; /* Dataset's space ID */
|
|
hid_t aid = -1; /* Attribute ID */
|
|
hsize_t start[2] = {0, 0}; /* Hyperslab selection values */
|
|
hsize_t count[2] = {1, 1}; /* Hyperslab selection values */
|
|
symbol_t record; /* The record to add to the dataset */
|
|
unsigned long rec_to_flush; /* # of records left to write before flush */
|
|
#ifdef OUT
|
|
volatile int dummy; /* Dummy varialbe for busy sleep */
|
|
#endif /* OUT */
|
|
hsize_t dim[2] = {1, 0}; /* Dataspace dimensions */
|
|
unsigned long u, v; /* Local index variables */
|
|
|
|
HDassert(fid >= 0);
|
|
|
|
/* Reset the record */
|
|
/* (record's 'info' field might need to change for each record written, also) */
|
|
HDmemset(&record, 0, sizeof(record));
|
|
|
|
/* Create a dataspace for the record to add */
|
|
if ((mem_sid = H5Screate(H5S_SCALAR)) < 0)
|
|
goto error;
|
|
|
|
/* Create datatype for appending records */
|
|
if ((tid = create_symbol_datatype()) < 0)
|
|
goto error;
|
|
|
|
/* Add records to random datasets, according to frequency distribution */
|
|
rec_to_flush = flush_count;
|
|
for (u = 0; u < nrecords; u++) {
|
|
symbol_info_t *symbol; /* Symbol to write record to */
|
|
|
|
/* Get a random dataset, according to the symbol distribution */
|
|
symbol = choose_dataset(NULL, NULL, verbose);
|
|
|
|
/* If this is the first time the dataset has been opened, extend it and
|
|
* add the sequence attribute */
|
|
if (symbol->nrecords == 0) {
|
|
symbol->nrecords = nrecords / 5;
|
|
dim[1] = symbol->nrecords;
|
|
|
|
if (H5Dset_extent(symbol->dsid, dim) < 0)
|
|
goto error;
|
|
|
|
if ((file_sid = H5Screate(H5S_SCALAR)) < 0)
|
|
goto error;
|
|
if ((aid = H5Acreate2(symbol->dsid, "seq", H5T_NATIVE_ULONG, file_sid, H5P_DEFAULT,
|
|
H5P_DEFAULT)) < 0)
|
|
goto error;
|
|
if (H5Sclose(file_sid) < 0)
|
|
goto error;
|
|
}
|
|
else if ((aid = H5Aopen(symbol->dsid, "seq", H5P_DEFAULT)) < 0)
|
|
goto error;
|
|
|
|
/* Get the coordinate to write */
|
|
start[1] = (hsize_t)HDrandom() % symbol->nrecords;
|
|
|
|
/* Set the record's ID (equal to its position) */
|
|
record.rec_id = start[1];
|
|
|
|
/* Get the dataset's dataspace */
|
|
if ((file_sid = H5Dget_space(symbol->dsid)) < 0)
|
|
goto error;
|
|
|
|
/* Choose a random record in the dataset */
|
|
if (H5Sselect_hyperslab(file_sid, H5S_SELECT_SET, start, NULL, count, NULL) < 0)
|
|
goto error;
|
|
|
|
/* Write record to the dataset */
|
|
if (H5Dwrite(symbol->dsid, tid, mem_sid, file_sid, H5P_DEFAULT, &record) < 0)
|
|
goto error;
|
|
|
|
/* Write the sequence number attribute. Since we synchronize the random
|
|
* number seed, the readers will always generate the same sequence of
|
|
* randomly chosen datasets and offsets. Therefore, and because of the
|
|
* flush dependencies on the object header, the reader will be
|
|
* guaranteed to see the written data if the sequence attribute is >=u.
|
|
*/
|
|
if (H5Awrite(aid, H5T_NATIVE_ULONG, &u) < 0)
|
|
goto error;
|
|
|
|
/* Close the attribute */
|
|
if (H5Aclose(aid) < 0)
|
|
goto error;
|
|
|
|
/* Close the dataset's dataspace */
|
|
if (H5Sclose(file_sid) < 0)
|
|
goto error;
|
|
|
|
/* Check for flushing file */
|
|
if (flush_count > 0) {
|
|
/* Decrement count of records to write before flushing */
|
|
rec_to_flush--;
|
|
|
|
/* Check for counter being reached */
|
|
if (0 == rec_to_flush) {
|
|
/* Reset flush counter */
|
|
rec_to_flush = flush_count;
|
|
} /* end if */
|
|
} /* end if */
|
|
|
|
#ifdef OUT
|
|
/* Busy wait, to let readers catch up */
|
|
/* If this is removed, also remove the BUSY_WAIT symbol
|
|
* at the top of the file.
|
|
*/
|
|
dummy = 0;
|
|
for (v = 0; v < BUSY_WAIT; v++)
|
|
dummy++;
|
|
if ((unsigned long)dummy != v)
|
|
return -1;
|
|
#endif /* OUT */
|
|
|
|
} /* end for */
|
|
|
|
/* Close the memory dataspace */
|
|
if (H5Sclose(mem_sid) < 0)
|
|
goto error;
|
|
|
|
/* Close the datatype */
|
|
if (H5Tclose(tid) < 0)
|
|
goto error;
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Closing datasets\n");
|
|
|
|
/* Close the datasets */
|
|
for (u = 0; u < NLEVELS; u++)
|
|
for (v = 0; v < symbol_count[u]; v++)
|
|
if (H5Dclose(symbol_info[u][v].dsid) < 0)
|
|
goto error;
|
|
|
|
return 0;
|
|
|
|
error:
|
|
H5E_BEGIN_TRY
|
|
{
|
|
H5Sclose(mem_sid);
|
|
H5Sclose(file_sid);
|
|
H5Tclose(tid);
|
|
H5Aclose(aid);
|
|
|
|
for (u = 0; u < NLEVELS; u++)
|
|
for (v = 0; v < symbol_count[u]; v++)
|
|
H5Dclose(symbol_info[u][v].dsid);
|
|
}
|
|
H5E_END_TRY;
|
|
|
|
return -1;
|
|
} /* add_records() */
|
|
|
|
static void
|
|
usage(void)
|
|
{
|
|
HDprintf("\n");
|
|
HDprintf("Usage error!\n");
|
|
HDprintf("\n");
|
|
HDprintf("Usage: vfd_swmr_sparse_writer [-q] [-f <# of records to write between\n");
|
|
HDprintf(" flushing file contents>] <# of records>\n");
|
|
HDprintf("\n");
|
|
HDprintf("<# of records to write between flushing file contents> should be 0\n");
|
|
HDprintf("(for no flushing) or between 1 and (<# of records> - 1)\n");
|
|
HDprintf("\n");
|
|
HDprintf("Defaults to verbose (no '-q' given) and flushing every 1000 records\n");
|
|
HDprintf("('-f 1000')\n");
|
|
HDprintf("\n");
|
|
HDexit(1);
|
|
} /* usage() */
|
|
|
|
int
|
|
main(int argc, const char *argv[])
|
|
{
|
|
sigset_t oldset;
|
|
hid_t fid; /* File ID for file opened */
|
|
long nrecords = 0; /* # of records to append */
|
|
long flush_count = 1000; /* # of records to write between flushing file */
|
|
unsigned verbose = 1; /* Whether to emit some informational messages */
|
|
unsigned u; /* Local index variable */
|
|
|
|
block_signals(&oldset);
|
|
|
|
/* Parse command line options */
|
|
if (argc < 2)
|
|
usage();
|
|
if (argc > 1) {
|
|
u = 1;
|
|
while (u < (unsigned)argc) {
|
|
if (argv[u][0] == '-') {
|
|
switch (argv[u][1]) {
|
|
/* # of records to write between flushing file */
|
|
case 'f':
|
|
flush_count = HDatol(argv[u + 1]);
|
|
if (flush_count < 0)
|
|
usage();
|
|
u += 2;
|
|
break;
|
|
|
|
/* Be quiet */
|
|
case 'q':
|
|
verbose = 0;
|
|
u++;
|
|
break;
|
|
|
|
default:
|
|
usage();
|
|
break;
|
|
} /* end switch */
|
|
} /* end if */
|
|
else {
|
|
/* Get the number of records to append */
|
|
nrecords = HDatol(argv[u]);
|
|
if (nrecords <= 0)
|
|
usage();
|
|
|
|
u++;
|
|
} /* end else */
|
|
} /* end while */
|
|
} /* end if */
|
|
if (nrecords <= 0)
|
|
usage();
|
|
if (flush_count >= nrecords)
|
|
usage();
|
|
|
|
/* Emit informational message */
|
|
if (verbose) {
|
|
HDfprintf(stderr, "WRITER: Parameters:\n");
|
|
HDfprintf(stderr, "\t# of records between flushes = %ld\n", flush_count);
|
|
HDfprintf(stderr, "\t# of records to write = %ld\n", nrecords);
|
|
} /* end if */
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Generating symbol names\n");
|
|
|
|
/* Generate dataset names */
|
|
if (generate_symbols() < 0)
|
|
return -1;
|
|
|
|
/* Emit informational message */
|
|
if (verbose) {
|
|
HDfprintf(stderr, "WRITER: Opening skeleton file: %s\n", VFD_SWMR_FILENAME);
|
|
}
|
|
|
|
/* Open file skeleton */
|
|
if ((fid = open_skeleton(VFD_SWMR_FILENAME, verbose)) < 0) {
|
|
HDfprintf(stderr, "WRITER: Error opening skeleton file!\n");
|
|
HDexit(1);
|
|
} /* end if */
|
|
|
|
/* Send a message to indicate "H5Fopen" is complete--releasing the file lock */
|
|
h5_send_message(VFD_SWMR_WRITER_MESSAGE, NULL, NULL);
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Adding records\n");
|
|
|
|
/* Append records to datasets */
|
|
if (add_records(fid, verbose, (unsigned long)nrecords, (unsigned long)flush_count) < 0) {
|
|
HDfprintf(stderr, "WRITER: Error appending records to datasets!\n");
|
|
HDexit(1);
|
|
} /* end if */
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Releasing symbols\n");
|
|
|
|
/* Clean up the symbols */
|
|
if (shutdown_symbols() < 0) {
|
|
HDfprintf(stderr, "WRITER: Error releasing symbols!\n");
|
|
HDexit(1);
|
|
} /* end if */
|
|
|
|
await_signal(fid);
|
|
|
|
restore_signals(&oldset);
|
|
|
|
/* Emit informational message */
|
|
if (verbose)
|
|
HDfprintf(stderr, "WRITER: Closing objects/file\n");
|
|
|
|
/* Close objects opened */
|
|
if (H5Fclose(fid) < 0) {
|
|
HDfprintf(stderr, "WRITER: Error closing file!\n");
|
|
HDexit(1);
|
|
} /* end if */
|
|
|
|
return 0;
|
|
} /* main() */
|
|
|
|
#else /* H5_HAVE_WIN32_API */
|
|
|
|
int
|
|
main(void)
|
|
{
|
|
HDfprintf(stderr, "Non-POSIX platform. Skipping.\n");
|
|
return EXIT_SUCCESS;
|
|
} /* end main() */
|
|
|
|
#endif /* H5_HAVE_WIN32_API */
|