From 9dd57ff963d4d0dde7f3ad0ff230837ff2f4b1df Mon Sep 17 00:00:00 2001 From: Pranith Kumar K Date: Thu, 10 Oct 2019 10:50:59 +0530 Subject: performance/open-behind: seek fop should open_and_resume fixes: bz#1760187 Change-Id: I4c6ad13194d4fc5c7705e35bf9a27fce504b51f9 Signed-off-by: Pranith Kumar K --- xlators/performance/open-behind/src/open-behind.c | 27 +++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'xlators') 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 @@ -708,6 +708,32 @@ err: return 0; } +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) { @@ -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, -- cgit