summaryrefslogtreecommitdiffstats
path: root/xlators
diff options
context:
space:
mode:
authorPranith Kumar K <pkarampu@redhat.com>2019-10-10 10:50:59 +0530
committerRaghavendra G <rgowdapp@redhat.com>2019-10-11 06:05:07 +0000
commit9dd57ff963d4d0dde7f3ad0ff230837ff2f4b1df (patch)
treebe2894acaa86d4e3d30ee40054f932f0b990aff4 /xlators
parent134fcea8e245fd5033151392b6265d0dcc87a900 (diff)
performance/open-behind: seek fop should open_and_resume
fixes: bz#1760187 Change-Id: I4c6ad13194d4fc5c7705e35bf9a27fce504b51f9 Signed-off-by: Pranith Kumar K <pkarampu@redhat.com>
Diffstat (limited to 'xlators')
-rw-r--r--xlators/performance/open-behind/src/open-behind.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/xlators/performance/open-behind/src/open-behind.c b/xlators/performance/open-behind/src/open-behind.c
index 70a144abb5f..95e00dbd790 100644
--- a/xlators/performance/open-behind/src/open-behind.c
+++ b/xlators/performance/open-behind/src/open-behind.c
@@ -709,6 +709,32 @@ err:
}
int
+ob_seek(call_frame_t *frame, xlator_t *this, fd_t *fd, off_t offset,
+ gf_seek_what_t what, dict_t *xdata)
+{
+ call_stub_t *stub = NULL;
+ fd_t *wind_fd = NULL;
+
+ wind_fd = ob_get_wind_fd(this, fd, NULL);
+
+ stub = fop_seek_stub(frame, default_seek_resume, wind_fd, offset, what,
+ xdata);
+
+ fd_unref(wind_fd);
+
+ if (!stub)
+ goto err;
+
+ open_and_resume(this, wind_fd, stub);
+
+ return 0;
+err:
+ STACK_UNWIND_STRICT(fstat, frame, -1, ENOMEM, 0, 0);
+
+ return 0;
+}
+
+int
ob_flush(call_frame_t *frame, xlator_t *this, fd_t *fd, dict_t *xdata)
{
call_stub_t *stub = NULL;
@@ -1256,6 +1282,7 @@ struct xlator_fops fops = {
.flush = ob_flush,
.fsync = ob_fsync,
.fstat = ob_fstat,
+ .seek = ob_seek,
.ftruncate = ob_ftruncate,
.fsetxattr = ob_fsetxattr,
.setxattr = ob_setxattr,