aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/afs/mntpt.c3
-rw-r--r--fs/namei.c15
2 files changed, 6 insertions, 12 deletions
diff --git a/fs/afs/mntpt.c b/fs/afs/mntpt.c
index e13cea220669..a3510b8ba3e7 100644
--- a/fs/afs/mntpt.c
+++ b/fs/afs/mntpt.c
@@ -235,8 +235,7 @@ static void *afs_mntpt_follow_link(struct dentry *dentry, struct nameidata *nd)
235 err = do_add_mount(newmnt, nd, MNT_SHRINKABLE, &afs_vfsmounts); 235 err = do_add_mount(newmnt, nd, MNT_SHRINKABLE, &afs_vfsmounts);
236 switch (err) { 236 switch (err) {
237 case 0: 237 case 0:
238 dput(nd->path.dentry); 238 path_put(&nd->path);
239 mntput(nd->path.mnt);
240 nd->path.mnt = newmnt; 239 nd->path.mnt = newmnt;
241 nd->path.dentry = dget(newmnt->mnt_root); 240 nd->path.dentry = dget(newmnt->mnt_root);
242 schedule_delayed_work(&afs_mntpt_expiry_timer, 241 schedule_delayed_work(&afs_mntpt_expiry_timer,
diff --git a/fs/namei.c b/fs/namei.c
index b0df7ea733d7..024993535b6f 100644
--- a/fs/namei.c
+++ b/fs/namei.c
@@ -625,8 +625,7 @@ static __always_inline int __do_follow_link(struct path *path, struct nameidata
625 if (dentry->d_inode->i_op->put_link) 625 if (dentry->d_inode->i_op->put_link)
626 dentry->d_inode->i_op->put_link(dentry, nd, cookie); 626 dentry->d_inode->i_op->put_link(dentry, nd, cookie);
627 } 627 }
628 dput(dentry); 628 path_put(path);
629 mntput(path->mnt);
630 629
631 return error; 630 return error;
632} 631}
@@ -1033,8 +1032,7 @@ static int link_path_walk(const char *name, struct nameidata *nd)
1033 result = __link_path_walk(name, nd); 1032 result = __link_path_walk(name, nd);
1034 } 1033 }
1035 1034
1036 dput(save.path.dentry); 1035 path_put(&save.path);
1037 mntput(save.path.mnt);
1038 1036
1039 return result; 1037 return result;
1040} 1038}
@@ -1056,8 +1054,7 @@ static int __emul_lookup_dentry(const char *name, struct nameidata *nd)
1056 1054
1057 if (!nd->path.dentry->d_inode || 1055 if (!nd->path.dentry->d_inode ||
1058 S_ISDIR(nd->path.dentry->d_inode->i_mode)) { 1056 S_ISDIR(nd->path.dentry->d_inode->i_mode)) {
1059 struct dentry *old_dentry = nd->path.dentry; 1057 struct path old_path = nd->path;
1060 struct vfsmount *old_mnt = nd->path.mnt;
1061 struct qstr last = nd->last; 1058 struct qstr last = nd->last;
1062 int last_type = nd->last_type; 1059 int last_type = nd->last_type;
1063 struct fs_struct *fs = current->fs; 1060 struct fs_struct *fs = current->fs;
@@ -1073,14 +1070,12 @@ static int __emul_lookup_dentry(const char *name, struct nameidata *nd)
1073 read_unlock(&fs->lock); 1070 read_unlock(&fs->lock);
1074 if (path_walk(name, nd) == 0) { 1071 if (path_walk(name, nd) == 0) {
1075 if (nd->path.dentry->d_inode) { 1072 if (nd->path.dentry->d_inode) {
1076 dput(old_dentry); 1073 path_put(&old_path);
1077 mntput(old_mnt);
1078 return 1; 1074 return 1;
1079 } 1075 }
1080 path_put(&nd->path); 1076 path_put(&nd->path);
1081 } 1077 }
1082 nd->path.dentry = old_dentry; 1078 nd->path = old_path;
1083 nd->path.mnt = old_mnt;
1084 nd->last = last; 1079 nd->last = last;
1085 nd->last_type = last_type; 1080 nd->last_type = last_type;
1086 } 1081 }