diff options
| author | Amar Tumballi <amar@gluster.com> | 2011-06-08 09:18:43 +0000 | 
|---|---|---|
| committer | Anand Avati <avati@gluster.com> | 2011-06-08 11:19:17 -0700 | 
| commit | c9f61338fadc69ad1da6f8100fe0c37057d622a0 (patch) | |
| tree | 040f6020253ca76aecaad3f8bb7fd22a419823b2 /glusterfsd | |
| parent | 84eca97a940fc1cad339e9238528c29cfcf9ac42 (diff) | |
fix multiple transport related portmap issues in client handshake
Signed-off-by: Amar Tumballi <amar@gluster.com>
Signed-off-by: Anand Avati <avati@gluster.com>
BUG: 2294 (Currently there is no way through cli to make a volume listen on both the transports (socket/rdma))
URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=2294
Diffstat (limited to 'glusterfsd')
| -rw-r--r-- | glusterfsd/src/glusterfsd-mgmt.c | 60 | ||||
| -rw-r--r-- | glusterfsd/src/glusterfsd.c | 14 | 
2 files changed, 73 insertions, 1 deletions
diff --git a/glusterfsd/src/glusterfsd-mgmt.c b/glusterfsd/src/glusterfsd-mgmt.c index 1e10056ac07..ef9afaf2374 100644 --- a/glusterfsd/src/glusterfsd-mgmt.c +++ b/glusterfsd/src/glusterfsd-mgmt.c @@ -899,12 +899,51 @@ out:  }  static int +mgmt_pmap_signin2_cbk (struct rpc_req *req, struct iovec *iov, int count, +                       void *myframe) +{ +        pmap_signin_rsp  rsp   = {0,}; +        call_frame_t    *frame = NULL; +        int              ret   = 0; + +        frame = myframe; + +        if (-1 == req->rpc_status) { +                rsp.op_ret   = -1; +                rsp.op_errno = EINVAL; +                goto out; +        } + +        ret = xdr_to_pmap_signin_rsp (*iov, &rsp); +        if (ret < 0) { +                gf_log (frame->this->name, GF_LOG_ERROR, "XDR decode error"); +                rsp.op_ret   = -1; +                rsp.op_errno = EINVAL; +                goto out; +        } + +        if (-1 == rsp.op_ret) { +                gf_log (frame->this->name, GF_LOG_ERROR, +                        "failed to register the port with glusterd"); +                goto out; +        } +out: +        STACK_DESTROY (frame->root); +        return 0; + +} + +static int  mgmt_pmap_signin_cbk (struct rpc_req *req, struct iovec *iov, int count,                        void *myframe)  {          pmap_signin_rsp  rsp   = {0,};          call_frame_t    *frame = NULL;          int              ret   = 0; +        pmap_signin_req  pmap_req = {0, }; +        cmd_args_t      *cmd_args = NULL; +        glusterfs_ctx_t *ctx      = NULL; +        char             brick_name[PATH_MAX] = {0,};          frame = myframe; @@ -927,6 +966,27 @@ mgmt_pmap_signin_cbk (struct rpc_req *req, struct iovec *iov, int count,                          "failed to register the port with glusterd");                  goto out;          } + +        ctx = glusterfs_ctx_get (); +        cmd_args = &ctx->cmd_args; + +        if (!cmd_args->brick_port2) { +                /* We are done with signin process */ +                goto out; +        } + +        snprintf (brick_name, PATH_MAX, "%s.rdma", cmd_args->brick_name); +        pmap_req.port  = cmd_args->brick_port2; +        pmap_req.brick = brick_name; + +        ret = mgmt_submit_request (&pmap_req, frame, ctx, &clnt_pmap_prog, +                                   GF_PMAP_SIGNIN, xdr_from_pmap_signin_req, +                                   mgmt_pmap_signin2_cbk); +        if (ret) +                goto out; + +        return 0; +  out:          STACK_DESTROY (frame->root); diff --git a/glusterfsd/src/glusterfsd.c b/glusterfsd/src/glusterfsd.c index 9406d74ac63..9a39570d7cd 100644 --- a/glusterfsd/src/glusterfsd.c +++ b/glusterfsd/src/glusterfsd.c @@ -453,6 +453,8 @@ parse_opts (int key, char *arg, struct argp_state *state)          gf_boolean_t  b             = _gf_false;          char         *pwd           = NULL;          char          tmp_buf[2048] = {0,}; +        char         *tmp_str       = NULL; +        char         *port_str      = NULL;          cmd_args = state->input; @@ -671,8 +673,18 @@ parse_opts (int key, char *arg, struct argp_state *state)          case ARGP_BRICK_PORT_KEY:                  n = 0; -                if (gf_string2uint_base10 (arg, &n) == 0) { +                port_str = strtok_r (arg, ",", &tmp_str); +                if (gf_string2uint_base10 (port_str, &n) == 0) {                          cmd_args->brick_port = n; +                        port_str = strtok_r (NULL, ",", &tmp_str); +                        if (port_str) { +                                if (gf_string2uint_base10 (port_str, &n) == 0) +                                        cmd_args->brick_port2 = n; +                                break; + +                                argp_failure (state, -1, 0, +                                              "wrong brick (listen) port %s", arg); +                        }                          break;                  }  | 
