pull security_inode_follow_link() into __do_follow_link()
authorAl Viro <viro@zeniv.linux.org.uk>
Wed, 23 Feb 2011 02:24:38 +0000 (21:24 -0500)
committerAl Viro <viro@zeniv.linux.org.uk>
Mon, 14 Mar 2011 13:15:24 +0000 (09:15 -0400)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/namei.c

index 8f10a9ff9f6b8a37a77d21f94b64b43435501055..f956567270bb1aed27113f2c1d84cc2df8aa08ee 100644 (file)
@@ -754,6 +754,13 @@ __do_follow_link(const struct path *link, struct nameidata *nd, void **p)
        if (link->mnt == nd->path.mnt)
                mntget(link->mnt);
 
+       error = security_inode_follow_link(link->dentry, nd);
+       if (error) {
+               *p = ERR_PTR(error); /* no ->put_link(), please */
+               path_put(&nd->path);
+               return error;
+       }
+
        nd->last_type = LAST_BIND;
        *p = dentry->d_inode->i_op->follow_link(dentry, nd);
        error = PTR_ERR(*p);
@@ -791,9 +798,6 @@ static inline int do_follow_link(struct inode *inode, struct path *path, struct
                goto loop;
        BUG_ON(nd->depth >= MAX_NESTED_LINKS);
        cond_resched();
-       err = security_inode_follow_link(path->dentry, nd);
-       if (err)
-               goto loop;
        current->link_count++;
        current->total_link_count++;
        nd->depth++;
@@ -2420,9 +2424,6 @@ reval:
                 * just set LAST_BIND.
                 */
                nd.flags |= LOOKUP_PARENT;
-               error = security_inode_follow_link(link.dentry, &nd);
-               if (error)
-                       goto exit_dput;
                error = __do_follow_link(&link, &nd, &cookie);
                if (unlikely(error)) {
                        if (!IS_ERR(cookie) && linki->i_op->put_link)