diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2014-11-27 20:27:08 -0500 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2014-12-08 20:25:23 -0500 |
commit | aa583096d9767892983332e7c1a984bd17e3cd39 (patch) | |
tree | 0a95463b6a62365ee6e37a8f2f4258ad7073197a /mm/iov_iter.c | |
parent | abb78f875f3fcedb88d85eef9f7be7aa474c6727 (diff) |
copy_from_iter_nocache()
BTW, do we want memcpy_nocache()?
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'mm/iov_iter.c')
-rw-r--r-- | mm/iov_iter.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/mm/iov_iter.c b/mm/iov_iter.c index 88c052e63a1d..a1599ca4ab0e 100644 --- a/mm/iov_iter.c +++ b/mm/iov_iter.c | |||
@@ -399,6 +399,27 @@ size_t copy_from_iter(void *addr, size_t bytes, struct iov_iter *i) | |||
399 | } | 399 | } |
400 | EXPORT_SYMBOL(copy_from_iter); | 400 | EXPORT_SYMBOL(copy_from_iter); |
401 | 401 | ||
402 | size_t copy_from_iter_nocache(void *addr, size_t bytes, struct iov_iter *i) | ||
403 | { | ||
404 | char *to = addr; | ||
405 | if (unlikely(bytes > i->count)) | ||
406 | bytes = i->count; | ||
407 | |||
408 | if (unlikely(!bytes)) | ||
409 | return 0; | ||
410 | |||
411 | iterate_and_advance(i, bytes, v, | ||
412 | __copy_from_user_nocache((to += v.iov_len) - v.iov_len, | ||
413 | v.iov_base, v.iov_len), | ||
414 | memcpy_from_page((to += v.bv_len) - v.bv_len, v.bv_page, | ||
415 | v.bv_offset, v.bv_len), | ||
416 | memcpy((to += v.iov_len) - v.iov_len, v.iov_base, v.iov_len) | ||
417 | ) | ||
418 | |||
419 | return bytes; | ||
420 | } | ||
421 | EXPORT_SYMBOL(copy_from_iter_nocache); | ||
422 | |||
402 | size_t copy_page_to_iter(struct page *page, size_t offset, size_t bytes, | 423 | size_t copy_page_to_iter(struct page *page, size_t offset, size_t bytes, |
403 | struct iov_iter *i) | 424 | struct iov_iter *i) |
404 | { | 425 | { |