diff options
Diffstat (limited to 'lib/iov_iter.c')
| -rw-r--r-- | lib/iov_iter.c | 54 | 
1 files changed, 27 insertions, 27 deletions
diff --git a/lib/iov_iter.c b/lib/iov_iter.c index c93870987b58..be4bd627caf0 100644 --- a/lib/iov_iter.c +++ b/lib/iov_iter.c @@ -561,13 +561,20 @@ static size_t copy_pipe_to_iter(const void *addr, size_t bytes,  	return bytes;  } +static __wsum csum_and_memcpy(void *to, const void *from, size_t len, +			      __wsum sum, size_t off) +{ +	__wsum next = csum_partial_copy_nocheck(from, to, len, 0); +	return csum_block_add(sum, next, off); +} +  static size_t csum_and_copy_to_pipe_iter(const void *addr, size_t bytes,  				__wsum *csum, struct iov_iter *i)  {  	struct pipe_inode_info *pipe = i->pipe;  	size_t n, r;  	size_t off = 0; -	__wsum sum = *csum, next; +	__wsum sum = *csum;  	int idx;  	if (!sanity(i)) @@ -579,8 +586,7 @@ static size_t csum_and_copy_to_pipe_iter(const void *addr, size_t bytes,  	for ( ; n; idx = next_idx(idx, pipe), r = 0) {  		size_t chunk = min_t(size_t, n, PAGE_SIZE - r);  		char *p = kmap_atomic(pipe->bufs[idx].page); -		next = csum_partial_copy_nocheck(addr, p + r, chunk, 0); -		sum = csum_block_add(sum, next, off); +		sum = csum_and_memcpy(p + r, addr, chunk, sum, off);  		kunmap_atomic(p);  		i->idx = idx;  		i->iov_offset = r + chunk; @@ -1401,17 +1407,15 @@ size_t csum_and_copy_from_iter(void *addr, size_t bytes, __wsum *csum,  		err ? v.iov_len : 0;  	}), ({  		char *p = kmap_atomic(v.bv_page); -		next = csum_partial_copy_nocheck(p + v.bv_offset, -						 (to += v.bv_len) - v.bv_len, -						 v.bv_len, 0); +		sum = csum_and_memcpy((to += v.bv_len) - v.bv_len, +				      p + v.bv_offset, v.bv_len, +				      sum, off);  		kunmap_atomic(p); -		sum = csum_block_add(sum, next, off);  		off += v.bv_len;  	}),({ -		next = csum_partial_copy_nocheck(v.iov_base, -						 (to += v.iov_len) - v.iov_len, -						 v.iov_len, 0); -		sum = csum_block_add(sum, next, off); +		sum = csum_and_memcpy((to += v.iov_len) - v.iov_len, +				      v.iov_base, v.iov_len, +				      sum, off);  		off += v.iov_len;  	})  	) @@ -1445,17 +1449,15 @@ bool csum_and_copy_from_iter_full(void *addr, size_t bytes, __wsum *csum,  		0;  	}), ({  		char *p = kmap_atomic(v.bv_page); -		next = csum_partial_copy_nocheck(p + v.bv_offset, -						 (to += v.bv_len) - v.bv_len, -						 v.bv_len, 0); +		sum = csum_and_memcpy((to += v.bv_len) - v.bv_len, +				      p + v.bv_offset, v.bv_len, +				      sum, off);  		kunmap_atomic(p); -		sum = csum_block_add(sum, next, off);  		off += v.bv_len;  	}),({ -		next = csum_partial_copy_nocheck(v.iov_base, -						 (to += v.iov_len) - v.iov_len, -						 v.iov_len, 0); -		sum = csum_block_add(sum, next, off); +		sum = csum_and_memcpy((to += v.iov_len) - v.iov_len, +				      v.iov_base, v.iov_len, +				      sum, off);  		off += v.iov_len;  	})  	) @@ -1493,17 +1495,15 @@ size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *csump,  		err ? v.iov_len : 0;  	}), ({  		char *p = kmap_atomic(v.bv_page); -		next = csum_partial_copy_nocheck((from += v.bv_len) - v.bv_len, -						 p + v.bv_offset, -						 v.bv_len, 0); +		sum = csum_and_memcpy(p + v.bv_offset, +				      (from += v.bv_len) - v.bv_len, +				      v.bv_len, sum, off);  		kunmap_atomic(p); -		sum = csum_block_add(sum, next, off);  		off += v.bv_len;  	}),({ -		next = csum_partial_copy_nocheck((from += v.iov_len) - v.iov_len, -						 v.iov_base, -						 v.iov_len, 0); -		sum = csum_block_add(sum, next, off); +		sum = csum_and_memcpy(v.iov_base, +				     (from += v.iov_len) - v.iov_len, +				     v.iov_len, sum, off);  		off += v.iov_len;  	})  	)  | 
