[PATCH] splice: add a SPLICE_F_MORE flag
authorJens Axboe <axboe@suse.de>
Sun, 2 Apr 2006 21:05:41 +0000 (23:05 +0200)
committerJens Axboe <axboe@suse.de>
Sun, 2 Apr 2006 21:05:41 +0000 (23:05 +0200)
This lets userspace indicate whether more data will be coming in a
subsequent splice call.

Signed-off-by: Jens Axboe <axboe@suse.de>
fs/splice.c
include/linux/pipe_fs_i.h

index 3459192..e845445 100644 (file)
@@ -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)
index 3286500..70ae933 100644 (file)
@@ -62,5 +62,6 @@ void free_pipe_info(struct inode* inode);
 #define SPLICE_F_NONBLOCK (0x02) /* don't block on the pipe splicing (but */
                                 /* we may still block on the fd we splice */
                                 /* from/to, of course */
+#define SPLICE_F_MORE  (0x04)  /* expect more data */
 
 #endif