aboutsummaryrefslogtreecommitdiff
path: root/lib/buffer.c
diff options
context:
space:
mode:
authorMiklos Szeredi <mszeredi@suse.cz>2011-05-27 12:12:31 +0200
committerMiklos Szeredi <mszeredi@suse.cz>2011-05-27 12:12:31 +0200
commit4a9f6ab4805d805ac3b437c89d11ae365a0370f3 (patch)
tree60f9f3092ac3cfdf918f11751a8486c224074a6e /lib/buffer.c
parent42043986ae655f854b4529500dc6e928501a3be3 (diff)
downloadlibfuse-4a9f6ab4805d805ac3b437c89d11ae365a0370f3.tar.gz
Check if splice/vmsplice are supported
Diffstat (limited to 'lib/buffer.c')
-rw-r--r--lib/buffer.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/buffer.c b/lib/buffer.c
index cb734a3..65b0dea 100644
--- a/lib/buffer.c
+++ b/lib/buffer.c
@@ -153,6 +153,7 @@ static ssize_t fuse_buf_fd_to_fd(const struct fuse_buf *dst, size_t dst_off,
return copied;
}
+#ifdef HAVE_SPLICE
static ssize_t fuse_buf_splice(const struct fuse_buf *dst, size_t dst_off,
const struct fuse_buf *src, size_t src_off,
size_t len, enum fuse_buf_copy_flags flags)
@@ -207,6 +208,16 @@ static ssize_t fuse_buf_splice(const struct fuse_buf *dst, size_t dst_off,
return copied;
}
+#else
+static ssize_t fuse_buf_splice(const struct fuse_buf *dst, size_t dst_off,
+ const struct fuse_buf *src, size_t src_off,
+ size_t len, enum fuse_buf_copy_flags flags)
+{
+ (void) flags;
+
+ return fuse_buf_fd_to_fd(dst, dst_off, src, src_off, len);
+}
+#endif
static ssize_t fuse_buf_copy_one(const struct fuse_buf *dst, size_t dst_off,