From: NIIBE Y. <gn...@m1...> - 2002-03-20 00:10:43
|
Here is the change. Well, it's really difficult (for me) bug to find. There is disagreement with maintainer of NFS wrt this change, so I guess that this file will be here a while. 2002-03-20 NIIBE Yutaka <gn...@m1...> * fs/nfs/inode.c (nfs_read_inode): Don't set inode->i_rdev here. (nfs_fill_inode): But set it here, instead. (nfs_find_actor): Reusing cached inode, clear ->i_mode. Index: fs/nfs/inode.c =================================================================== RCS file: /cvsroot/linuxsh/linux/fs/nfs/Attic/inode.c,v retrieving revision 1.1.2.1 diff -u -3 -p -r1.1.2.1 inode.c --- fs/nfs/inode.c 19 Mar 2002 23:57:40 -0000 1.1.2.1 +++ fs/nfs/inode.c 20 Mar 2002 00:05:30 -0000 @@ -104,7 +104,6 @@ nfs_read_inode(struct inode * inode) { inode->i_blksize = inode->i_sb->s_blocksize; inode->i_mode = 0; - inode->i_rdev = 0; /* We can't support UPDATE_ATIME(), since the server will reset it */ inode->i_flags |= S_NOATIME; INIT_LIST_HEAD(&inode->u.nfs_i.read); @@ -638,6 +637,7 @@ nfs_fill_inode(struct inode *inode, stru * that's precisely what we have in nfs_file_inode_operations. */ inode->i_op = &nfs_file_inode_operations; + inode->i_rdev = 0; if (S_ISREG(inode->i_mode)) { inode->i_fop = &nfs_file_operations; inode->i_data.a_ops = &nfs_file_aops; @@ -679,7 +679,7 @@ nfs_find_actor(struct inode *inode, unsi return 0; /* Force an attribute cache update if inode->i_count == 0 */ if (!atomic_read(&inode->i_count)) - NFS_CACHEINV(inode); + inode->i_mode = 0; return 1; } |