提交 79ed0226 编写于 作者: A Al Viro

switch follow_mount()

Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 9393bd07
...@@ -715,16 +715,16 @@ static int __follow_mount(struct path *path) ...@@ -715,16 +715,16 @@ static int __follow_mount(struct path *path)
return res; return res;
} }
static void follow_mount(struct vfsmount **mnt, struct dentry **dentry) static void follow_mount(struct path *path)
{ {
while (d_mountpoint(*dentry)) { while (d_mountpoint(path->dentry)) {
struct vfsmount *mounted = lookup_mnt(*mnt, *dentry); struct vfsmount *mounted = lookup_mnt(path->mnt, path->dentry);
if (!mounted) if (!mounted)
break; break;
dput(*dentry); dput(path->dentry);
mntput(*mnt); mntput(path->mnt);
*mnt = mounted; path->mnt = mounted;
*dentry = dget(mounted->mnt_root); path->dentry = dget(mounted->mnt_root);
} }
} }
...@@ -779,7 +779,7 @@ static __always_inline void follow_dotdot(struct nameidata *nd) ...@@ -779,7 +779,7 @@ static __always_inline void follow_dotdot(struct nameidata *nd)
mntput(nd->path.mnt); mntput(nd->path.mnt);
nd->path.mnt = parent; nd->path.mnt = parent;
} }
follow_mount(&nd->path.mnt, &nd->path.dentry); follow_mount(&nd->path);
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册