mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
Revert some of the changes to support the original property list value of
metadata read attempts.
This commit is contained in:
parent
d0d360ff2d
commit
6c99961bb2
@ -219,7 +219,7 @@ H5F_get_access_plist(H5F_t *f, hbool_t app_ref)
|
||||
HGOTO_ERROR(H5E_FILE, H5E_CANTSET, H5I_INVALID_HID, "can't set 'low' bound for library format versions")
|
||||
if(H5P_set(new_plist, H5F_ACS_LIBVER_HIGH_BOUND_NAME, &f->shared->high_bound) < 0)
|
||||
HGOTO_ERROR(H5E_FILE, H5E_CANTSET, H5I_INVALID_HID, "can't set 'high' bound for library format versions")
|
||||
if(H5P_set(new_plist, H5F_ACS_METADATA_READ_ATTEMPTS_NAME, &(f->shared->orig_read_attempts)) < 0)
|
||||
if(H5P_set(new_plist, H5F_ACS_METADATA_READ_ATTEMPTS_NAME, &(f->shared->read_attempts)) < 0)
|
||||
HGOTO_ERROR(H5E_FILE, H5E_CANTSET, H5I_INVALID_HID, "can't set 'read attempts ' flag")
|
||||
if(H5P_set(new_plist, H5F_ACS_OBJECT_FLUSH_CB_NAME, &(f->shared->object_flush)) < 0)
|
||||
HGOTO_ERROR(H5E_FILE, H5E_CANTSET, H5I_INVALID_HID, "can't set object flush callback")
|
||||
@ -1046,9 +1046,8 @@ H5F__new(H5F_file_t *shared, unsigned flags, hid_t fcpl_id, hid_t fapl_id, H5FD_
|
||||
f->shared->use_tmp_space = !H5F_HAS_FEATURE(f, H5FD_FEAT_HAS_MPI);
|
||||
|
||||
/* Retrieve the # of read attempts here so that sohm in superblock will get the correct # of attempts */
|
||||
if(H5P_get(plist, H5F_ACS_METADATA_READ_ATTEMPTS_NAME, &f->shared->orig_read_attempts) < 0)
|
||||
if(H5P_get(plist, H5F_ACS_METADATA_READ_ATTEMPTS_NAME, &f->shared->read_attempts) < 0)
|
||||
HGOTO_ERROR(H5E_PLIST, H5E_CANTGET, NULL, "can't get the # of read attempts")
|
||||
f->shared->read_attempts = f->shared->orig_read_attempts;
|
||||
|
||||
/* When opening file with SWMR access, the # of read attempts is H5F_SWMR_METADATA_READ_ATTEMPTS if not set */
|
||||
/* When opening file without SWMR access, the # of read attempts is always H5F_METADATA_READ_ATTEMPTS (set or not set) */
|
||||
|
@ -353,7 +353,6 @@ struct H5F_file_t {
|
||||
|
||||
/* Metadata retry info */
|
||||
unsigned read_attempts; /* The # of reads to try when reading metadata with checksum */
|
||||
unsigned orig_read_attempts; /* Original value from the property: The # of reads to try when reading metadata with checksum */
|
||||
unsigned retries_nbins; /* # of bins for each retries[] */
|
||||
uint32_t *retries[H5AC_NTYPES]; /* Track # of read retries for metdata items with checksum */
|
||||
|
||||
|
11
test/vol.c
11
test/vol.c
@ -256,6 +256,15 @@ test_basic_file_operation(void)
|
||||
/* Retrieve the file access property for testing */
|
||||
fapl_id = h5_fileaccess();
|
||||
|
||||
/* Set the file close degree to a non-default value, to make the H5Pequal
|
||||
* work out. This is kinda odd, but the library's current behavior with
|
||||
* a default value is to return the value chosen (H5F_CLOSE_SEMI) instead
|
||||
* of the default value (H5F_CLOSE_DEFAULT) from the property and then
|
||||
* the H5Pequal doesn't detect that the property lists are the same. Since
|
||||
* this is the documented behavior for file close degree for many years,
|
||||
* I'm not fighting it, just getting the testing to verify that the VOL
|
||||
* connector property is returned correctly. -QAK, 2018/11/17
|
||||
*/
|
||||
/* Set the file close degree to a non-default value, to make the H5Pequal
|
||||
* work out. This is kinda odd, but the library's current behavior with
|
||||
* a default value is to return the value chosen (H5F_CLOSE_SEMI) instead
|
||||
@ -267,6 +276,8 @@ test_basic_file_operation(void)
|
||||
*/
|
||||
if(H5Pset_fclose_degree(fapl_id, H5F_CLOSE_SEMI) < 0)
|
||||
TEST_ERROR;
|
||||
if(H5Pset_metadata_read_attempts(fapl_id, 9) < 0)
|
||||
FAIL_STACK_ERROR
|
||||
|
||||
/* H5Fcreate */
|
||||
if ((fid = H5Fcreate(NATIVE_VOL_TEST_FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, fapl_id)) < 0)
|
||||
|
Loading…
x
Reference in New Issue
Block a user