ecryptfs: redo dget,mntget on dentry_open failure
authorEric Sandeen <[email protected]>
Sat, 22 Dec 2007 22:03:26 +0000 (14:03 -0800)
committerLinus Torvalds <[email protected]>
Sun, 23 Dec 2007 20:54:37 +0000 (12:54 -0800)
Thanks to Jeff Moyer for pointing this out.

If the RDWR dentry_open() in ecryptfs_init_persistent_file fails,
it will do a dput/mntput.  Need to re-take references if we
retry as RDONLY.

Signed-off-by: Eric Sandeen <[email protected]>
Acked-by: Mike Halcrow <[email protected]>
Signed-off-by: Jeff Moyer <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
fs/ecryptfs/main.c

index a277754da17163ee90521aea4c83f6c1fa3ac14f..e5580bcb923a20e7d86e147f9bb9646b42722d15 100644 (file)
@@ -138,11 +138,14 @@ int ecryptfs_init_persistent_file(struct dentry *ecryptfs_dentry)
                inode_info->lower_file = dentry_open(lower_dentry,
                                                     lower_mnt,
                                                     (O_RDWR | O_LARGEFILE));
-               if (IS_ERR(inode_info->lower_file))
+               if (IS_ERR(inode_info->lower_file)) {
+                       dget(lower_dentry);
+                       mntget(lower_mnt);
                        inode_info->lower_file = dentry_open(lower_dentry,
                                                             lower_mnt,
                                                             (O_RDONLY
                                                              | O_LARGEFILE));
+               }
                if (IS_ERR(inode_info->lower_file)) {
                        printk(KERN_ERR "Error opening lower persistent file "
                               "for lower_dentry [0x%p] and lower_mnt [0x%p]\n",