linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 2/3] splice: allow non-block splice only when in file is seekable
@ 2010-05-26  9:56 Changli Gao
  2010-05-26 10:29 ` Miklos Szeredi
  0 siblings, 1 reply; 4+ messages in thread
From: Changli Gao @ 2010-05-26  9:56 UTC (permalink / raw)
  To: Alexander Viro; +Cc: linux-fsdevel, linux-kernel, Changli Gao

allow non-block splice only when in file is seekable.

do_splice_to() is split to two parts: read data from in file to spd, and move
data from spd to pipe. If there isn't much space in pipe for the data in spd,
and the splice is called with non-block flag, the data dropped due to non
enough space in pipe will be lost forever when in file isn't seekable.

Signed-off-by: Changli Gao <xiaosuo@gmail.com>
----
 fs/splice.c |    6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/fs/splice.c b/fs/splice.c
index 9e52de5..8137e23 100644
--- a/fs/splice.c
+++ b/fs/splice.c
@@ -1346,8 +1346,12 @@ static long do_splice(struct file *in, loff_t __user *off_in,
 			if (copy_from_user(&offset, off_in, sizeof(loff_t)))
 				return -EFAULT;
 			off = &offset;
-		} else
+		} else {
+			if ((flags & SPLICE_F_NONBLOCK) &&
+			    !(in->f_mode & FMODE_PREAD))
+				return -EINVAL;
 			off = &in->f_pos;
+		}
 
 		ret = do_splice_to(in, off, opipe, len, flags);
 

^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2010-05-26 12:23 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-05-26  9:56 [PATCH 2/3] splice: allow non-block splice only when in file is seekable Changli Gao
2010-05-26 10:29 ` Miklos Szeredi
2010-05-26 11:53   ` Changli Gao
2010-05-26 12:23     ` Miklos Szeredi

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).