aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/namei.c3
-rw-r--r--fs/proc/base.c12
2 files changed, 9 insertions, 6 deletions
diff --git a/fs/namei.c b/fs/namei.c
index 6b29a51bef5d..a9b94c62c303 100644
--- a/fs/namei.c
+++ b/fs/namei.c
@@ -624,7 +624,7 @@ follow_link(struct path *link, struct nameidata *nd, void **p)
624 *p = dentry->d_inode->i_op->follow_link(dentry, nd); 624 *p = dentry->d_inode->i_op->follow_link(dentry, nd);
625 error = PTR_ERR(*p); 625 error = PTR_ERR(*p);
626 if (IS_ERR(*p)) 626 if (IS_ERR(*p))
627 goto out_put_link; 627 goto out_put_nd_path;
628 628
629 error = 0; 629 error = 0;
630 s = nd_get_link(nd); 630 s = nd_get_link(nd);
@@ -646,7 +646,6 @@ follow_link(struct path *link, struct nameidata *nd, void **p)
646 646
647out_put_nd_path: 647out_put_nd_path:
648 path_put(&nd->path); 648 path_put(&nd->path);
649out_put_link:
650 path_put(link); 649 path_put(link);
651 return error; 650 return error;
652} 651}
diff --git a/fs/proc/base.c b/fs/proc/base.c
index 8eaa5ea1c613..3bd5ac1ff018 100644
--- a/fs/proc/base.c
+++ b/fs/proc/base.c
@@ -1427,16 +1427,20 @@ static int proc_exe_link(struct dentry *dentry, struct path *exe_path)
1427static void *proc_pid_follow_link(struct dentry *dentry, struct nameidata *nd) 1427static void *proc_pid_follow_link(struct dentry *dentry, struct nameidata *nd)
1428{ 1428{
1429 struct inode *inode = dentry->d_inode; 1429 struct inode *inode = dentry->d_inode;
1430 struct path path;
1430 int error = -EACCES; 1431 int error = -EACCES;
1431 1432
1432 /* We don't need a base pointer in the /proc filesystem */
1433 path_put(&nd->path);
1434
1435 /* Are we allowed to snoop on the tasks file descriptors? */ 1433 /* Are we allowed to snoop on the tasks file descriptors? */
1436 if (!proc_fd_access_allowed(inode)) 1434 if (!proc_fd_access_allowed(inode))
1437 goto out; 1435 goto out;
1438 1436
1439 error = PROC_I(inode)->op.proc_get_link(dentry, &nd->path); 1437 error = PROC_I(inode)->op.proc_get_link(dentry, &path);
1438 if (error)
1439 goto out;
1440
1441 path_put(&nd->path);
1442 nd->path = path;
1443 return NULL;
1440out: 1444out:
1441 return ERR_PTR(error); 1445 return ERR_PTR(error);
1442} 1446}