From 0ebe35ead483071ac3ff4b5c3802f40b1c719c8e Mon Sep 17 00:00:00 2001 From: Raghavendra G Date: Thu, 14 Aug 2014 16:44:23 +0530 Subject: libglusterfs/syncop: implement inodelk Change-Id: Iea489157490b70cb2bb03576b0d4943c6d8f052d BUG: 1139998 Signed-off-by: Raghavendra G Reviewed-on: http://review.gluster.org/8522 Reviewed-by: Pranith Kumar Karampuri Tested-by: Gluster Build System Reviewed-by: Vijay Bellur Reviewed-on: http://review.gluster.org/8680 Reviewed-by: N Balachandran Reviewed-by: Kaleb KEITHLEY --- libglusterfs/src/syncop.c | 40 ++++++++++++++++++++++++++++++++++++++++ libglusterfs/src/syncop.h | 4 ++++ 2 files changed, 44 insertions(+) diff --git a/libglusterfs/src/syncop.c b/libglusterfs/src/syncop.c index 6c2e8e48e05..24ceba15dcc 100644 --- a/libglusterfs/src/syncop.c +++ b/libglusterfs/src/syncop.c @@ -2102,3 +2102,43 @@ syncop_lk (xlator_t *subvol, fd_t *fd, int cmd, struct gf_flock *flock) return args.op_ret; } + +int32_t +syncop_inodelk_cbk (call_frame_t *frame, void *cookie, xlator_t *this, + int32_t op_ret, int32_t op_errno, dict_t *xdata) +{ + struct syncargs *args = NULL; + + args = cookie; + + args->op_ret = op_ret; + args->op_errno = op_errno; + + if (xdata) + args->xdata = dict_ref (xdata); + + __wake (args); + + return 0; + +} + +int +syncop_inodelk (xlator_t *subvol, const char *volume, loc_t *loc, int32_t cmd, + struct gf_flock *lock, dict_t *xdata_req, dict_t **xdata_rsp) +{ + struct syncargs args = {0, }; + + SYNCOP (subvol, (&args), syncop_inodelk_cbk, subvol->fops->inodelk, + volume, loc, cmd, lock, xdata_req); + + if (xdata_rsp) + *xdata_rsp = args.xdata; + else + dict_unref (args.xdata); + + if (args.op_ret < 0) + return -args.op_errno; + + return args.op_ret; +} diff --git a/libglusterfs/src/syncop.h b/libglusterfs/src/syncop.h index 4e14dc35335..b620e27ef24 100644 --- a/libglusterfs/src/syncop.h +++ b/libglusterfs/src/syncop.h @@ -396,4 +396,8 @@ int syncop_rename (xlator_t *subvol, loc_t *oldloc, loc_t *newloc); int syncop_lk (xlator_t *subvol, fd_t *fd, int cmd, struct gf_flock *flock); +int +syncop_inodelk (xlator_t *subvol, const char *volume, loc_t *loc, int32_t cmd, + struct gf_flock *lock, dict_t *xdata_req, dict_t **xdata_rsp); + #endif /* _SYNCOP_H */ -- cgit