summaryrefslogtreecommitdiffstats
path: root/fs/orangefs
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2015-10-08 17:47:44 -0400
committerMike Marshall <hubcap@omnibond.com>2015-11-13 10:57:53 -0500
commit34204fde4c877cb33d8ec0df09f38333f570cc84 (patch)
treef5ccfef4968e45e9d3432556b17805e02a8b660e /fs/orangefs
parent5c278228bbfe3abb7d468ef39dffac23de15c078 (diff)
pvfs_bufmap_copy_from_iovec(): don't rely upon size being equal to iov_iter_count(iter)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Mike Marshall <hubcap@omnibond.com>
Diffstat (limited to 'fs/orangefs')
-rw-r--r--fs/orangefs/pvfs2-bufmap.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/fs/orangefs/pvfs2-bufmap.c b/fs/orangefs/pvfs2-bufmap.c
index 843883035214..dacf42bee196 100644
--- a/fs/orangefs/pvfs2-bufmap.c
+++ b/fs/orangefs/pvfs2-bufmap.c
@@ -512,26 +512,25 @@ int pvfs_bufmap_copy_from_iovec(struct pvfs2_bufmap *bufmap,
int buffer_index,
size_t size)
{
- struct pvfs_bufmap_desc *to;
- struct page *page;
- size_t copied;
+ struct pvfs_bufmap_desc *to = &bufmap->desc_array[buffer_index];
int i;
gossip_debug(GOSSIP_BUFMAP_DEBUG,
- "%s: buffer_index:%d: size:%lu:\n",
+ "%s: buffer_index:%d: size:%zu:\n",
__func__, buffer_index, size);
- to = &bufmap->desc_array[buffer_index];
for (i = 0; size; i++) {
- page = to->page_array[i];
- copied = copy_page_from_iter(page, 0, PAGE_SIZE, iter);
- size -= copied;
- if ((copied == 0) && (size))
- break;
+ struct page *page = to->page_array[i];
+ size_t n = size;
+ if (n > PAGE_SIZE)
+ n = PAGE_SIZE;
+ n = copy_page_from_iter(page, 0, n, iter);
+ if (!n)
+ return -EFAULT;
+ size -= n;
}
-
- return size ? -EFAULT : 0;
+ return 0;
}