diff options
author | Jens Axboe <axboe@suse.de> | 2006-04-02 23:05:41 +0200 |
---|---|---|
committer | Jens Axboe <axboe@suse.de> | 2006-04-02 23:05:41 +0200 |
commit | b2b39fa478db6db89b7ccafb0649973845b0eb75 (patch) | |
tree | 784d85b94fb634e3b33dfd3f1153c98580cfac15 /fs/splice.c | |
parent | 83f9135bddffded9f1716519b6c147bcf046c87e (diff) | |
download | lwn-b2b39fa478db6db89b7ccafb0649973845b0eb75.tar.gz lwn-b2b39fa478db6db89b7ccafb0649973845b0eb75.zip |
[PATCH] splice: add a SPLICE_F_MORE flag
This lets userspace indicate whether more data will be coming in a
subsequent splice call.
Signed-off-by: Jens Axboe <axboe@suse.de>
Diffstat (limited to 'fs/splice.c')
-rw-r--r-- | fs/splice.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/splice.c b/fs/splice.c index 34591924c783..e84544558946 100644 --- a/fs/splice.c +++ b/fs/splice.c @@ -354,6 +354,7 @@ static int pipe_to_sendpage(struct pipe_inode_info *info, unsigned int offset; ssize_t ret; void *ptr; + int more; /* * sub-optimal, but we are limited by the pipe ->map. we don't @@ -366,9 +367,9 @@ static int pipe_to_sendpage(struct pipe_inode_info *info, return PTR_ERR(ptr); offset = pos & ~PAGE_CACHE_MASK; + more = (sd->flags & SPLICE_F_MORE) || sd->len < sd->total_len; - ret = file->f_op->sendpage(file, buf->page, offset, sd->len, &pos, - sd->len < sd->total_len); + ret = file->f_op->sendpage(file, buf->page, offset, sd->len, &pos,more); buf->ops->unmap(info, buf); if (ret == sd->len) |