From: Al Viro Date: Thu, 24 Dec 2009 07:08:19 +0000 (-0500) Subject: postpone __putname() until after do_last() X-Git-Tag: firefly_0821_release~9833^2~3017^2~13 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c41c14056210e4a328659c82b1edaccb0910d18c;p=firefly-linux-kernel-4.4.55.git postpone __putname() until after do_last() Since do_last() doesn't mangle nd->last_name, we can safely postpone __putname() done in handling of trailing symlinks until after the call of do_last() Signed-off-by: Al Viro --- diff --git a/fs/namei.c b/fs/namei.c index fc6bed7215c9..30ba3f3a25e2 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -1923,9 +1923,9 @@ do_link: mutex_lock(&dir->d_inode->i_mutex); path.dentry = lookup_hash(&nd); path.mnt = nd.path.mnt; - __putname(nd.last.name); filp = do_last(&nd, &path, open_flag, flag, acc_mode, mode, pathname, dir, &is_link); + __putname(nd.last.name); if (is_link) goto do_link; if (nd.root.mnt)