aboutsummaryrefslogtreecommitdiffstats
path: root/fs/cifs/inode.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/cifs/inode.c')
-rw-r--r--fs/cifs/inode.c56
1 files changed, 14 insertions, 42 deletions
diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c
index ca3af4eafcb2..49efdefcff7c 100644
--- a/fs/cifs/inode.c
+++ b/fs/cifs/inode.c
@@ -995,7 +995,6 @@ int cifs_setattr(struct dentry *direntry, struct iattr *attrs)
995 filemap_fdatawait(direntry->d_inode->i_mapping); 995 filemap_fdatawait(direntry->d_inode->i_mapping);
996 996
997 if (attrs->ia_valid & ATTR_SIZE) { 997 if (attrs->ia_valid & ATTR_SIZE) {
998 read_lock(&GlobalSMBSeslock);
999 /* To avoid spurious oplock breaks from server, in the case of 998 /* To avoid spurious oplock breaks from server, in the case of
1000 inodes that we already have open, avoid doing path based 999 inodes that we already have open, avoid doing path based
1001 setting of file size if we can do it by handle. 1000 setting of file size if we can do it by handle.
@@ -1003,49 +1002,22 @@ int cifs_setattr(struct dentry *direntry, struct iattr *attrs)
1003 when the local oplock break takes longer to flush 1002 when the local oplock break takes longer to flush
1004 writebehind data than the SMB timeout for the SetPathInfo 1003 writebehind data than the SMB timeout for the SetPathInfo
1005 request would allow */ 1004 request would allow */
1006 list_for_each(tmp, &cifsInode->openFileList) { 1005 open_file = find_writable_file(cifsInode);
1007 open_file = list_entry(tmp, struct cifsFileInfo, 1006 if (open_file) {
1008 flist); 1007 __u16 nfid = open_file->netfid;
1009 /* We check if file is open for writing first */ 1008 __u32 npid = open_file->pid;
1010 if ((open_file->pfile) && 1009 rc = CIFSSMBSetFileSize(xid, pTcon, attrs->ia_size,
1011 ((open_file->pfile->f_flags & O_RDWR) || 1010 nfid, npid, FALSE);
1012 (open_file->pfile->f_flags & O_WRONLY))) { 1011 cFYI(1,("SetFSize for attrs rc = %d", rc));
1013 if (open_file->invalidHandle == FALSE) { 1012 if(rc == -EINVAL) {
1014 /* we found a valid, writeable network 1013 int bytes_written;
1015 file handle to use to try to set the 1014 rc = CIFSSMBWrite(xid, pTcon,
1016 file size */ 1015 nfid, 0, attrs->ia_size,
1017 __u16 nfid = open_file->netfid; 1016 &bytes_written, NULL, NULL,
1018 __u32 npid = open_file->pid; 1017 1 /* 45 seconds */);
1019 read_unlock(&GlobalSMBSeslock); 1018 cFYI(1,("Wrt seteof rc %d", rc));
1020 found = TRUE;
1021 rc = CIFSSMBSetFileSize(xid, pTcon,
1022 attrs->ia_size, nfid, npid,
1023 FALSE);
1024 cFYI(1, ("SetFileSize by handle "
1025 "(setattrs) rc = %d", rc));
1026 /* Do not need reopen and retry on
1027 EAGAIN since we will retry by
1028 pathname below */
1029
1030 /* now that we found one valid file
1031 handle no sense continuing to loop
1032 trying others, so break here */
1033 if(rc == -EINVAL) {
1034 int bytes_written;
1035 rc = CIFSSMBWrite(xid, pTcon,
1036 nfid, 0,
1037 attrs->ia_size,
1038 &bytes_written, NULL,
1039 NULL, 1 /* 45 sec */);
1040 cFYI(1,("wrt seteof rc %d",rc));
1041 }
1042 break;
1043 }
1044 } 1019 }
1045 } 1020 }
1046 if (found == FALSE)
1047 read_unlock(&GlobalSMBSeslock);
1048
1049 if (rc != 0) { 1021 if (rc != 0) {
1050 /* Set file size by pathname rather than by handle 1022 /* Set file size by pathname rather than by handle
1051 either because no valid, writeable file handle for 1023 either because no valid, writeable file handle for