Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
b148cba4
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
b148cba4
编写于
5月 31, 2018
作者:
M
Miklos Szeredi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ovl: clean up copy-up error paths
Signed-off-by:
N
Miklos Szeredi
<
mszeredi@redhat.com
>
上级
dd8ac699
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
36 deletion
+18
-36
fs/overlayfs/copy_up.c
fs/overlayfs/copy_up.c
+18
-36
未找到文件。
fs/overlayfs/copy_up.c
浏览文件 @
b148cba4
...
...
@@ -366,12 +366,13 @@ static int ovl_create_index(struct dentry *dentry, struct dentry *origin,
return
err
;
temp
=
ovl_create_temp
(
indexdir
,
OVL_CATTR
(
S_IFDIR
|
0
));
err
=
PTR_ERR
(
temp
);
if
(
IS_ERR
(
temp
))
goto
temp_err
;
goto
free_name
;
err
=
ovl_set_upper_fh
(
upper
,
temp
);
if
(
err
)
goto
out
_cleanup
;
goto
out
;
index
=
lookup_one_len
(
name
.
name
,
indexdir
,
name
.
len
);
if
(
IS_ERR
(
index
))
{
...
...
@@ -380,23 +381,13 @@ static int ovl_create_index(struct dentry *dentry, struct dentry *origin,
err
=
ovl_do_rename
(
dir
,
temp
,
dir
,
index
,
0
);
dput
(
index
);
}
if
(
err
)
goto
out_cleanup
;
out:
if
(
err
)
ovl_cleanup
(
dir
,
temp
);
dput
(
temp
);
free_name:
kfree
(
name
.
name
);
return
err
;
temp_err:
err
=
PTR_ERR
(
temp
);
temp
=
NULL
;
goto
out
;
out_cleanup:
ovl_cleanup
(
dir
,
temp
);
goto
out
;
}
struct
ovl_copy_up_ctx
{
...
...
@@ -476,7 +467,7 @@ static int ovl_install_temp(struct ovl_copy_up_ctx *c, struct dentry *temp,
return
err
;
}
static
int
ovl_get_tmpfile
(
struct
ovl_copy_up_ctx
*
c
,
struct
dentry
**
tempp
)
static
struct
dentry
*
ovl_get_tmpfile
(
struct
ovl_copy_up_ctx
*
c
)
{
int
err
;
struct
dentry
*
temp
;
...
...
@@ -490,6 +481,7 @@ static int ovl_get_tmpfile(struct ovl_copy_up_ctx *c, struct dentry **tempp)
};
err
=
security_inode_copy_up
(
c
->
dentry
,
&
new_creds
);
temp
=
ERR_PTR
(
err
);
if
(
err
<
0
)
goto
out
;
...
...
@@ -500,21 +492,13 @@ static int ovl_get_tmpfile(struct ovl_copy_up_ctx *c, struct dentry **tempp)
temp
=
ovl_do_tmpfile
(
c
->
workdir
,
c
->
stat
.
mode
);
else
temp
=
ovl_create_temp
(
c
->
workdir
,
&
cattr
);
if
(
IS_ERR
(
temp
))
goto
temp_err
;
err
=
0
;
*
tempp
=
temp
;
out:
if
(
new_creds
)
{
revert_creds
(
old_creds
);
put_cred
(
new_creds
);
}
return
err
;
temp_err:
err
=
PTR_ERR
(
temp
);
goto
out
;
return
temp
;
}
static
int
ovl_copy_up_inode
(
struct
ovl_copy_up_ctx
*
c
,
struct
dentry
*
temp
)
...
...
@@ -564,21 +548,21 @@ static int ovl_copy_up_locked(struct ovl_copy_up_ctx *c)
struct
inode
*
udir
=
c
->
destdir
->
d_inode
;
struct
inode
*
inode
;
struct
dentry
*
newdentry
=
NULL
;
struct
dentry
*
temp
=
NULL
;
struct
dentry
*
temp
;
int
err
;
err
=
ovl_get_tmpfile
(
c
,
&
temp
);
if
(
err
)
goto
out
;
temp
=
ovl_get_tmpfile
(
c
);
if
(
IS_ERR
(
temp
)
)
return
PTR_ERR
(
temp
)
;
err
=
ovl_copy_up_inode
(
c
,
temp
);
if
(
err
)
goto
out
_cleanup
;
goto
out
;
if
(
S_ISDIR
(
c
->
stat
.
mode
)
&&
c
->
indexed
)
{
err
=
ovl_create_index
(
c
->
dentry
,
c
->
lowerpath
.
dentry
,
temp
);
if
(
err
)
goto
out
_cleanup
;
goto
out
;
}
if
(
c
->
tmpfile
)
{
...
...
@@ -589,7 +573,7 @@ static int ovl_copy_up_locked(struct ovl_copy_up_ctx *c)
err
=
ovl_install_temp
(
c
,
temp
,
&
newdentry
);
}
if
(
err
)
goto
out
_cleanup
;
goto
out
;
inode
=
d_inode
(
c
->
dentry
);
ovl_inode_update
(
inode
,
newdentry
);
...
...
@@ -597,13 +581,11 @@ static int ovl_copy_up_locked(struct ovl_copy_up_ctx *c)
ovl_set_flag
(
OVL_WHITEOUTS
,
inode
);
out:
if
(
err
&&
!
c
->
tmpfile
)
ovl_cleanup
(
d_inode
(
c
->
workdir
),
temp
);
dput
(
temp
);
return
err
;
out_cleanup:
if
(
!
c
->
tmpfile
)
ovl_cleanup
(
d_inode
(
c
->
workdir
),
temp
);
goto
out
;
}
/*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录