diff options
| author | Kaushik BV <kaushikbv@gluster.com> | 2010-10-07 06:37:12 +0000 | 
|---|---|---|
| committer | Vijay Bellur <vijay@dev.gluster.com> | 2010-10-07 05:43:35 -0700 | 
| commit | c7b518ab85f6fbcbdbae64c8fa092e998a14d1e9 (patch) | |
| tree | 4f55db97bf6e843c96637264c8d97219a5b0aa38 /rpc/rpc-lib | |
| parent | f62484f42230db9d240c9b0eaadac48d845053b1 (diff) | |
mgmt/Glusterd: Volume set enhancements
- performance.flush-behind, transport.keepalive added
- volume info to display the options reconfigured
Signed-off-by: Kaushik BV <kaushikbv@gluster.com>
Signed-off-by: Vijay Bellur <vijay@dev.gluster.com>
BUG: 1159 ()
URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=1159
Diffstat (limited to 'rpc/rpc-lib')
| -rw-r--r-- | rpc/rpc-lib/src/rpc-transport.c | 10 | ||||
| -rw-r--r-- | rpc/rpc-lib/src/rpc-transport.h | 11 | 
2 files changed, 19 insertions, 2 deletions
diff --git a/rpc/rpc-lib/src/rpc-transport.c b/rpc/rpc-lib/src/rpc-transport.c index 43b2a0c18cf..2a10a3b7f80 100644 --- a/rpc/rpc-lib/src/rpc-transport.c +++ b/rpc/rpc-lib/src/rpc-transport.c @@ -804,6 +804,8 @@ err:          return NULL;  } + +  rpc_transport_t *  rpc_transport_load (glusterfs_ctx_t *ctx, dict_t *options, char *trans_name)  { @@ -830,7 +832,7 @@ rpc_transport_load (glusterfs_ctx_t *ctx, dict_t *options, char *trans_name)  	type = str;  	/* Backward compatibility */ -	ret = dict_get_str (options, "transport-type", &type); +        ret = dict_get_str (options, "transport-type", &type);  	if (ret < 0) {  		ret = dict_set_str (options, "transport-type", "socket");  		if (ret < 0) @@ -922,6 +924,12 @@ rpc_transport_load (glusterfs_ctx_t *ctx, dict_t *options, char *trans_name)  			"dlsym (gf_rpc_transport_fini) on %s", dlerror ());  		goto fail;  	} +         +        trans->reconfigure = dlsym (handle, "reconfigure"); +        if (trans->fini == NULL) { +                gf_log ("rpc-transport", GF_LOG_DEBUG, +                        "dlsym (gf_rpc_transport_reconfigure) on %s", dlerror()); +        }  	vol_opt = GF_CALLOC (1, sizeof (volume_opt_list_t),                               gf_common_mt_volume_opt_list_t); diff --git a/rpc/rpc-lib/src/rpc-transport.h b/rpc/rpc-lib/src/rpc-transport.h index 478de9ef1c4..560eae45314 100644 --- a/rpc/rpc-lib/src/rpc-transport.h +++ b/rpc/rpc-lib/src/rpc-transport.h @@ -25,6 +25,7 @@  #include "config.h"  #endif +  #include <inttypes.h>  #ifdef GF_SOLARIS_HOST_OS  #include <rpc/auth.h> @@ -34,6 +35,7 @@  #include <rpc/rpc_msg.h> +  #ifndef MAX_IOVEC  #define MAX_IOVEC 16  #endif @@ -172,6 +174,8 @@ typedef struct rpc_transport_pollin rpc_transport_pollin_t;  typedef int (*rpc_transport_notify_t) (rpc_transport_t *, void *mydata,                                         rpc_transport_event_t, void *data, ...); + +  struct rpc_transport {  	struct rpc_transport_ops  *ops;          rpc_transport_t           *listener; /* listener transport to which @@ -179,6 +183,7 @@ struct rpc_transport {                                                * transport came from. valid only                                                * on server process.                                                */ +          	void                      *private;          void                      *xl_private;          void                      *xl;       /* Used for THIS */ @@ -191,8 +196,12 @@ struct rpc_transport {          char                      *name;  	void                      *dnscache;  	data_t                    *buf; -	int32_t                  (*init)   (rpc_transport_t *this); + 	int32_t                  (*init)   (rpc_transport_t *this);  	void                     (*fini)   (rpc_transport_t *this); +        int32_t                  (*validate_options) (rpc_transport_t *this,  +                                                      dict_t *options,  +                                                      char **op_errstr); +        int                      (*reconfigure) (rpc_transport_t *this, dict_t *options);          rpc_transport_notify_t     notify;          void                      *notify_data;  	peer_info_t                peerinfo;  | 
