summaryrefslogtreecommitdiffstats
path: root/xlators/mgmt
diff options
context:
space:
mode:
Diffstat (limited to 'xlators/mgmt')
-rw-r--r--xlators/mgmt/glusterd/src/glusterd-geo-rep.c43
1 files changed, 40 insertions, 3 deletions
diff --git a/xlators/mgmt/glusterd/src/glusterd-geo-rep.c b/xlators/mgmt/glusterd/src/glusterd-geo-rep.c
index ac07eb83bd8..8299971f6c7 100644
--- a/xlators/mgmt/glusterd/src/glusterd-geo-rep.c
+++ b/xlators/mgmt/glusterd/src/glusterd-geo-rep.c
@@ -1341,6 +1341,15 @@ out:
if (slave_buf)
GF_FREE(slave_buf);
+ if (slave_vol)
+ GF_FREE (slave_vol);
+
+ if (slave_url)
+ GF_FREE (slave_url);
+
+ if (slave_host)
+ GF_FREE (slave_host);
+
gf_msg_debug (this->name, 0, "Returning %d.", ret);
return ret;
}
@@ -1605,6 +1614,15 @@ out:
if (errmsg)
GF_FREE (errmsg);
+ if (slave_url)
+ GF_FREE (slave_url);
+
+ if (slave_vol)
+ GF_FREE (slave_vol);
+
+ if (slave_host)
+ GF_FREE (slave_host);
+
gf_msg_debug (this->name, 0, "Returning %d.", ret);
return ret;
}
@@ -2085,7 +2103,17 @@ _get_slave_status (dict_t *dict, char *key, data_t *value, void *data)
ret = is_geo_rep_active (param->volinfo,slave, conf_path,
&param->is_active);
out:
- GF_FREE(errmsg);
+ if (errmsg)
+ GF_FREE (errmsg);
+
+ if (slave_vol)
+ GF_FREE (slave_vol);
+
+ if (slave_url)
+ GF_FREE (slave_url);
+ if (slave_host)
+ GF_FREE (slave_host);
+
return ret;
}
@@ -2955,9 +2983,15 @@ get_slavehost_from_voluuid (dict_t *dict, char *key, data_t *value, void *data)
/* get corresponding slave host for reference*/
slave_host = value->data;
slave_host = strstr (slave_host, "://");
- if (slave_host)
+ if (slave_host) {
slave_host += 3;
-
+ } else {
+ gf_msg (this->name, GF_LOG_ERROR, 0,
+ GD_MSG_SLAVE_VOL_PARSE_FAIL,
+ "Invalid slave_host format!");
+ ret = -2;
+ goto out;
+ }
/* To go past username in non-root geo-rep session */
tmp = strchr (slave_host, '@');
if (tmp) {
@@ -3435,6 +3469,7 @@ out:
if (ret && errmsg[0] != '\0')
*op_errstr = gf_strdup (errmsg);
+
if (slave_url_buf)
GF_FREE (slave_url_buf);
@@ -4817,6 +4852,8 @@ glusterd_check_restart_gsync_session (glusterd_volinfo_t *volinfo, char *slave,
out:
gf_msg_debug (this->name, 0, "Returning %d", ret);
+ if (op_errstr)
+ GF_FREE (op_errstr);
return ret;
}