Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
db6ec212
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
db6ec212
编写于
10月 23, 2014
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
overlayfs: embed middle into overlay_readdir_data
same story... Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
49be4fb9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
7 deletion
+5
-7
fs/overlayfs/readdir.c
fs/overlayfs/readdir.c
+5
-7
未找到文件。
fs/overlayfs/readdir.c
浏览文件 @
db6ec212
...
@@ -38,7 +38,7 @@ struct ovl_readdir_data {
...
@@ -38,7 +38,7 @@ struct ovl_readdir_data {
bool
is_merge
;
bool
is_merge
;
struct
rb_root
root
;
struct
rb_root
root
;
struct
list_head
*
list
;
struct
list_head
*
list
;
struct
list_head
*
middle
;
struct
list_head
middle
;
int
count
;
int
count
;
int
err
;
int
err
;
};
};
...
@@ -139,13 +139,13 @@ static int ovl_fill_lower(struct ovl_readdir_data *rdd,
...
@@ -139,13 +139,13 @@ static int ovl_fill_lower(struct ovl_readdir_data *rdd,
p
=
ovl_cache_entry_find
(
&
rdd
->
root
,
name
,
namelen
);
p
=
ovl_cache_entry_find
(
&
rdd
->
root
,
name
,
namelen
);
if
(
p
)
{
if
(
p
)
{
list_move_tail
(
&
p
->
l_node
,
rdd
->
middle
);
list_move_tail
(
&
p
->
l_node
,
&
rdd
->
middle
);
}
else
{
}
else
{
p
=
ovl_cache_entry_new
(
name
,
namelen
,
ino
,
d_type
);
p
=
ovl_cache_entry_new
(
name
,
namelen
,
ino
,
d_type
);
if
(
p
==
NULL
)
if
(
p
==
NULL
)
rdd
->
err
=
-
ENOMEM
;
rdd
->
err
=
-
ENOMEM
;
else
else
list_add_tail
(
&
p
->
l_node
,
rdd
->
middle
);
list_add_tail
(
&
p
->
l_node
,
&
rdd
->
middle
);
}
}
return
rdd
->
err
;
return
rdd
->
err
;
...
@@ -277,7 +277,6 @@ static inline int ovl_dir_read_merged(struct path *upperpath,
...
@@ -277,7 +277,6 @@ static inline int ovl_dir_read_merged(struct path *upperpath,
struct
list_head
*
list
)
struct
list_head
*
list
)
{
{
int
err
;
int
err
;
struct
list_head
middle
;
struct
ovl_readdir_data
rdd
=
{
struct
ovl_readdir_data
rdd
=
{
.
ctx
.
actor
=
ovl_fill_merge
,
.
ctx
.
actor
=
ovl_fill_merge
,
.
list
=
list
,
.
list
=
list
,
...
@@ -301,11 +300,10 @@ static inline int ovl_dir_read_merged(struct path *upperpath,
...
@@ -301,11 +300,10 @@ static inline int ovl_dir_read_merged(struct path *upperpath,
* Insert lowerpath entries before upperpath ones, this allows
* Insert lowerpath entries before upperpath ones, this allows
* offsets to be reasonably constant
* offsets to be reasonably constant
*/
*/
list_add
(
&
middle
,
rdd
.
list
);
list_add
(
&
rdd
.
middle
,
rdd
.
list
);
rdd
.
middle
=
&
middle
;
rdd
.
is_merge
=
true
;
rdd
.
is_merge
=
true
;
err
=
ovl_dir_read
(
lowerpath
,
&
rdd
);
err
=
ovl_dir_read
(
lowerpath
,
&
rdd
);
list_del
(
&
middle
);
list_del
(
&
rdd
.
middle
);
}
}
out:
out:
return
err
;
return
err
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录