提交 c22205d0 编写于 作者: A Amir Goldstein 提交者: Miklos Szeredi

ovl: use an auxiliary var for overlay root entry

Signed-off-by: NAmir Goldstein <amir73il@gmail.com>
Signed-off-by: NMiklos Szeredi <mszeredi@redhat.com>
上级 3a1e819b
...@@ -220,6 +220,7 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry, ...@@ -220,6 +220,7 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry,
const struct cred *old_cred; const struct cred *old_cred;
struct ovl_fs *ofs = dentry->d_sb->s_fs_info; struct ovl_fs *ofs = dentry->d_sb->s_fs_info;
struct ovl_entry *poe = dentry->d_parent->d_fsdata; struct ovl_entry *poe = dentry->d_parent->d_fsdata;
struct ovl_entry *roe = dentry->d_sb->s_root->d_fsdata;
struct path *stack = NULL; struct path *stack = NULL;
struct dentry *upperdir, *upperdentry = NULL; struct dentry *upperdir, *upperdentry = NULL;
unsigned int ctr = 0; unsigned int ctr = 0;
...@@ -259,7 +260,7 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry, ...@@ -259,7 +260,7 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry,
if (!upperredirect) if (!upperredirect)
goto out_put_upper; goto out_put_upper;
if (d.redirect[0] == '/') if (d.redirect[0] == '/')
poe = dentry->d_sb->s_root->d_fsdata; poe = roe;
} }
upperopaque = d.opaque; upperopaque = d.opaque;
} }
...@@ -290,10 +291,8 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry, ...@@ -290,10 +291,8 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry,
if (d.stop) if (d.stop)
break; break;
if (d.redirect && if (d.redirect && d.redirect[0] == '/' && poe != roe) {
d.redirect[0] == '/' && poe = roe;
poe != dentry->d_sb->s_root->d_fsdata) {
poe = dentry->d_sb->s_root->d_fsdata;
/* Find the current layer on the root dentry */ /* Find the current layer on the root dentry */
for (i = 0; i < poe->numlower; i++) for (i = 0; i < poe->numlower; i++)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册