Commit 81055e58 authored by Al Viro's avatar Al Viro

optimize copy_page_{to,from}_iter()

if we'd ended up in the end of a segment, jump to the
beginning of the next one (iov_offset = 0, iov++),
rather than having the next primitive deal with that.

Ought to be folded back...
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 6abd2322
...@@ -74,6 +74,10 @@ size_t copy_page_to_iter(struct page *page, size_t offset, size_t bytes, ...@@ -74,6 +74,10 @@ size_t copy_page_to_iter(struct page *page, size_t offset, size_t bytes,
} }
kunmap(page); kunmap(page);
done: done:
if (skip == iov->iov_len) {
iov++;
skip = 0;
}
i->count -= wanted - bytes; i->count -= wanted - bytes;
i->nr_segs -= iov - i->iov; i->nr_segs -= iov - i->iov;
i->iov = iov; i->iov = iov;
...@@ -152,6 +156,10 @@ size_t copy_page_from_iter(struct page *page, size_t offset, size_t bytes, ...@@ -152,6 +156,10 @@ size_t copy_page_from_iter(struct page *page, size_t offset, size_t bytes,
} }
kunmap(page); kunmap(page);
done: done:
if (skip == iov->iov_len) {
iov++;
skip = 0;
}
i->count -= wanted - bytes; i->count -= wanted - bytes;
i->nr_segs -= iov - i->iov; i->nr_segs -= iov - i->iov;
i->iov = iov; i->iov = iov;
......
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