diff options
| author | Soumya Koduri <skoduri@redhat.com> | 2015-04-14 04:03:36 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2015-05-07 04:19:41 -0700 | 
| commit | a53eddfac357400faf636e28b10cd184c53301c5 (patch) | |
| tree | e5500d7de63bed0a69a25bf4f01e61da435a4225 /rpc/xdr | |
| parent | ea8d9ebafa4a6afb99721022e638292fd475ed62 (diff) | |
Upcall: Replaced opaque gfid with string in rpc cbk args
For GF_CBK_CACHE_INVALIDATION, have changed the type of gfid
to be string (cannonical form) instead of opaque byte format
to ensure correctness across platforms supporting different
endianness.
BUG: 1217711
Change-Id: Iac4372714f4b4ebcd9c4393aaf46ceba3f37f587
Signed-off-by: Soumya Koduri <skoduri@redhat.com>
Reviewed-on: http://review.gluster.org/10224
Reviewed-by: Kaleb KEITHLEY <kkeithle@redhat.com>
Reviewed-on: http://review.gluster.org/10563
Tested-by: NetBSD Build System
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Diffstat (limited to 'rpc/xdr')
| -rw-r--r-- | rpc/xdr/src/glusterfs3-xdr.x | 2 | ||||
| -rw-r--r-- | rpc/xdr/src/glusterfs3.h | 15 | 
2 files changed, 13 insertions, 4 deletions
| diff --git a/rpc/xdr/src/glusterfs3-xdr.x b/rpc/xdr/src/glusterfs3-xdr.x index f0cd4cbc953..5304a26da3a 100644 --- a/rpc/xdr/src/glusterfs3-xdr.x +++ b/rpc/xdr/src/glusterfs3-xdr.x @@ -45,7 +45,7 @@ struct gf_iatt {  struct gfs3_cbk_cache_invalidation_req { -        opaque         gfid[16]; +        string         gfid<>;          unsigned int   event_type; /* Upcall event type */          unsigned int   flags;  /* or mask of events incase of inotify */          unsigned int   expire_time_attr; /* the amount of time which client diff --git a/rpc/xdr/src/glusterfs3.h b/rpc/xdr/src/glusterfs3.h index 2acdfc756c4..6808064cb95 100644 --- a/rpc/xdr/src/glusterfs3.h +++ b/rpc/xdr/src/glusterfs3.h @@ -273,6 +273,7 @@ gf_proto_cache_invalidation_from_upcall (gfs3_cbk_cache_invalidation_req *gf_c_r  {          struct gf_upcall_cache_invalidation *gf_c_data = NULL;          int    is_cache_inval                          = 0; +        int    ret                                     = -1;          GF_VALIDATE_OR_GOTO(THIS->name, gf_c_req, out);          GF_VALIDATE_OR_GOTO(THIS->name, gf_up_data, out); @@ -284,7 +285,7 @@ gf_proto_cache_invalidation_from_upcall (gfs3_cbk_cache_invalidation_req *gf_c_r          gf_c_data = (struct gf_upcall_cache_invalidation *)gf_up_data->data;          GF_VALIDATE_OR_GOTO(THIS->name, gf_c_data, out); -        memcpy (gf_c_req->gfid, gf_up_data->gfid, 16); +        gf_c_req->gfid = uuid_utoa (gf_up_data->gfid);          gf_c_req->event_type       = gf_up_data->event_type;          gf_c_req->flags            = gf_c_data->flags;          gf_c_req->expire_time_attr = gf_c_data->expire_time_attr; @@ -298,6 +299,7 @@ gf_proto_cache_invalidation_to_upcall (gfs3_cbk_cache_invalidation_req *gf_c_req                                         struct gf_upcall *gf_up_data)  {          struct gf_upcall_cache_invalidation *gf_c_data = NULL; +        int    ret                                     = -1;          GF_VALIDATE_OR_GOTO(THIS->name, gf_c_req, out);          GF_VALIDATE_OR_GOTO(THIS->name, gf_up_data, out); @@ -305,8 +307,15 @@ gf_proto_cache_invalidation_to_upcall (gfs3_cbk_cache_invalidation_req *gf_c_req          gf_c_data = (struct gf_upcall_cache_invalidation *)gf_up_data->data;          GF_VALIDATE_OR_GOTO(THIS->name, gf_c_data, out); -        memcpy (gf_up_data->gfid, gf_c_req->gfid, 16); -        gf_up_data->event_type       = gf_c_req->event_type; +        ret = gf_uuid_parse (gf_c_req->gfid, gf_up_data->gfid); +        if (ret) { +                gf_log (THIS->name, GF_LOG_WARNING, "gf_uuid_parse(%s) failed", +                        gf_c_req->gfid); +                gf_up_data->event_type = GF_UPCALL_EVENT_NULL; +                return; +        } + +        gf_up_data->event_type      = gf_c_req->event_type;          gf_c_data->flags            = gf_c_req->flags;          gf_c_data->expire_time_attr = gf_c_req->expire_time_attr; | 
