diff options
author | Poornima G <pgurusid@redhat.com> | 2015-07-09 15:06:49 +0530 |
---|---|---|
committer | Pranith Kumar Karampuri <pkarampu@redhat.com> | 2016-04-21 03:01:38 -0700 |
commit | 63918789fbb5f3a2d381e0f960f2dcbaf1b7ff72 (patch) | |
tree | 885377e1dcb957a2215c73ef7e908f726e2109ae /libglusterfs/src/call-stub.c | |
parent | e964dd74fa805124005a5b2cb031ecbc34198b9a (diff) |
core: add lease fop
Change-Id: Ia27d66b1061b0377857827515590eb89b18515c9
BUG: 1319992
Signed-off-by: Poornima G <pgurusid@redhat.com>
Reviewed-on: http://review.gluster.org/11596
NetBSD-regression: NetBSD Build System <jenkins@build.gluster.org>
CentOS-regression: Gluster Build System <jenkins@build.gluster.com>
Smoke: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Rajesh Joseph <rjoseph@redhat.com>
Reviewed-by: Raghavendra Talur <rtalur@redhat.com>
Reviewed-by: Pranith Kumar Karampuri <pkarampu@redhat.com>
Diffstat (limited to 'libglusterfs/src/call-stub.c')
-rw-r--r-- | libglusterfs/src/call-stub.c | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/libglusterfs/src/call-stub.c b/libglusterfs/src/call-stub.c index 3f64cbc7d3b..42ebca6b3cc 100644 --- a/libglusterfs/src/call-stub.c +++ b/libglusterfs/src/call-stub.c @@ -1803,6 +1803,43 @@ out: } +call_stub_t * +fop_lease_cbk_stub (call_frame_t *frame, fop_lease_cbk_t fn, + int32_t op_ret, int32_t op_errno, + struct gf_lease *lease, dict_t *xdata) +{ + call_stub_t *stub = NULL; + + GF_VALIDATE_OR_GOTO ("call-stub", frame, out); + + stub = stub_new (frame, 0, GF_FOP_LEASE); + GF_VALIDATE_OR_GOTO ("call-stub", stub, out); + + stub->fn_cbk.lease = fn; + args_lease_cbk_store (&stub->args_cbk, op_ret, op_errno, lease, xdata); +out: + return stub; +} + +call_stub_t * +fop_lease_stub (call_frame_t *frame, fop_lease_t fn, + loc_t *loc, struct gf_lease *lease, dict_t *xdata) +{ + call_stub_t *stub = NULL; + + GF_VALIDATE_OR_GOTO ("call-stub", frame, out); + GF_VALIDATE_OR_GOTO ("call-stub", fn, out); + GF_VALIDATE_OR_GOTO ("call-stub", lease, out); + + stub = stub_new (frame, 1, GF_FOP_LEASE); + GF_VALIDATE_OR_GOTO ("call-stub", stub, out); + + stub->fn.lease = fn; + args_lease_store (&stub->args, loc, lease, xdata); +out: + return stub; + +} call_stub_t * fop_seek_cbk_stub (call_frame_t *frame, fop_seek_cbk_t fn, @@ -2085,6 +2122,11 @@ call_resume_wind (call_stub_t *stub) stub->args.fd, stub->args.offset, stub->args.what, stub->args.xdata); break; + case GF_FOP_LEASE: + stub->fn.lease (stub->frame, stub->frame->this, + &stub->args.loc, &stub->args.lease, + stub->args.xdata); + break; default: gf_msg_callingfn ("call-stub", GF_LOG_ERROR, EINVAL, @@ -2299,6 +2341,10 @@ call_resume_unwind (call_stub_t *stub) STUB_UNWIND (stub, seek, stub->args_cbk.offset, stub->args_cbk.xdata); break; + case GF_FOP_LEASE: + STUB_UNWIND (stub, lease, &stub->args_cbk.lease, + stub->args_cbk.xdata); + break; default: gf_msg_callingfn ("call-stub", GF_LOG_ERROR, EINVAL, |