summaryrefslogtreecommitdiff
path: root/fs/namespace.c
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2011-01-17 01:35:23 -0500
committerAl Viro <viro@zeniv.linux.org.uk>2011-01-17 01:35:23 -0500
commit19a167af7c97248ec646552ebc9140bc6aa3552a (patch)
treea521153c80fa6e40b2b4983c5bba21c2e96d1864 /fs/namespace.c
parente78bf5e6cbe837daa6ab628a5f679548742994d3 (diff)
downloadlwn-19a167af7c97248ec646552ebc9140bc6aa3552a.tar.gz
lwn-19a167af7c97248ec646552ebc9140bc6aa3552a.zip
Take the completion of automount into new helper
... and shift it from namei.c to namespace.c Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/namespace.c')
-rw-r--r--fs/namespace.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/fs/namespace.c b/fs/namespace.c
index 9f544f35ed34..bec51e4e0549 100644
--- a/fs/namespace.c
+++ b/fs/namespace.c
@@ -1895,6 +1895,39 @@ static int do_new_mount(struct path *path, char *type, int flags,
return do_add_mount(mnt, path, mnt_flags);
}
+int finish_automount(struct vfsmount *m, struct path *path)
+{
+ int err;
+ /* The new mount record should have at least 2 refs to prevent it being
+ * expired before we get a chance to add it
+ */
+ BUG_ON(mnt_get_count(m) < 2);
+
+ if (m->mnt_sb == path->mnt->mnt_sb &&
+ m->mnt_root == path->dentry) {
+ mnt_clear_expiry(m);
+ mntput(m);
+ mntput(m);
+ return -ELOOP;
+ }
+
+ /* We need to add the mountpoint to the parent. The filesystem may
+ * have placed it on an expiry list, and so we need to make sure it
+ * won't be expired under us if do_add_mount() fails (do_add_mount()
+ * will eat a reference unconditionally).
+ */
+ mntget(m);
+ err = do_add_mount(m, path, path->mnt->mnt_flags | MNT_SHRINKABLE);
+ if (err) {
+ mnt_clear_expiry(m);
+ mntput(m);
+ mntput(m);
+ } else {
+ mntput(m);
+ }
+ return err;
+}
+
/*
* add a mount into a namespace's mount tree
* - this unconditionally eats one of the caller's references to newmnt.