diff options
Diffstat (limited to 'xlators/mgmt/glusterd/src/glusterd-volume-ops.c')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-volume-ops.c | 57 | 
1 files changed, 51 insertions, 6 deletions
| diff --git a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c index fb1832f0d..bc656a091 100644 --- a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c +++ b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c @@ -31,7 +31,7 @@          glusterd_op_stop_volume_args_get (dict, volname, flags)  int -glusterd_handle_create_volume (rpcsvc_request_t *req) +__glusterd_handle_create_volume (rpcsvc_request_t *req)  {          int32_t                 ret         = -1;          gf_cli_req              cli_req     = {{0,}}; @@ -187,7 +187,14 @@ out:  }  int -glusterd_handle_cli_start_volume (rpcsvc_request_t *req) +glusterd_handle_create_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_create_volume); +} + +int +__glusterd_handle_cli_start_volume (rpcsvc_request_t *req)  {          int32_t                         ret = -1;          gf_cli_req                      cli_req = {{0,}}; @@ -252,9 +259,15 @@ out:          return ret;  } +int +glusterd_handle_cli_start_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_cli_start_volume); +}  int -glusterd_handle_cli_stop_volume (rpcsvc_request_t *req) +__glusterd_handle_cli_stop_volume (rpcsvc_request_t *req)  {          int32_t                         ret = -1;          gf_cli_req                      cli_req = {{0,}}; @@ -322,7 +335,14 @@ out:  }  int -glusterd_handle_cli_delete_volume (rpcsvc_request_t *req) +glusterd_handle_cli_stop_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_cli_stop_volume); +} + +int +__glusterd_handle_cli_delete_volume (rpcsvc_request_t *req)  {          int32_t        ret         = -1;          gf_cli_req     cli_req     = {{0,},}; @@ -392,7 +412,14 @@ out:  }  int -glusterd_handle_cli_heal_volume (rpcsvc_request_t *req) +glusterd_handle_cli_delete_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_cli_delete_volume); +} + +int +__glusterd_handle_cli_heal_volume (rpcsvc_request_t *req)  {          int32_t                         ret = -1;          gf_cli_req                      cli_req = {{0,}}; @@ -480,7 +507,14 @@ out:  }  int -glusterd_handle_cli_statedump_volume (rpcsvc_request_t *req) +glusterd_handle_cli_heal_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_cli_heal_volume); +} + +int +__glusterd_handle_cli_statedump_volume (rpcsvc_request_t *req)  {          int32_t                         ret = -1;          gf_cli_req                      cli_req = {{0,}}; @@ -561,6 +595,13 @@ out:          return ret;  } +int +glusterd_handle_cli_statedump_volume (rpcsvc_request_t *req) +{ +        return glusterd_big_locked_handler (req, +                                            __glusterd_handle_cli_statedump_volume); +} +  #ifdef HAVE_BD_XLATOR  int  glusterd_is_valid_vg (const char *name) @@ -1844,7 +1885,9 @@ glusterd_clearlocks_unmount (glusterd_volinfo_t *volinfo, char *mntpt)          runner_add_args (&runner, "/bin/umount", "-f", NULL);          runner_argprintf (&runner, "%s", mntpt); +        synclock_unlock (&priv->big_lock);          ret = runner_run (&runner); +        synclock_lock (&priv->big_lock);          if (ret) {                  ret = 0;                  gf_log ("", GF_LOG_DEBUG, @@ -1916,7 +1959,9 @@ glusterd_clearlocks_mount (glusterd_volinfo_t *volinfo, char **xl_opts,          }          runner_argprintf (&runner, "%s", mntpt); +        synclock_unlock (&priv->big_lock);          ret = runner_run (&runner); +        synclock_lock (&priv->big_lock);          if (ret) {                  gf_log (THIS->name, GF_LOG_DEBUG,                          "Could not start glusterfs"); | 
