mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-04-18 17:40:55 +08:00
H5R: set app ref when incrementing ref_count on location held by reference
(fix HDFFV-10992)
This commit is contained in:
parent
c3ae64a875
commit
9c398c804b
@ -383,7 +383,8 @@ H5O__copy_expand_ref_object2(H5O_loc_t *src_oloc, hid_t tid_src, H5T_t *dt_src,
|
||||
H5F_addr_encode(dst_oloc->file, &p, dst_oloc->addr);
|
||||
if(H5R__set_obj_token(ref, (const H5VL_token_t *)&tmp_token, token_size) < 0)
|
||||
HGOTO_ERROR(H5E_OHDR, H5E_CANTSET, FAIL, "unable to set object token")
|
||||
if(H5R__set_loc_id(ref, dst_loc_id, TRUE) < 0)
|
||||
/* Do not set app_ref since references are released once the copy is done */
|
||||
if(H5R__set_loc_id(ref, dst_loc_id, TRUE, FALSE) < 0)
|
||||
HGOTO_ERROR(H5E_OHDR, H5E_CANTSET, FAIL, "unable to set destination loc id")
|
||||
} /* end for */
|
||||
|
||||
|
@ -139,7 +139,7 @@ H5Rcreate_object(hid_t loc_id, const char *name, hid_t oapl_id, H5R_ref_t *ref_p
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCREATE, FAIL, "unable to create object reference")
|
||||
|
||||
/* Attach loc_id to reference and hold reference to it */
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE) < 0)
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "unable to attach location id to reference")
|
||||
|
||||
done:
|
||||
@ -232,7 +232,7 @@ H5Rcreate_region(hid_t loc_id, const char *name, hid_t space_id,
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCREATE, FAIL, "unable to create region reference")
|
||||
|
||||
/* Attach loc_id to reference and hold reference to it */
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE) < 0)
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "unable to attach location id to reference")
|
||||
|
||||
done:
|
||||
@ -321,7 +321,7 @@ H5Rcreate_attr(hid_t loc_id, const char *name, const char *attr_name,
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCREATE, FAIL, "unable to create attribute reference")
|
||||
|
||||
/* Attach loc_id to reference and hold reference to it */
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE) < 0)
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref_ptr, file_id, TRUE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "unable to attach location id to reference")
|
||||
|
||||
done:
|
||||
|
39
src/H5Rint.c
39
src/H5Rint.c
@ -433,8 +433,15 @@ H5R__destroy(H5R_ref_priv_t *ref)
|
||||
} /* end switch */
|
||||
|
||||
/* Decrement refcount of attached loc_id */
|
||||
if(ref->type && (ref->loc_id != H5I_INVALID_HID) && (H5I_dec_ref(ref->loc_id) < 0))
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
if(ref->type && (ref->loc_id != H5I_INVALID_HID)) {
|
||||
if(ref->app_ref) {
|
||||
if(H5I_dec_app_ref(ref->loc_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
} else {
|
||||
if(H5I_dec_ref(ref->loc_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
}
|
||||
}
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -451,7 +458,7 @@ done:
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
herr_t
|
||||
H5R__set_loc_id(H5R_ref_priv_t *ref, hid_t id, hbool_t inc_ref)
|
||||
H5R__set_loc_id(H5R_ref_priv_t *ref, hid_t id, hbool_t inc_ref, hbool_t app_ref)
|
||||
{
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
@ -460,14 +467,26 @@ H5R__set_loc_id(H5R_ref_priv_t *ref, hid_t id, hbool_t inc_ref)
|
||||
HDassert(ref != NULL);
|
||||
HDassert(id != H5I_INVALID_HID);
|
||||
|
||||
/* If a location ID was previously assigned, decrement refcount and assign new one */
|
||||
if((ref->loc_id != H5I_INVALID_HID) && (H5I_dec_ref(ref->loc_id) < 0))
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
/* If a location ID was previously assigned, decrement refcount and
|
||||
* assign new one */
|
||||
if((ref->loc_id != H5I_INVALID_HID)) {
|
||||
if(ref->app_ref) {
|
||||
if(H5I_dec_app_ref(ref->loc_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
} else {
|
||||
if(H5I_dec_ref(ref->loc_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "decrementing location ID failed")
|
||||
}
|
||||
}
|
||||
ref->loc_id = id;
|
||||
|
||||
/* Prevent location ID from being freed until reference is destroyed */
|
||||
if(inc_ref && H5I_inc_ref(ref->loc_id, FALSE) < 0)
|
||||
/* Prevent location ID from being freed until reference is destroyed,
|
||||
* set app_ref if necessary as references are exposed to users and are
|
||||
* expected to be destroyed, this allows the loc_id to be cleanly released
|
||||
* on shutdown if users fail to call H5Rdestroy(). */
|
||||
if(inc_ref && H5I_inc_ref(ref->loc_id, app_ref) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINC, FAIL, "incrementing location ID failed")
|
||||
ref->app_ref = app_ref;
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -559,7 +578,7 @@ H5R__reopen_file(H5R_ref_priv_t *ref, hid_t fapl_id)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, H5I_INVALID_HID, "unable to make file 'post open' callback")
|
||||
|
||||
/* Attach loc_id to reference */
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref, ret_value, FALSE) < 0)
|
||||
if(H5R__set_loc_id((H5R_ref_priv_t *)ref, ret_value, FALSE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, H5I_INVALID_HID, "unable to attach location id to reference")
|
||||
|
||||
done:
|
||||
@ -711,7 +730,7 @@ H5R__copy(const H5R_ref_priv_t *src_ref, H5R_ref_priv_t *dst_ref)
|
||||
dst_ref->ref.obj.filename = NULL;
|
||||
|
||||
/* Set location ID and hold reference to it */
|
||||
if(H5R__set_loc_id(dst_ref, src_ref->loc_id, TRUE) < 0)
|
||||
if(H5R__set_loc_id(dst_ref, src_ref->loc_id, TRUE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "cannot set reference location ID")
|
||||
}
|
||||
|
||||
|
@ -79,7 +79,7 @@ typedef struct H5R_ref_priv_t {
|
||||
uint32_t encode_size; /* Cached encoding size */
|
||||
int8_t type; /* Reference type */
|
||||
uint8_t token_size; /* Cached token size */
|
||||
char unused[18]; /* Unused */
|
||||
hbool_t app_ref; /* App ref on loc_id */
|
||||
} H5R_ref_priv_t;
|
||||
|
||||
/*****************************/
|
||||
@ -95,7 +95,7 @@ H5_DLL herr_t H5R__create_region(const H5VL_token_t *obj_token, size_t token_s
|
||||
H5_DLL herr_t H5R__create_attr(const H5VL_token_t *obj_token, size_t token_size, const char *attr_name, H5R_ref_priv_t *ref);
|
||||
H5_DLL herr_t H5R__destroy(H5R_ref_priv_t *ref);
|
||||
|
||||
H5_DLL herr_t H5R__set_loc_id(H5R_ref_priv_t *ref, hid_t id, hbool_t inc_ref);
|
||||
H5_DLL herr_t H5R__set_loc_id(H5R_ref_priv_t *ref, hid_t id, hbool_t inc_ref, hbool_t app_ref);
|
||||
H5_DLL hid_t H5R__get_loc_id(const H5R_ref_priv_t *ref);
|
||||
H5_DLL hid_t H5R__reopen_file(H5R_ref_priv_t *ref, hid_t fapl_id);
|
||||
|
||||
|
@ -622,8 +622,9 @@ H5T__ref_mem_write(H5VL_object_t *src_file, const void *src_buf, size_t src_size
|
||||
if((file_id = H5F_get_file_id(src_file, H5I_FILE, FALSE)) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a file or file object")
|
||||
|
||||
/* Attach loc ID to reference and hold reference to it */
|
||||
if(H5R__set_loc_id(dst_ref, file_id, TRUE) < 0)
|
||||
/* Attach loc ID to reference and hold reference to it, this is a
|
||||
* user exposed reference so set app_ref to TRUE. */
|
||||
if(H5R__set_loc_id(dst_ref, file_id, TRUE, TRUE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "unable to attach location id to reference")
|
||||
} /* end if */
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user