提交 aae5d55a 编写于 作者: O Oleg Drokin 提交者: Greg Kroah-Hartman

staging/lustre/llite: ll_revalidate_dentry update

There are a couple of cases in ll_revalidate_dentry() where
we are pretty sure the dentry is valid, so check for them early
and save more expensive checks for later.
Signed-off-by: NOleg Drokin <green@linuxhacker.ru>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 6dad4d89
...@@ -302,6 +302,17 @@ static int ll_revalidate_dentry(struct dentry *dentry, ...@@ -302,6 +302,17 @@ static int ll_revalidate_dentry(struct dentry *dentry,
{ {
struct inode *dir = d_inode(dentry->d_parent); struct inode *dir = d_inode(dentry->d_parent);
/* If this is intermediate component path lookup and we were able to get
* to this dentry, then its lock has not been revoked and the
* path component is valid.
*/
if (lookup_flags & LOOKUP_PARENT)
return 1;
/* Symlink - always valid as long as the dentry was found */
if (dentry->d_inode && S_ISLNK(dentry->d_inode->i_mode))
return 1;
/* /*
* if open&create is set, talk to MDS to make sure file is created if * if open&create is set, talk to MDS to make sure file is created if
* necessary, because we can't do this in ->open() later since that's * necessary, because we can't do this in ->open() later since that's
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册