Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
53dbb0b4
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
163
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
53dbb0b4
编写于
11月 09, 2017
作者:
M
Miklos Szeredi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ovl: split out ovl_get_lowerstack() from ovl_fill_super()
Signed-off-by:
N
Miklos Szeredi
<
mszeredi@redhat.com
>
上级
87ad447a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
72 addition
and
50 deletion
+72
-50
fs/overlayfs/super.c
fs/overlayfs/super.c
+72
-50
未找到文件。
fs/overlayfs/super.c
浏览文件 @
53dbb0b4
...
...
@@ -895,6 +895,75 @@ static int ovl_get_workpath(struct ovl_fs *ufs, struct path *upperpath,
return
err
;
}
static
int
ovl_get_lowerstack
(
struct
super_block
*
sb
,
struct
ovl_fs
*
ufs
,
struct
path
**
stackp
,
unsigned
int
*
stacklenp
)
{
int
err
;
char
*
lowertmp
,
*
lower
;
struct
path
*
stack
;
unsigned
int
stacklen
,
numlower
,
i
;
bool
remote
=
false
;
err
=
-
ENOMEM
;
lowertmp
=
kstrdup
(
ufs
->
config
.
lowerdir
,
GFP_KERNEL
);
if
(
!
lowertmp
)
goto
out
;
err
=
-
EINVAL
;
stacklen
=
ovl_split_lowerdirs
(
lowertmp
);
if
(
stacklen
>
OVL_MAX_STACK
)
{
pr_err
(
"overlayfs: too many lower directories, limit is %d
\n
"
,
OVL_MAX_STACK
);
goto
out
;
}
else
if
(
!
ufs
->
config
.
upperdir
&&
stacklen
==
1
)
{
pr_err
(
"overlayfs: at least 2 lowerdir are needed while upperdir nonexistent
\n
"
);
goto
out
;
}
err
=
-
ENOMEM
;
stack
=
kcalloc
(
stacklen
,
sizeof
(
struct
path
),
GFP_KERNEL
);
if
(
!
stack
)
goto
out
;
err
=
-
EINVAL
;
lower
=
lowertmp
;
for
(
numlower
=
0
;
numlower
<
stacklen
;
numlower
++
)
{
err
=
ovl_lower_dir
(
lower
,
&
stack
[
numlower
],
ufs
,
&
sb
->
s_stack_depth
,
&
remote
);
if
(
err
)
goto
out_free_stack
;
lower
=
strchr
(
lower
,
'\0'
)
+
1
;
}
err
=
-
EINVAL
;
sb
->
s_stack_depth
++
;
if
(
sb
->
s_stack_depth
>
FILESYSTEM_MAX_STACK_DEPTH
)
{
pr_err
(
"overlayfs: maximum fs stacking depth exceeded
\n
"
);
goto
out_free_stack
;
}
*
stackp
=
stack
;
*
stacklenp
=
numlower
;
if
(
remote
)
sb
->
s_d_op
=
&
ovl_reval_dentry_operations
;
else
sb
->
s_d_op
=
&
ovl_dentry_operations
;
err
=
0
;
out:
kfree
(
lowertmp
);
return
err
;
out_free_stack:
for
(
i
=
0
;
i
<
numlower
;
i
++
)
path_put
(
&
stack
[
i
]);
kfree
(
stack
);
goto
out
;
}
static
int
ovl_fill_super
(
struct
super_block
*
sb
,
void
*
data
,
int
silent
)
{
struct
path
upperpath
=
{
};
...
...
@@ -903,12 +972,8 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
struct
ovl_entry
*
oe
;
struct
ovl_fs
*
ufs
;
struct
path
*
stack
=
NULL
;
char
*
lowertmp
;
char
*
lower
;
unsigned
int
numlower
;
unsigned
int
stacklen
=
0
;
unsigned
int
numlower
=
0
;
unsigned
int
i
;
bool
remote
=
false
;
struct
cred
*
cred
;
int
err
;
...
...
@@ -948,45 +1013,10 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
sb
->
s_stack_depth
=
upperpath
.
mnt
->
mnt_sb
->
s_stack_depth
;
}
err
=
-
ENOMEM
;
lowertmp
=
kstrdup
(
ufs
->
config
.
lowerdir
,
GFP_KERNEL
);
if
(
!
lowertmp
)
err
=
ovl_get_lowerstack
(
sb
,
ufs
,
&
stack
,
&
numlower
);
if
(
err
)
goto
out_unlock_workdentry
;
err
=
-
EINVAL
;
stacklen
=
ovl_split_lowerdirs
(
lowertmp
);
if
(
stacklen
>
OVL_MAX_STACK
)
{
pr_err
(
"overlayfs: too many lower directories, limit is %d
\n
"
,
OVL_MAX_STACK
);
goto
out_free_lowertmp
;
}
else
if
(
!
ufs
->
config
.
upperdir
&&
stacklen
==
1
)
{
pr_err
(
"overlayfs: at least 2 lowerdir are needed while upperdir nonexistent
\n
"
);
goto
out_free_lowertmp
;
}
err
=
-
ENOMEM
;
stack
=
kcalloc
(
stacklen
,
sizeof
(
struct
path
),
GFP_KERNEL
);
if
(
!
stack
)
goto
out_free_lowertmp
;
err
=
-
EINVAL
;
lower
=
lowertmp
;
for
(
numlower
=
0
;
numlower
<
stacklen
;
numlower
++
)
{
err
=
ovl_lower_dir
(
lower
,
&
stack
[
numlower
],
ufs
,
&
sb
->
s_stack_depth
,
&
remote
);
if
(
err
)
goto
out_put_lowerpath
;
lower
=
strchr
(
lower
,
'\0'
)
+
1
;
}
err
=
-
EINVAL
;
sb
->
s_stack_depth
++
;
if
(
sb
->
s_stack_depth
>
FILESYSTEM_MAX_STACK_DEPTH
)
{
pr_err
(
"overlayfs: maximum fs stacking depth exceeded
\n
"
);
goto
out_put_lowerpath
;
}
if
(
ufs
->
config
.
upperdir
)
{
ufs
->
upper_mnt
=
clone_private_mount
(
&
upperpath
);
err
=
PTR_ERR
(
ufs
->
upper_mnt
);
...
...
@@ -1145,11 +1175,6 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
if
(
!
ufs
->
indexdir
)
ufs
->
config
.
index
=
false
;
if
(
remote
)
sb
->
s_d_op
=
&
ovl_reval_dentry_operations
;
else
sb
->
s_d_op
=
&
ovl_dentry_operations
;
err
=
-
ENOMEM
;
ufs
->
creator_cred
=
cred
=
prepare_creds
();
if
(
!
cred
)
...
...
@@ -1173,7 +1198,6 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
mntput
(
stack
[
i
].
mnt
);
kfree
(
stack
);
mntput
(
workpath
.
mnt
);
kfree
(
lowertmp
);
if
(
upperpath
.
dentry
)
{
oe
->
has_upper
=
true
;
...
...
@@ -1212,8 +1236,6 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
for
(
i
=
0
;
i
<
numlower
;
i
++
)
path_put
(
&
stack
[
i
]);
kfree
(
stack
);
out_free_lowertmp:
kfree
(
lowertmp
);
out_unlock_workdentry:
if
(
ufs
->
workdir_locked
)
ovl_inuse_unlock
(
workpath
.
dentry
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录