diff options
author | Soumya Koduri <skoduri@redhat.com> | 2015-03-30 16:56:59 +0530 |
---|---|---|
committer | Kaleb KEITHLEY <kkeithle@redhat.com> | 2015-04-30 04:51:46 -0700 |
commit | 2bf85951c6c25aa17acc591fabc3b3927b6dc82f (patch) | |
tree | 8db692b3c4f833f3a075cb5fb58195dda9004280 /xlators/protocol/client/src | |
parent | 288e02853d913b96e4d6bce9afb16da7d891546f (diff) |
Upcall: Process each of the upcall events separately
As suggested during the code-review of Bug1200262, have modified
GF_CBK_UPCALL to be exlusively GF_CBK_CACHE_INVALIDATION.
Thus, for any new upcall event, a new CBK procedure will be added.
Also made changes to store upcall data separately based on the
upcall event type received.
BUG: 1200262
Change-Id: I0f5e53d6f5ece16aecb514a0a426dca40fa1c755
Signed-off-by: Soumya Koduri <skoduri@redhat.com>
Reviewed-on: http://review.gluster.org/10049
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Kaleb KEITHLEY <kkeithle@redhat.com>
Diffstat (limited to 'xlators/protocol/client/src')
-rw-r--r-- | xlators/protocol/client/src/client-callback.c | 34 |
1 files changed, 21 insertions, 13 deletions
diff --git a/xlators/protocol/client/src/client-callback.c b/xlators/protocol/client/src/client-callback.c index fdfb3dc313b..722db7d0f5f 100644 --- a/xlators/protocol/client/src/client-callback.c +++ b/xlators/protocol/client/src/client-callback.c @@ -42,30 +42,36 @@ client_cbk_ino_flush (struct rpc_clnt *rpc, void *mydata, void *data) } int -client_cbk_upcall (struct rpc_clnt *rpc, void *mydata, void *data) +client_cbk_cache_invalidation (struct rpc_clnt *rpc, void *mydata, void *data) { - int ret = -1; - gfs3_upcall_req up_req; - struct gf_upcall upcall_data; - struct iovec *iov = NULL; + int ret = -1; + struct iovec *iov = NULL; + struct gf_upcall upcall_data = {0,}; + uuid_t gfid; + struct gf_upcall_cache_invalidation ca_data = {0,}; + gfs3_cbk_cache_invalidation_req ca_req = {{0,},}; - gf_log (THIS->name, GF_LOG_TRACE, - "Upcall callback is called"); + gf_log (THIS->name, GF_LOG_TRACE, "Upcall callback is called"); if (!rpc || !mydata || !data) goto out; iov = (struct iovec *)data; - ret = xdr_to_generic (*iov, &up_req, - (xdrproc_t)xdr_gfs3_upcall_req); + ret = xdr_to_generic (*iov, &ca_req, + (xdrproc_t)xdr_gfs3_cbk_cache_invalidation_req); - if (ret < 0) + if (ret < 0) { + gf_log (THIS->name, GF_LOG_WARNING, + "XDR decode of cache_invalidation failed."); goto out; + } - gf_proto_upcall_to_upcall (&up_req, &upcall_data); + upcall_data.data = &ca_data; + gf_proto_cache_invalidation_to_upcall (&ca_req, &upcall_data); + memcpy (gfid, ca_req.gfid, 16); gf_log (THIS->name, GF_LOG_TRACE, "Upcall gfid = %s, ret = %d", - (char *)(up_req.gfid), ret); + uuid_utoa (gfid), ret); default_notify (THIS, GF_EVENT_UPCALL, &upcall_data); @@ -77,7 +83,9 @@ rpcclnt_cb_actor_t gluster_cbk_actors[GF_CBK_MAXVALUE] = { [GF_CBK_NULL] = {"NULL", GF_CBK_NULL, client_cbk_null }, [GF_CBK_FETCHSPEC] = {"FETCHSPEC", GF_CBK_FETCHSPEC, client_cbk_fetchspec }, [GF_CBK_INO_FLUSH] = {"INO_FLUSH", GF_CBK_INO_FLUSH, client_cbk_ino_flush }, - [GF_CBK_UPCALL] = {"UPCALL", GF_CBK_UPCALL, client_cbk_upcall }, + [GF_CBK_CACHE_INVALIDATION] = {"CACHE_INVALIDATION", + GF_CBK_CACHE_INVALIDATION, + client_cbk_cache_invalidation }, }; |