Linux CIFS filesystem development
 help / color / mirror / Atom feed
From: bfields-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org (J. Bruce Fields)
To: Christoph Hellwig <hch-jcswGhMUV9g@public.gmane.org>
Cc: viro-RmSDqhL/yNMiFSDQTTA3OLVCufUGDwFn@public.gmane.org,
	tao.peng-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org,
	jeff.layton-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org,
	linux-fsdevel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-btrfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-nfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [PATCH 2/5] locks: new locks_mandatory_area calling convention
Date: Mon, 30 Nov 2015 17:38:30 -0500	[thread overview]
Message-ID: <20151130223830.GB31564@fieldses.org> (raw)
In-Reply-To: <1448563859-21922-3-git-send-email-hch-jcswGhMUV9g@public.gmane.org>

On Thu, Nov 26, 2015 at 07:50:56PM +0100, Christoph Hellwig wrote:
> Pass a loff_t end for the last byte instead of the 32-bit count
> parameter to allow full file clones even on 32-bit architectures.
> While we're at it also drop the pointless inode argument and simplify
> the read/write selection.
> 
> Signed-off-by: Christoph Hellwig <hch-jcswGhMUV9g@public.gmane.org>
> ---
>  fs/locks.c         | 22 +++++++++-------------
>  fs/read_write.c    |  5 ++---
>  include/linux/fs.h | 28 +++++++++++++---------------
>  3 files changed, 24 insertions(+), 31 deletions(-)
> 
> diff --git a/fs/locks.c b/fs/locks.c
> index 0d2b326..d503669 100644
> --- a/fs/locks.c
> +++ b/fs/locks.c
> @@ -1227,21 +1227,17 @@ int locks_mandatory_locked(struct file *file)
>  
>  /**
>   * locks_mandatory_area - Check for a conflicting lock
> - * @read_write: %FLOCK_VERIFY_WRITE for exclusive access, %FLOCK_VERIFY_READ
> - *		for shared
> - * @inode:      the file to check
>   * @filp:       how the file was opened (if it was)
> - * @offset:     start of area to check
> - * @count:      length of area to check
> + * @start:	first byte in the file to check
> + * @end:	lastbyte in the file to check
> + * @write:	%true if checking for write access
>   *
>   * Searches the inode's list of locks to find any POSIX locks which conflict.
> - * This function is called from rw_verify_area() and
> - * locks_verify_truncate().
>   */
> -int locks_mandatory_area(int read_write, struct inode *inode,
> -			 struct file *filp, loff_t offset,
> -			 size_t count)
> +int locks_mandatory_area(struct file *filp, loff_t start, loff_t end,
> +		bool write)
>  {
> +	struct inode *inode = file_inode(filp);
>  	struct file_lock fl;
>  	int error;
>  	bool sleep = false;
> @@ -1252,9 +1248,9 @@ int locks_mandatory_area(int read_write, struct inode *inode,
>  	fl.fl_flags = FL_POSIX | FL_ACCESS;
>  	if (filp && !(filp->f_flags & O_NONBLOCK))
>  		sleep = true;
> -	fl.fl_type = (read_write == FLOCK_VERIFY_WRITE) ? F_WRLCK : F_RDLCK;
> -	fl.fl_start = offset;
> -	fl.fl_end = offset + count - 1;
> +	fl.fl_type = write ? F_WRLCK : F_RDLCK;
> +	fl.fl_start = start;
> +	fl.fl_end = end;
>  
>  	for (;;) {
>  		if (filp) {
> diff --git a/fs/read_write.c b/fs/read_write.c
> index c81ef39..48157dd 100644
> --- a/fs/read_write.c
> +++ b/fs/read_write.c
> @@ -396,9 +396,8 @@ int rw_verify_area(int read_write, struct file *file, const loff_t *ppos, size_t
>  	}
>  
>  	if (unlikely(inode->i_flctx && mandatory_lock(inode))) {
> -		retval = locks_mandatory_area(
> -			read_write == READ ? FLOCK_VERIFY_READ : FLOCK_VERIFY_WRITE,
> -			inode, file, pos, count);
> +		retval = locks_mandatory_area(file, pos, pos + count - 1,
> +				read_write == READ ? false : true);
>  		if (retval < 0)
>  			return retval;
>  	}
> diff --git a/include/linux/fs.h b/include/linux/fs.h
> index 870a76e..e640f791 100644
> --- a/include/linux/fs.h
> +++ b/include/linux/fs.h
> @@ -2030,12 +2030,9 @@ extern struct kobject *fs_kobj;
>  
>  #define MAX_RW_COUNT (INT_MAX & PAGE_CACHE_MASK)
>  
> -#define FLOCK_VERIFY_READ  1
> -#define FLOCK_VERIFY_WRITE 2
> -
>  #ifdef CONFIG_FILE_LOCKING
>  extern int locks_mandatory_locked(struct file *);
> -extern int locks_mandatory_area(int, struct inode *, struct file *, loff_t, size_t);
> +extern int locks_mandatory_area(struct file *, loff_t, loff_t, bool);
>  
>  /*
>   * Candidates for mandatory locking have the setgid bit set
> @@ -2068,14 +2065,16 @@ static inline int locks_verify_truncate(struct inode *inode,
>  				    struct file *filp,
>  				    loff_t size)
>  {
> -	if (inode->i_flctx && mandatory_lock(inode))
> -		return locks_mandatory_area(
> -			FLOCK_VERIFY_WRITE, inode, filp,
> -			size < inode->i_size ? size : inode->i_size,
> -			(size < inode->i_size ? inode->i_size - size
> -			 : size - inode->i_size)
> -		);
> -	return 0;
> +	if (!inode->i_flctx || !mandatory_lock(inode))
> +		return 0;
> +
> +	if (size < inode->i_size) {
> +		return locks_mandatory_area(filp, size, inode->i_size - 1,
> +				true);
> +	} else {
> +		return locks_mandatory_area(filp, inode->i_size, size - 1,
> +				true);

I feel like these callers would be just slightly more self-documenting
if that last parameter was F_WRLCK instead of true.

But I could live with it either way, patch looks like an
improvement--ACK.

--b.

> +	}
>  }
>  
>  static inline int break_lease(struct inode *inode, unsigned int mode)
> @@ -2144,9 +2143,8 @@ static inline int locks_mandatory_locked(struct file *file)
>  	return 0;
>  }
>  
> -static inline int locks_mandatory_area(int rw, struct inode *inode,
> -				       struct file *filp, loff_t offset,
> -				       size_t count)
> +static inline int locks_mandatory_area(struct file *filp, loff_t start,
> +		loff_t end, bool write)
>  {
>  	return 0;
>  }
> -- 
> 1.9.1
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

  parent reply	other threads:[~2015-11-30 22:38 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-26 18:50 vfs: move btrfs clone ioctls to common code Christoph Hellwig
2015-11-26 18:50 ` [PATCH 2/5] locks: new locks_mandatory_area calling convention Christoph Hellwig
     [not found]   ` <1448563859-21922-3-git-send-email-hch-jcswGhMUV9g@public.gmane.org>
2015-11-30 22:38     ` J. Bruce Fields [this message]
     [not found]       ` <20151130223830.GB31564-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org>
2015-12-01  7:37         ` Christoph Hellwig
2015-11-26 18:50 ` [PATCH 3/5] vfs: pull btrfs clone API to vfs layer Christoph Hellwig
2015-11-26 18:50 ` [PATCH 4/5] nfsd: Pass filehandle to nfs4_preprocess_stateid_op() Christoph Hellwig
     [not found] ` <1448563859-21922-1-git-send-email-hch-jcswGhMUV9g@public.gmane.org>
2015-11-26 18:50   ` [PATCH 1/5] cifs: implement clone_file_range operation Christoph Hellwig
     [not found]     ` <1448563859-21922-2-git-send-email-hch-jcswGhMUV9g@public.gmane.org>
2015-11-27 10:42       ` David Disseldorp
     [not found]         ` <20151127114232.5b367b7b-TzLh5lQYVSQb1SvskN2V4Q@public.gmane.org>
2015-11-30  9:02           ` Christoph Hellwig
2015-11-26 18:50   ` [PATCH 5/5] nfsd: implement the NFSv4.2 CLONE operation Christoph Hellwig
2015-11-30 22:56   ` vfs: move btrfs clone ioctls to common code J. Bruce Fields
2015-12-01 17:09   ` Chris Mason
2015-12-01 22:48   ` Steve French
2015-12-02  7:27     ` Christoph Hellwig
     [not found]       ` <20151202072757.GB15839-jcswGhMUV9g@public.gmane.org>
2015-12-02 17:40         ` Steve French
2015-12-03 10:30           ` Christoph Hellwig
     [not found]             ` <20151203103035.GA15996-jcswGhMUV9g@public.gmane.org>
2015-12-03 19:28               ` Steve French

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20151130223830.GB31564@fieldses.org \
    --to=bfields-uc3wqj2krung9huczpvpmw@public.gmane.org \
    --cc=hch-jcswGhMUV9g@public.gmane.org \
    --cc=jeff.layton-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org \
    --cc=linux-btrfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-fsdevel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-nfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=tao.peng-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org \
    --cc=viro-RmSDqhL/yNMiFSDQTTA3OLVCufUGDwFn@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox