Remove path_release_on_umount()
authorJan Blunck <jblunck@suse.de>
Fri, 15 Feb 2008 03:34:31 +0000 (19:34 -0800)
committerLinus Torvalds <torvalds@woody.linux-foundation.org>
Fri, 15 Feb 2008 05:13:32 +0000 (21:13 -0800)
path_release_on_umount() should only be called from sys_umount(). I merged the
function into sys_umount() instead of having in in namei.c.

Signed-off-by: Jan Blunck <jblunck@suse.de>
Acked-by: Christoph Hellwig <hch@lst.de>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/namei.c
fs/namespace.c
include/linux/namei.h

index 52703986323a98ae43b93a92c91d439660a7fc6f..3ed4d7576d6dcf0923db3bc538fbb1cae990bd7d 100644 (file)
@@ -368,16 +368,6 @@ void path_release(struct nameidata *nd)
        mntput(nd->mnt);
 }
 
-/*
- * umount() mustn't call path_release()/mntput() as that would clear
- * mnt_expiry_mark
- */
-void path_release_on_umount(struct nameidata *nd)
-{
-       dput(nd->dentry);
-       mntput_no_expire(nd->mnt);
-}
-
 /**
  * release_open_intent - free up open intent resources
  * @nd: pointer to nameidata
index 63ced21c12dc2a2f212786c3b5e2d25b48437bf6..7937d30a6732e97cab6889d6eff111bbbd4b8cb0 100644 (file)
@@ -690,7 +690,9 @@ asmlinkage long sys_umount(char __user * name, int flags)
 
        retval = do_umount(nd.mnt, flags);
 dput_and_out:
-       path_release_on_umount(&nd);
+       /* we mustn't call path_put() as that would clear mnt_expiry_mark */
+       dput(nd.dentry);
+       mntput_no_expire(nd.mnt);
 out:
        return retval;
 }
index c13e411491f4ee0d1a386b3fb19a3ccb92aae2fb..307b1b31d37f63918342a3586e82128b6edca1ea 100644 (file)
@@ -72,7 +72,6 @@ extern int path_lookup(const char *, unsigned, struct nameidata *);
 extern int vfs_path_lookup(struct dentry *, struct vfsmount *,
                           const char *, unsigned int, struct nameidata *);
 extern void path_release(struct nameidata *);
-extern void path_release_on_umount(struct nameidata *);
 
 extern int __user_path_lookup_open(const char __user *, unsigned lookup_flags, struct nameidata *nd, int open_flags);
 extern int path_lookup_open(int dfd, const char *name, unsigned lookup_flags, struct nameidata *, int open_flags);