]> git.michaelhowe.org Git - packages/o/openafs.git/commitdiff
linux-hash-inodes-for-mmap-20071127
authorMarc Dionne <marc.dionne@technoconseil.com>
Tue, 27 Nov 2007 19:26:42 +0000 (19:26 +0000)
committerDerrick Brashear <shadow@dementia.org>
Tue, 27 Nov 2007 19:26:42 +0000 (19:26 +0000)
FIXES 78544

inodes are only added to the superblock dirty list if hashed.

do so.

src/afs/LINUX/osi_vnodeops.c

index b5b29d101b204f1eeac4552c87c42e16acf29809..16ef9d6dfc45a6b30b4e24956a1e744dfbb7529f 100644 (file)
@@ -970,6 +970,7 @@ afs_linux_create(struct inode *dip, struct dentry *dp, int mode)
 
        afs_getattr(vcp, &vattr, credp);
        afs_fill_inode(ip, &vattr);
+       insert_inode_hash(ip);
        dp->d_op = &afs_dentry_operations;
        dp->d_time = hgetlo(VTOAFS(dip)->m.DataVersion);
        d_instantiate(dp, ip);
@@ -1018,6 +1019,8 @@ afs_linux_lookup(struct inode *dip, struct dentry *dp)
        ip = AFSTOV(vcp);
        afs_getattr(vcp, &vattr, credp);
        afs_fill_inode(ip, &vattr);
+       if (hlist_unhashed(&ip->i_hash))
+           insert_inode_hash(ip);
     }
     dp->d_op = &afs_dentry_operations;
     dp->d_time = hgetlo(VTOAFS(dip)->m.DataVersion);
@@ -1880,5 +1883,4 @@ afs_fill_inode(struct inode *ip, struct vattr *vattr)
 #endif
     }
 
-    /* insert_inode_hash(ip);  -- this would make iget() work (if we used it) */
 }