Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
a7c22421
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
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看板
提交
a7c22421
编写于
9月 25, 2016
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
relay: simplify relay_file_read()
to hell with actors... Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
523ac9af
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
58 deletion
+20
-58
kernel/relay.c
kernel/relay.c
+20
-58
未找到文件。
kernel/relay.c
浏览文件 @
a7c22421
...
...
@@ -1121,51 +1121,23 @@ static size_t relay_file_read_end_pos(struct rchan_buf *buf,
return
end_pos
;
}
/*
* subbuf_read_actor - read up to one subbuf's worth of data
*/
static
int
subbuf_read_actor
(
size_t
read_start
,
struct
rchan_buf
*
buf
,
size_t
avail
,
read_descriptor_t
*
desc
)
{
void
*
from
;
int
ret
=
0
;
from
=
buf
->
start
+
read_start
;
ret
=
avail
;
if
(
copy_to_user
(
desc
->
arg
.
buf
,
from
,
avail
))
{
desc
->
error
=
-
EFAULT
;
ret
=
0
;
}
desc
->
arg
.
data
+=
ret
;
desc
->
written
+=
ret
;
desc
->
count
-=
ret
;
return
ret
;
}
typedef
int
(
*
subbuf_actor_t
)
(
size_t
read_start
,
struct
rchan_buf
*
buf
,
size_t
avail
,
read_descriptor_t
*
desc
);
/*
* relay_file_read_subbufs - read count bytes, bridging subbuf boundaries
*/
static
ssize_t
relay_file_read_subbufs
(
struct
file
*
filp
,
loff_t
*
ppos
,
subbuf_actor_t
subbuf_actor
,
read_descriptor_t
*
desc
)
static
ssize_t
relay_file_read
(
struct
file
*
filp
,
char
__user
*
buffer
,
size_t
count
,
loff_t
*
ppos
)
{
struct
rchan_buf
*
buf
=
filp
->
private_data
;
size_t
read_start
,
avail
;
size_t
written
=
0
;
int
ret
;
if
(
!
desc
->
count
)
if
(
!
count
)
return
0
;
inode_lock
(
file_inode
(
filp
));
do
{
void
*
from
;
if
(
!
relay_file_read_avail
(
buf
,
*
ppos
))
break
;
...
...
@@ -1174,32 +1146,22 @@ static ssize_t relay_file_read_subbufs(struct file *filp, loff_t *ppos,
if
(
!
avail
)
break
;
avail
=
min
(
desc
->
count
,
avail
);
ret
=
subbuf_actor
(
read_start
,
buf
,
avail
,
desc
);
if
(
desc
->
error
<
0
)
avail
=
min
(
count
,
avail
);
from
=
buf
->
start
+
read_start
;
ret
=
avail
;
if
(
copy_to_user
(
buffer
,
from
,
avail
))
break
;
if
(
ret
)
{
relay_file_read_consume
(
buf
,
read_start
,
ret
);
*
ppos
=
relay_file_read_end_pos
(
buf
,
read_start
,
ret
);
}
}
while
(
desc
->
count
&&
ret
);
inode_unlock
(
file_inode
(
filp
));
buffer
+=
ret
;
written
+=
ret
;
count
-=
ret
;
return
desc
->
written
;
}
relay_file_read_consume
(
buf
,
read_start
,
ret
);
*
ppos
=
relay_file_read_end_pos
(
buf
,
read_start
,
ret
);
}
while
(
count
);
inode_unlock
(
file_inode
(
filp
));
static
ssize_t
relay_file_read
(
struct
file
*
filp
,
char
__user
*
buffer
,
size_t
count
,
loff_t
*
ppos
)
{
read_descriptor_t
desc
;
desc
.
written
=
0
;
desc
.
count
=
count
;
desc
.
arg
.
buf
=
buffer
;
desc
.
error
=
0
;
return
relay_file_read_subbufs
(
filp
,
ppos
,
subbuf_read_actor
,
&
desc
);
return
written
;
}
static
void
relay_consume_bytes
(
struct
rchan_buf
*
rbuf
,
int
bytes_consumed
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录