diff options
| author | Trond Myklebust <Trond.Myklebust@netapp.com> | 2007-09-30 15:13:17 -0400 |
|---|---|---|
| committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2007-10-09 17:19:11 -0400 |
| commit | b64e8a5ef758888cb42b7c105dcfaaf51aab1baf (patch) | |
| tree | a8555028da59911132f4677ddabc73f4b88dc41c /fs/nfs/inode.c | |
| parent | 7fdc49c4e49ba926348f71844cda7f5e12709738 (diff) | |
NFS: Remove bogus check of cache_change_attribute in nfs_update_inode
Remove the bogus 'data_stable' check in nfs_update_inode. The
cache_change_attribute tells you if the directory changed on the server,
and should have nothing to do with the file length.
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/inode.c')
| -rw-r--r-- | fs/nfs/inode.c | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/fs/nfs/inode.c b/fs/nfs/inode.c index 185cfd09d7f7..23feb9e3d8b0 100644 --- a/fs/nfs/inode.c +++ b/fs/nfs/inode.c | |||
| @@ -942,7 +942,6 @@ static int nfs_update_inode(struct inode *inode, struct nfs_fattr *fattr) | |||
| 942 | loff_t cur_isize, new_isize; | 942 | loff_t cur_isize, new_isize; |
| 943 | unsigned int invalid = 0; | 943 | unsigned int invalid = 0; |
| 944 | unsigned long now = jiffies; | 944 | unsigned long now = jiffies; |
| 945 | int data_stable; | ||
| 946 | 945 | ||
| 947 | dfprintk(VFS, "NFS: %s(%s/%ld ct=%d info=0x%x)\n", | 946 | dfprintk(VFS, "NFS: %s(%s/%ld ct=%d info=0x%x)\n", |
| 948 | __FUNCTION__, inode->i_sb->s_id, inode->i_ino, | 947 | __FUNCTION__, inode->i_sb->s_id, inode->i_ino, |
| @@ -969,8 +968,6 @@ static int nfs_update_inode(struct inode *inode, struct nfs_fattr *fattr) | |||
| 969 | nfsi->read_cache_jiffies = fattr->time_start; | 968 | nfsi->read_cache_jiffies = fattr->time_start; |
| 970 | nfsi->last_updated = now; | 969 | nfsi->last_updated = now; |
| 971 | 970 | ||
| 972 | /* Are we racing with known updates of the metadata on the server? */ | ||
| 973 | data_stable = nfs_verify_change_attribute(inode, fattr->time_start); | ||
| 974 | nfsi->cache_validity &= ~(NFS_INO_INVALID_ATTR | NFS_INO_INVALID_ATIME | 971 | nfsi->cache_validity &= ~(NFS_INO_INVALID_ATTR | NFS_INO_INVALID_ATIME |
| 975 | | NFS_INO_REVAL_PAGECACHE); | 972 | | NFS_INO_REVAL_PAGECACHE); |
| 976 | 973 | ||
| @@ -1002,15 +999,9 @@ static int nfs_update_inode(struct inode *inode, struct nfs_fattr *fattr) | |||
| 1002 | new_isize = nfs_size_to_loff_t(fattr->size); | 999 | new_isize = nfs_size_to_loff_t(fattr->size); |
| 1003 | cur_isize = i_size_read(inode); | 1000 | cur_isize = i_size_read(inode); |
| 1004 | if (new_isize != cur_isize) { | 1001 | if (new_isize != cur_isize) { |
| 1005 | /* Do we perhaps have any outstanding writes? */ | 1002 | /* Do we perhaps have any outstanding writes, or has |
| 1006 | if (nfsi->npages == 0) { | 1003 | * the file grown beyond our last write? */ |
| 1007 | /* No, but did we race with nfs_end_data_update()? */ | 1004 | if (nfsi->npages == 0 || new_isize > cur_isize) { |
| 1008 | if (data_stable) { | ||
| 1009 | inode->i_size = new_isize; | ||
| 1010 | invalid |= NFS_INO_INVALID_DATA; | ||
| 1011 | } | ||
| 1012 | invalid |= NFS_INO_INVALID_ATTR; | ||
| 1013 | } else if (new_isize > cur_isize) { | ||
| 1014 | inode->i_size = new_isize; | 1005 | inode->i_size = new_isize; |
| 1015 | invalid |= NFS_INO_INVALID_ATTR|NFS_INO_INVALID_DATA; | 1006 | invalid |= NFS_INO_INVALID_ATTR|NFS_INO_INVALID_DATA; |
| 1016 | } | 1007 | } |
