diff options
author | Jeff Layton <jlayton@primarydata.com> | 2014-08-09 10:16:44 -0400 |
---|---|---|
committer | Steve French <smfrench@gmail.com> | 2014-08-16 00:01:52 -0400 |
commit | 024408062b21af7316221c420ff16bdaac478fa8 (patch) | |
tree | c2f521ad6627e7c509ca2905012d915340976353 | |
parent | d43cc79343dfabf9f168531d3f5cff313205c8fb (diff) |
cifs: handle lease F_UNLCK requests properly
Currently any F_UNLCK request for a lease just gets back -EAGAIN. Allow
them to go immediately to generic_setlease instead.
Signed-off-by: Jeff Layton <jlayton@primarydata.com>
Signed-off-by: Steve French <smfrench@gmail.com>
-rw-r--r-- | fs/cifs/cifsfs.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c index 888398067420..0a4a4d7d407e 100644 --- a/fs/cifs/cifsfs.c +++ b/fs/cifs/cifsfs.c | |||
@@ -812,8 +812,9 @@ static int cifs_setlease(struct file *file, long arg, struct file_lock **lease) | |||
812 | if (!(S_ISREG(inode->i_mode))) | 812 | if (!(S_ISREG(inode->i_mode))) |
813 | return -EINVAL; | 813 | return -EINVAL; |
814 | 814 | ||
815 | /* check if file is oplocked */ | 815 | /* Check if file is oplocked if this is request for new lease */ |
816 | if (((arg == F_RDLCK) && CIFS_CACHE_READ(CIFS_I(inode))) || | 816 | if (arg == F_UNLCK || |
817 | ((arg == F_RDLCK) && CIFS_CACHE_READ(CIFS_I(inode))) || | ||
817 | ((arg == F_WRLCK) && CIFS_CACHE_WRITE(CIFS_I(inode)))) | 818 | ((arg == F_WRLCK) && CIFS_CACHE_WRITE(CIFS_I(inode)))) |
818 | return generic_setlease(file, arg, lease); | 819 | return generic_setlease(file, arg, lease); |
819 | else if (tlink_tcon(cfile->tlink)->local_lease && | 820 | else if (tlink_tcon(cfile->tlink)->local_lease && |