diff options
| author | Jeff Darcy <jdarcy@redhat.com> | 2017-03-20 12:32:33 -0400 | 
|---|---|---|
| committer | Atin Mukherjee <amukherj@redhat.com> | 2017-03-30 23:33:32 -0400 | 
| commit | a7ce0548b7969050644891cd90c0bf134fa1594c (patch) | |
| tree | 484e634b55b55830e1003c797c8e9e4c47418313 /xlators/mgmt/glusterd/src/glusterd-volume-ops.c | |
| parent | ed89f3ef064b6100bb0731f2493d915f6fb141c3 (diff) | |
glusterd: hold off volume deletes while still restarting bricks
We need to do this because modifying the volume/brick tree while
glusterd_restart_bricks is still walking it can lead to segfaults.
Without waiting we could accidentally "slip in" while attach_brick has
released big_lock between retries and make such a modification.
Change-Id: I30ccc4efa8d286aae847250f5d4fb28956a74b03
BUG: 1432542
Signed-off-by: Jeff Darcy <jeff@pl.atyp.us>
Reviewed-on: https://review.gluster.org/16927
Smoke: Gluster Build System <jenkins@build.gluster.org>
NetBSD-regression: NetBSD Build System <jenkins@build.gluster.org>
CentOS-regression: Gluster Build System <jenkins@build.gluster.org>
Reviewed-by: Atin Mukherjee <amukherj@redhat.com>
Diffstat (limited to 'xlators/mgmt/glusterd/src/glusterd-volume-ops.c')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-volume-ops.c | 3 | 
1 files changed, 0 insertions, 3 deletions
| diff --git a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c index d7983f6fd71..5d164fd8df3 100644 --- a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c +++ b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c @@ -2761,14 +2761,11 @@ glusterd_op_delete_volume (dict_t *dict)  {          int                                     ret = 0;          char                                    *volname = NULL; -        glusterd_conf_t                         *priv = NULL;          glusterd_volinfo_t                      *volinfo = NULL;          xlator_t                                *this = NULL;          this = THIS;          GF_ASSERT (this); -        priv = this->private; -        GF_ASSERT (priv);          ret = dict_get_str (dict, "volname", &volname);          if (ret) { | 
