aboutsummaryrefslogtreecommitdiffstats
path: root/fs/cifs
diff options
context:
space:
mode:
authorPavel Shilovsky <piastryyy@gmail.com>2010-12-14 03:29:51 -0500
committerSteve French <sfrench@us.ibm.com>2011-01-20 16:42:25 -0500
commit7a6a19b17ab9103ec708c18befd28f2a3908d4c1 (patch)
tree3b781bf11b2a25c93ce20dbd80876e7e01c730e6 /fs/cifs
parent8be7e6ba142423e6ad98fed293c96f196f685229 (diff)
CIFS: Implement cifs_file_strict_mmap (try #2)
Invalidate inode mapping if we don't have at least Level II oplock. Reviewed-by: Jeff Layton <jlayton@redhat.com> Signed-off-by: Pavel Shilovsky <piastryyy@gmail.com> Signed-off-by: Steve French <sfrench@us.ibm.com>
Diffstat (limited to 'fs/cifs')
-rw-r--r--fs/cifs/cifsfs.c4
-rw-r--r--fs/cifs/cifsfs.h1
-rw-r--r--fs/cifs/file.c15
3 files changed, 18 insertions, 2 deletions
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c
index f6093e401c5a..e24d966fb214 100644
--- a/fs/cifs/cifsfs.c
+++ b/fs/cifs/cifsfs.c
@@ -743,7 +743,7 @@ const struct file_operations cifs_file_strict_ops = {
743 .lock = cifs_lock, 743 .lock = cifs_lock,
744 .fsync = cifs_strict_fsync, 744 .fsync = cifs_strict_fsync,
745 .flush = cifs_flush, 745 .flush = cifs_flush,
746 .mmap = cifs_file_mmap, 746 .mmap = cifs_file_strict_mmap,
747 .splice_read = generic_file_splice_read, 747 .splice_read = generic_file_splice_read,
748 .llseek = cifs_llseek, 748 .llseek = cifs_llseek,
749#ifdef CONFIG_CIFS_POSIX 749#ifdef CONFIG_CIFS_POSIX
@@ -798,7 +798,7 @@ const struct file_operations cifs_file_strict_nobrl_ops = {
798 .release = cifs_close, 798 .release = cifs_close,
799 .fsync = cifs_strict_fsync, 799 .fsync = cifs_strict_fsync,
800 .flush = cifs_flush, 800 .flush = cifs_flush,
801 .mmap = cifs_file_mmap, 801 .mmap = cifs_file_strict_mmap,
802 .splice_read = generic_file_splice_read, 802 .splice_read = generic_file_splice_read,
803 .llseek = cifs_llseek, 803 .llseek = cifs_llseek,
804#ifdef CONFIG_CIFS_POSIX 804#ifdef CONFIG_CIFS_POSIX
diff --git a/fs/cifs/cifsfs.h b/fs/cifs/cifsfs.h
index 10c4303c282d..710072e36912 100644
--- a/fs/cifs/cifsfs.h
+++ b/fs/cifs/cifsfs.h
@@ -89,6 +89,7 @@ extern int cifs_fsync(struct file *, int);
89extern int cifs_strict_fsync(struct file *, int); 89extern int cifs_strict_fsync(struct file *, int);
90extern int cifs_flush(struct file *, fl_owner_t id); 90extern int cifs_flush(struct file *, fl_owner_t id);
91extern int cifs_file_mmap(struct file * , struct vm_area_struct *); 91extern int cifs_file_mmap(struct file * , struct vm_area_struct *);
92extern int cifs_file_strict_mmap(struct file * , struct vm_area_struct *);
92extern const struct file_operations cifs_dir_ops; 93extern const struct file_operations cifs_dir_ops;
93extern int cifs_dir_open(struct inode *inode, struct file *file); 94extern int cifs_dir_open(struct inode *inode, struct file *file);
94extern int cifs_readdir(struct file *file, void *direntry, filldir_t filldir); 95extern int cifs_readdir(struct file *file, void *direntry, filldir_t filldir);
diff --git a/fs/cifs/file.c b/fs/cifs/file.c
index 5790fab7349b..0b32377ef8b7 100644
--- a/fs/cifs/file.c
+++ b/fs/cifs/file.c
@@ -1769,6 +1769,21 @@ static ssize_t cifs_read(struct file *file, char *read_data, size_t read_size,
1769 return total_read; 1769 return total_read;
1770} 1770}
1771 1771
1772int cifs_file_strict_mmap(struct file *file, struct vm_area_struct *vma)
1773{
1774 int rc, xid;
1775 struct inode *inode = file->f_path.dentry->d_inode;
1776
1777 xid = GetXid();
1778
1779 if (!CIFS_I(inode)->clientCanCacheRead)
1780 cifs_invalidate_mapping(inode);
1781
1782 rc = generic_file_mmap(file, vma);
1783 FreeXid(xid);
1784 return rc;
1785}
1786
1772int cifs_file_mmap(struct file *file, struct vm_area_struct *vma) 1787int cifs_file_mmap(struct file *file, struct vm_area_struct *vma)
1773{ 1788{
1774 int rc, xid; 1789 int rc, xid;