should_follow_link(): validate ->d_seq after having decided to follow
commit a7f775428b8f5808815c0e3004020cedb94cbe3b upstream. ... otherwise d_is_symlink() above might have nothing to do with the inode value we've got. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
9108b130f7
commit
6f4b352f00
1 changed files with 5 additions and 0 deletions
|
@ -1711,6 +1711,11 @@ static inline int should_follow_link(struct nameidata *nd, struct path *link,
|
|||
return 0;
|
||||
if (!follow)
|
||||
return 0;
|
||||
/* make sure that d_is_symlink above matches inode */
|
||||
if (nd->flags & LOOKUP_RCU) {
|
||||
if (read_seqcount_retry(&link->dentry->d_seq, seq))
|
||||
return -ECHILD;
|
||||
}
|
||||
return pick_link(nd, link, inode, seq);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue