diff options
| -rw-r--r-- | cli/src/cli-rpc-ops.c | 19 | ||||
| -rw-r--r-- | cli/src/cli-xml-output.c | 12 | ||||
| -rw-r--r-- | xlators/protocol/client/src/client-handshake.c | 6 | ||||
| -rw-r--r-- | xlators/protocol/server/src/server-handshake.c | 18 | ||||
| -rw-r--r-- | xlators/protocol/server/src/server-messages.h | 11 | ||||
| -rw-r--r-- | xlators/protocol/server/src/server.c | 8 | 
6 files changed, 67 insertions, 7 deletions
diff --git a/cli/src/cli-rpc-ops.c b/cli/src/cli-rpc-ops.c index 97cf7410aea..2ecee81daee 100644 --- a/cli/src/cli-rpc-ops.c +++ b/cli/src/cli-rpc-ops.c @@ -7229,6 +7229,7 @@ cli_print_volume_status_clients (dict_t *dict, gf_boolean_t notbrick)          char            *clientname = NULL;          uint64_t        bytesread = 0;          uint64_t        byteswrite = 0; +        uint32_t        opversion = 0;          char            key[1024] = {0,};          int             i = 0;          int             j = 0; @@ -7294,10 +7295,10 @@ cli_print_volume_status_clients (dict_t *dict, gf_boolean_t notbrick)                  if (client_count == 0)                          continue; -                cli_out ("%-48s %15s %15s", "Hostname", "BytesRead", -                         "BytesWritten"); -                cli_out ("%-48s %15s %15s", "--------", "---------", -                         "------------"); +                cli_out ("%-48s %15s %15s %15s", "Hostname", "BytesRead", +                         "BytesWritten", "OpVersion"); +                cli_out ("%-48s %15s %15s %15s", "--------", "---------", +                         "------------", "---------");                  for (j =0; j < client_count; j++) {                          memset (key, 0, sizeof (key));                          snprintf (key, sizeof (key), @@ -7314,8 +7315,14 @@ cli_print_volume_status_clients (dict_t *dict, gf_boolean_t notbrick)                                   "brick%d.client%d.byteswrite", i, j);                          ret = dict_get_uint64 (dict, key, &byteswrite); -                        cli_out ("%-48s %15"PRIu64" %15"PRIu64, -                                 clientname, bytesread, byteswrite); +                        memset (key, 0, sizeof (key)); +                        snprintf (key, sizeof (key), +                                 "brick%d.client%d.opversion", i, j); +                        ret = dict_get_uint32 (dict, key, &opversion); + +                        cli_out ("%-48s %15"PRIu64" %15"PRIu64" %15"PRIu32, +                                  clientname, bytesread, byteswrite, +                                  opversion);                  }          }  out: diff --git a/cli/src/cli-xml-output.c b/cli/src/cli-xml-output.c index fe03ea17265..3de7d064bec 100644 --- a/cli/src/cli-xml-output.c +++ b/cli/src/cli-xml-output.c @@ -743,6 +743,7 @@ cli_xml_output_vol_status_clients (xmlTextWriterPtr writer, dict_t *dict,          char            *hostname = NULL;          uint64_t        bytes_read = 0;          uint64_t        bytes_write = 0; +        uint32_t        opversion = 0;          char            key[1024] = {0,};          int             i = 0; @@ -797,6 +798,17 @@ cli_xml_output_vol_status_clients (xmlTextWriterPtr writer, dict_t *dict,                                                         "%"PRIu64, bytes_write);                  XML_RET_CHECK_AND_GOTO (ret, out); +                memset (key, 0, sizeof (key)); +                snprintf (key, sizeof (key), "brick%d.client%d.opversion", +                          brick_index, i); +                ret = dict_get_uint32 (dict, key, &opversion); +                if (ret) +                        goto out; +                ret = xmlTextWriterWriteFormatElement (writer, +                                                       (xmlChar *)"opVersion", +                                                       "%"PRIu32, opversion); +                XML_RET_CHECK_AND_GOTO (ret, out); +                  /* </client> */                  ret = xmlTextWriterEndElement (writer);                  XML_RET_CHECK_AND_GOTO (ret, out); diff --git a/xlators/protocol/client/src/client-handshake.c b/xlators/protocol/client/src/client-handshake.c index adccd8d4e51..354b9167810 100644 --- a/xlators/protocol/client/src/client-handshake.c +++ b/xlators/protocol/client/src/client-handshake.c @@ -1387,6 +1387,12 @@ client_setvolume (xlator_t *this, struct rpc_clnt *rpc)                          "msg", client_get_lk_ver (conf));          } +        ret = dict_set_int32 (options, "opversion", GD_OP_VERSION_MAX); +        if (ret < 0) { +                gf_msg (this->name, GF_LOG_ERROR, 0, PC_MSG_DICT_SET_FAILED, +                        "Failed to set client opversion in handshake message"); +        } +          ret = dict_serialized_length (options);          if (ret < 0) {                  gf_msg (this->name, GF_LOG_ERROR, 0, PC_MSG_DICT_ERROR, diff --git a/xlators/protocol/server/src/server-handshake.c b/xlators/protocol/server/src/server-handshake.c index 1230cdf7ab5..a33efb8c33a 100644 --- a/xlators/protocol/server/src/server-handshake.c +++ b/xlators/protocol/server/src/server-handshake.c @@ -431,6 +431,8 @@ server_setvolume (rpcsvc_request_t *req)          uint32_t             lk_version    = 0;          char                *buf           = NULL;          gf_boolean_t        cancelled      = _gf_false; +        uint32_t            opversion      = 0; +        rpc_transport_t     *xprt          = NULL;          params = dict_new ();          reply  = dict_new (); @@ -669,6 +671,22 @@ server_setvolume (rpcsvc_request_t *req)                          gf_msg_debug (this->name, 0, "failed to set "                                        "peer-info");          } + +        ret = dict_get_uint32 (params, "opversion", &opversion); +        if (ret) +                gf_msg (this->name, GF_LOG_INFO, 0, +                        PS_MSG_CLIENT_OPVERSION_GET_FAILED, +                        "Failed to get client opversion"); + +        /* Assign op-version value to the client */ +        pthread_mutex_lock (&conf->mutex); +        list_for_each_entry (xprt, &conf->xprt_list, list) { +                if (strcmp (peerinfo->identifier, xprt->peerinfo.identifier)) +                        continue; +                xprt->peerinfo.max_op_version = opversion; +        } +        pthread_mutex_unlock (&conf->mutex); +          if (conf->auth_modules == NULL) {                  gf_msg (this->name, GF_LOG_ERROR, 0, PS_MSG_AUTH_INIT_FAILED,                          "Authentication module not initialized"); diff --git a/xlators/protocol/server/src/server-messages.h b/xlators/protocol/server/src/server-messages.h index 5593e68d3d4..b8245af18df 100644 --- a/xlators/protocol/server/src/server-messages.h +++ b/xlators/protocol/server/src/server-messages.h @@ -40,7 +40,7 @@   */  #define GLFS_PS_BASE                GLFS_MSGID_COMP_PS -#define GLFS_NUM_MESSAGES           90 +#define GLFS_NUM_MESSAGES           91  #define GLFS_MSGID_END              (GLFS_PS_BASE + GLFS_NUM_MESSAGES + 1)  /* Messages with message IDs */  #define glfs_msg_start_x GLFS_PS_BASE, "Invalid: Start of messages" @@ -848,6 +848,15 @@   */  #define PS_MSG_COMPOUND_INFO                    (GLFS_PS_BASE + 90) + +/*! + * @messageid + * @diagnosis + * @recommendedaction + * + */ + +#define PS_MSG_CLIENT_OPVERSION_GET_FAILED      (GLFS_PS_BASE + 91)  /*------------*/  #define glfs_msg_end_x GLFS_MSGID_END, "Invalid: End of messages" diff --git a/xlators/protocol/server/src/server.c b/xlators/protocol/server/src/server.c index af3adb36ef2..db2f06ad582 100644 --- a/xlators/protocol/server/src/server.c +++ b/xlators/protocol/server/src/server.c @@ -275,6 +275,14 @@ server_priv_to_dict (xlator_t *this, dict_t *dict)                          if (ret)                                  goto unlock; +                        memset (key, 0, sizeof (key)); +                        snprintf (key, sizeof (key), "client%d.opversion", +                                  count); +                        ret = dict_set_uint32 (dict, key, +                                               peerinfo->max_op_version); +                        if (ret) +                                goto unlock; +                          count++;                  }          }  | 
