summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMohamad Chaarawi <chaarawi@hdfgroup.org>2014-03-07 14:37:09 (GMT)
committerMohamad Chaarawi <chaarawi@hdfgroup.org>2014-03-07 14:37:09 (GMT)
commit871ebb02cfb10f459ca3c7329d22d40dbc530095 (patch)
tree369c613673937e93f3c7c780aa7f0e6e332245de
parent36eb8049c75aa7367cdeee28f115356a230b454b (diff)
downloadhdf5-871ebb02cfb10f459ca3c7329d22d40dbc530095.zip
hdf5-871ebb02cfb10f459ca3c7329d22d40dbc530095.tar.gz
hdf5-871ebb02cfb10f459ca3c7329d22d40dbc530095.tar.bz2
[svn-r24768] Add persist rety goverened by ENV variable:
H5ENV_NUM_PERSIST_RETRY - default 0 Add sleep before persist retry goverened by variable: H5ENV_SLEEP_PERSIST_RETRY - default 0
-rw-r--r--src/H5VLiod_trans.c44
1 files changed, 41 insertions, 3 deletions
diff --git a/src/H5VLiod_trans.c b/src/H5VLiod_trans.c
index 1dd41cb..0fb64d8 100644
--- a/src/H5VLiod_trans.c
+++ b/src/H5VLiod_trans.c
@@ -248,7 +248,11 @@ H5VL_iod_server_rcxt_persist_cb(AXE_engine_t UNUSED axe_engine,
{
op_data_t *op_data = (op_data_t *)_op_data;
rc_persist_in_t *input = (rc_persist_in_t *)op_data->input;
- iod_handle_t coh = input->coh; /* the container handle */
+ iod_handle_t coh = input->coh; /* the container handle */
+ char *persist = NULL, *sleep_timer = NULL;
+ int num_persist_retry = 0, i;
+ int sleep_t = 0;
+ iod_ret_t ret;
herr_t ret_value = SUCCEED;
FUNC_ENTER_NOAPI_NOINIT
@@ -257,8 +261,42 @@ H5VL_iod_server_rcxt_persist_cb(AXE_engine_t UNUSED axe_engine,
fprintf(stderr, "Persist Read Context %"PRIu64"\n", input->c_version);
#endif
- if(iod_trans_persist(coh, input->c_version, NULL, NULL) < 0)
- HGOTO_ERROR2(H5E_SYM, H5E_CANTSET, FAIL, "can't persist Read Context");
+ persist = getenv ("H5ENV_NUM_PERSIST_RETRY");
+ sleep_timer = getenv ("H5ENV_SLEEP_PERSIST_RETRY");
+
+ if(NULL != persist)
+ num_persist_retry = atoi(persist);
+
+ if(NULL != sleep_timer)
+ sleep_t = atoi(sleep_timer);
+
+ ret = iod_trans_persist(coh, input->c_version, NULL, NULL);
+ if(ret != 0) {
+ fprintf(stderr, "%d (%s).\n", ret, strerror(-ret));
+ }
+
+ if(ret != 0) {
+ for(i=0 ; i<num_persist_retry; i++) {
+ fprintf(stderr, "Retry Persist # %d on %"PRIu64".\n", i+1, input->c_version);
+ ret = iod_trans_persist(coh, input->c_version, NULL, NULL);
+ if(0 == ret) {
+ break;
+ }
+ else if(-ESHUTDOWN == ret) {
+ fprintf(stderr, "%d (%s).\n", ret, strerror(-ret));
+ HGOTO_ERROR2(H5E_SYM, H5E_CANTINIT, FAIL, "can't persist read context");
+ }
+ else {
+ fprintf(stderr, "Retry failed.. %d (%s).\n", ret, strerror(-ret));
+ if(sleep_timer)
+ sleep(sleep_t);
+ }
+ }
+ }
+
+ if(ret != 0) {
+ HGOTO_ERROR2(H5E_SYM, H5E_CANTINIT, FAIL, "can't persist read context");
+ }
done:
if(HG_SUCCESS != HG_Handler_start_output(op_data->hg_handle, &ret_value))