Re: [PATCH 42/44] get rid of non-advancing variants

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 2022-06-22 at 05:15 +0100, Al Viro wrote:
> mechanical change; will be further massaged in subsequent commits
> 
> Signed-off-by: Al Viro <viro@xxxxxxxxxxxxxxxxxx>
> ---
>  include/linux/uio.h | 24 ++----------------------
>  lib/iov_iter.c      | 27 ++++++++++++++++++---------
>  2 files changed, 20 insertions(+), 31 deletions(-)
> 
> diff --git a/include/linux/uio.h b/include/linux/uio.h
> index ab1cc218b9de..f2fc55f88e45 100644
> --- a/include/linux/uio.h
> +++ b/include/linux/uio.h
> @@ -245,9 +245,9 @@ void iov_iter_pipe(struct iov_iter *i, unsigned int direction, struct pipe_inode
>  void iov_iter_discard(struct iov_iter *i, unsigned int direction, size_t count);
>  void iov_iter_xarray(struct iov_iter *i, unsigned int direction, struct xarray *xarray,
>  		     loff_t start, size_t count);
> -ssize_t iov_iter_get_pages(struct iov_iter *i, struct page **pages,
> +ssize_t iov_iter_get_pages2(struct iov_iter *i, struct page **pages,
>  			size_t maxsize, unsigned maxpages, size_t *start);
> -ssize_t iov_iter_get_pages_alloc(struct iov_iter *i, struct page ***pages,
> +ssize_t iov_iter_get_pages_alloc2(struct iov_iter *i, struct page ***pages,
>  			size_t maxsize, size_t *start);
>  int iov_iter_npages(const struct iov_iter *i, int maxpages);
>  void iov_iter_restore(struct iov_iter *i, struct iov_iter_state *state);
> @@ -349,24 +349,4 @@ static inline void iov_iter_ubuf(struct iov_iter *i, unsigned int direction,
>  	};
>  }
>  
> -static inline ssize_t iov_iter_get_pages2(struct iov_iter *i, struct page **pages,
> -			size_t maxsize, unsigned maxpages, size_t *start)
> -{
> -	ssize_t res = iov_iter_get_pages(i, pages, maxsize, maxpages, start);
> -
> -	if (res >= 0)
> -		iov_iter_advance(i, res);
> -	return res;
> -}
> -
> -static inline ssize_t iov_iter_get_pages_alloc2(struct iov_iter *i, struct page ***pages,
> -			size_t maxsize, size_t *start)
> -{
> -	ssize_t res = iov_iter_get_pages_alloc(i, pages, maxsize, start);
> -
> -	if (res >= 0)
> -		iov_iter_advance(i, res);
> -	return res;
> -}
> -
>  #endif
> diff --git a/lib/iov_iter.c b/lib/iov_iter.c
> index 1c744f0c0b2c..70736b3e07c5 100644
> --- a/lib/iov_iter.c
> +++ b/lib/iov_iter.c
> @@ -1231,6 +1231,7 @@ static ssize_t pipe_get_pages(struct iov_iter *i,
>  		left -= PAGE_SIZE - off;
>  		if (left <= 0) {
>  			buf->len += maxsize;
> +			iov_iter_advance(i, maxsize);
>  			return maxsize;
>  		}
>  		buf->len = PAGE_SIZE;
> @@ -1250,7 +1251,9 @@ static ssize_t pipe_get_pages(struct iov_iter *i,
>  	}
>  	if (!npages)
>  		return -EFAULT;
> -	return maxsize - left;
> +	maxsize -= left;
> +	iov_iter_advance(i, maxsize);
> +	return maxsize;
>  }
>  
>  static ssize_t iter_xarray_populate_pages(struct page **pages, struct xarray *xa,
> @@ -1300,7 +1303,9 @@ static ssize_t iter_xarray_get_pages(struct iov_iter *i,
>  	if (nr == 0)
>  		return 0;
>  
> -	return min_t(size_t, nr * PAGE_SIZE - offset, maxsize);
> +	maxsize = min_t(size_t, nr * PAGE_SIZE - offset, maxsize);
> +	iov_iter_advance(i, maxsize);
> +	return maxsize;
>  }
>  
>  /* must be done on non-empty ITER_UBUF or ITER_IOVEC one */
> @@ -1372,7 +1377,9 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,
>  		res = get_user_pages_fast(addr, n, gup_flags, *pages);
>  		if (unlikely(res <= 0))
>  			return res;
> -		return min_t(size_t, maxsize, res * PAGE_SIZE - *start);
> +		maxsize = min_t(size_t, maxsize, res * PAGE_SIZE - *start);
> +		iov_iter_advance(i, maxsize);
> +		return maxsize;
>  	}
>  	if (iov_iter_is_bvec(i)) {
>  		struct page **p;
> @@ -1384,8 +1391,10 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,
>  			return -ENOMEM;
>  		p = *pages;
>  		for (int k = 0; k < n; k++)
> -			get_page(*p++ = page++);
> -		return min_t(size_t, maxsize, n * PAGE_SIZE - *start);
> +			get_page(p[k] = page + k);
> +		maxsize = min_t(size_t, maxsize, n * PAGE_SIZE - *start);
> +		iov_iter_advance(i, maxsize);
> +		return maxsize;
>  	}
>  	if (iov_iter_is_pipe(i))
>  		return pipe_get_pages(i, pages, maxsize, maxpages, start);
> @@ -1395,7 +1404,7 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,
>  	return -EFAULT;
>  }
>  
> -ssize_t iov_iter_get_pages(struct iov_iter *i,
> +ssize_t iov_iter_get_pages2(struct iov_iter *i,
>  		   struct page **pages, size_t maxsize, unsigned maxpages,
>  		   size_t *start)
>  {
> @@ -1405,9 +1414,9 @@ ssize_t iov_iter_get_pages(struct iov_iter *i,
>  
>  	return __iov_iter_get_pages_alloc(i, &pages, maxsize, maxpages, start);
>  }
> -EXPORT_SYMBOL(iov_iter_get_pages);
> +EXPORT_SYMBOL(iov_iter_get_pages2);
>  
> -ssize_t iov_iter_get_pages_alloc(struct iov_iter *i,
> +ssize_t iov_iter_get_pages_alloc2(struct iov_iter *i,
>  		   struct page ***pages, size_t maxsize,
>  		   size_t *start)
>  {
> @@ -1422,7 +1431,7 @@ ssize_t iov_iter_get_pages_alloc(struct iov_iter *i,
>  	}
>  	return len;
>  }
> -EXPORT_SYMBOL(iov_iter_get_pages_alloc);
> +EXPORT_SYMBOL(iov_iter_get_pages_alloc2);
>  
>  size_t csum_and_copy_from_iter(void *addr, size_t bytes, __wsum *csum,
>  			       struct iov_iter *i)

Reviewed-by: Jeff Layton <jlayton@xxxxxxxxxx>




[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [NTFS 3]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [NTFS 3]     [Samba]     [Device Mapper]     [CEPH Development]

  Powered by Linux