Commit 6852df12 authored by Al Viro's avatar Al Viro

csum_and_copy_to_pipe_iter(): leave handling of csum_state to caller

... since all the logics is already there for use by iovec/kvec/etc.
cases.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 2a510a74
...@@ -582,39 +582,34 @@ static __wsum csum_and_memcpy(void *to, const void *from, size_t len, ...@@ -582,39 +582,34 @@ static __wsum csum_and_memcpy(void *to, const void *from, size_t len,
} }
static size_t csum_and_copy_to_pipe_iter(const void *addr, size_t bytes, static size_t csum_and_copy_to_pipe_iter(const void *addr, size_t bytes,
struct csum_state *csstate, struct iov_iter *i, __wsum *sump)
struct iov_iter *i)
{ {
struct pipe_inode_info *pipe = i->pipe; struct pipe_inode_info *pipe = i->pipe;
unsigned int p_mask = pipe->ring_size - 1; unsigned int p_mask = pipe->ring_size - 1;
__wsum sum = csstate->csum; __wsum sum = *sump;
size_t off = csstate->off; size_t off = 0;
unsigned int i_head; unsigned int i_head;
size_t n, r; size_t r;
if (!sanity(i)) if (!sanity(i))
return 0; return 0;
bytes = n = push_pipe(i, bytes, &i_head, &r); bytes = push_pipe(i, bytes, &i_head, &r);
if (unlikely(!n)) while (bytes) {
return 0; size_t chunk = min_t(size_t, bytes, PAGE_SIZE - r);
do {
size_t chunk = min_t(size_t, n, PAGE_SIZE - r);
char *p = kmap_local_page(pipe->bufs[i_head & p_mask].page); char *p = kmap_local_page(pipe->bufs[i_head & p_mask].page);
sum = csum_and_memcpy(p + r, addr, chunk, sum, off); sum = csum_and_memcpy(p + r, addr + off, chunk, sum, off);
kunmap_local(p); kunmap_local(p);
i->head = i_head; i->head = i_head;
i->iov_offset = r + chunk; i->iov_offset = r + chunk;
n -= chunk; bytes -= chunk;
off += chunk; off += chunk;
addr += chunk;
r = 0; r = 0;
i_head++; i_head++;
} while (n); }
i->count -= bytes; *sump = sum;
csstate->csum = sum; i->count -= off;
csstate->off = off; return off;
return bytes;
} }
size_t _copy_to_iter(const void *addr, size_t bytes, struct iov_iter *i) size_t _copy_to_iter(const void *addr, size_t bytes, struct iov_iter *i)
...@@ -1669,15 +1664,15 @@ size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *_csstate, ...@@ -1669,15 +1664,15 @@ size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *_csstate,
struct csum_state *csstate = _csstate; struct csum_state *csstate = _csstate;
__wsum sum, next; __wsum sum, next;
if (unlikely(iov_iter_is_pipe(i)))
return csum_and_copy_to_pipe_iter(addr, bytes, _csstate, i);
sum = csum_shift(csstate->csum, csstate->off);
if (unlikely(iov_iter_is_discard(i))) { if (unlikely(iov_iter_is_discard(i))) {
WARN_ON(1); /* for now */ WARN_ON(1); /* for now */
return 0; return 0;
} }
iterate_and_advance(i, bytes, base, len, off, ({
sum = csum_shift(csstate->csum, csstate->off);
if (unlikely(iov_iter_is_pipe(i)))
bytes = csum_and_copy_to_pipe_iter(addr, bytes, i, &sum);
else iterate_and_advance(i, bytes, base, len, off, ({
next = csum_and_copy_to_user(addr + off, base, len); next = csum_and_copy_to_user(addr + off, base, len);
sum = csum_block_add(sum, next, off); sum = csum_block_add(sum, next, off);
next ? 0 : len; next ? 0 : len;
......
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