Commit 13c0f52b authored by Al Viro's avatar Al Viro

make nr_pages calculation in default_file_splice_read() a bit less ugly

It's an artifact of lousy calling conventions of iov_iter_get_pages_alloc().
Hopefully, we'll get something saner come next cycle; for now that'll
do.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 3d6ea290
...@@ -385,7 +385,7 @@ static ssize_t default_file_splice_read(struct file *in, loff_t *ppos, ...@@ -385,7 +385,7 @@ static ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
struct iov_iter to; struct iov_iter to;
struct page **pages; struct page **pages;
unsigned int nr_pages; unsigned int nr_pages;
size_t offset, dummy, copied = 0; size_t offset, base, copied = 0;
ssize_t res; ssize_t res;
int i; int i;
...@@ -400,12 +400,11 @@ static ssize_t default_file_splice_read(struct file *in, loff_t *ppos, ...@@ -400,12 +400,11 @@ static ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
iov_iter_pipe(&to, ITER_PIPE | READ, pipe, len + offset); iov_iter_pipe(&to, ITER_PIPE | READ, pipe, len + offset);
res = iov_iter_get_pages_alloc(&to, &pages, len + offset, &dummy); res = iov_iter_get_pages_alloc(&to, &pages, len + offset, &base);
if (res <= 0) if (res <= 0)
return -ENOMEM; return -ENOMEM;
BUG_ON(dummy); nr_pages = DIV_ROUND_UP(res + base, PAGE_SIZE);
nr_pages = DIV_ROUND_UP(res, PAGE_SIZE);
vec = __vec; vec = __vec;
if (nr_pages > PIPE_DEF_BUFFERS) { if (nr_pages > PIPE_DEF_BUFFERS) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment