diff options
-rw-r--r-- | fs/cifs/file.c | 21 |
1 files changed, 7 insertions, 14 deletions
diff --git a/fs/cifs/file.c b/fs/cifs/file.c index baf4b5067ff9..128e07b85d6c 100644 --- a/fs/cifs/file.c +++ b/fs/cifs/file.c | |||
@@ -1688,20 +1688,13 @@ int cifs_flush(struct file *file, fl_owner_t id) | |||
1688 | struct inode *inode = file->f_path.dentry->d_inode; | 1688 | struct inode *inode = file->f_path.dentry->d_inode; |
1689 | int rc = 0; | 1689 | int rc = 0; |
1690 | 1690 | ||
1691 | /* Rather than do the steps manually: | 1691 | if (file->f_mode & FMODE_WRITE) { |
1692 | lock the inode for writing | 1692 | rc = filemap_write_and_wait(inode->i_mapping); |
1693 | loop through pages looking for write behind data (dirty pages) | 1693 | /* reset wb rc if we were able to write out dirty pages */ |
1694 | coalesce into contiguous 16K (or smaller) chunks to write to server | 1694 | if (!rc) { |
1695 | send to server (prefer in parallel) | 1695 | rc = CIFS_I(inode)->write_behind_rc; |
1696 | deal with writebehind errors | 1696 | CIFS_I(inode)->write_behind_rc = 0; |
1697 | unlock inode for writing | 1697 | } |
1698 | filemapfdatawrite appears easier for the time being */ | ||
1699 | |||
1700 | rc = filemap_fdatawrite(inode->i_mapping); | ||
1701 | /* reset wb rc if we were able to write out dirty pages */ | ||
1702 | if (!rc) { | ||
1703 | rc = CIFS_I(inode)->write_behind_rc; | ||
1704 | CIFS_I(inode)->write_behind_rc = 0; | ||
1705 | } | 1698 | } |
1706 | 1699 | ||
1707 | cFYI(1, "Flush inode %p file %p rc %d", inode, file, rc); | 1700 | cFYI(1, "Flush inode %p file %p rc %d", inode, file, rc); |