Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
39c6acea
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
39c6acea
编写于
1月 09, 2016
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
afs_send_pages(): use ITER_BVEC
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
be6e4d66
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
7 addition
and
8 deletion
+7
-8
fs/afs/rxrpc.c
fs/afs/rxrpc.c
+7
-8
未找到文件。
fs/afs/rxrpc.c
浏览文件 @
39c6acea
...
...
@@ -249,8 +249,7 @@ void afs_flat_call_destructor(struct afs_call *call)
/*
* attach the data from a bunch of pages on an inode to a call
*/
static
int
afs_send_pages
(
struct
afs_call
*
call
,
struct
msghdr
*
msg
,
struct
kvec
*
iov
)
static
int
afs_send_pages
(
struct
afs_call
*
call
,
struct
msghdr
*
msg
)
{
struct
page
*
pages
[
8
];
unsigned
count
,
n
,
loop
,
offset
,
to
;
...
...
@@ -273,20 +272,21 @@ static int afs_send_pages(struct afs_call *call, struct msghdr *msg,
loop
=
0
;
do
{
struct
bio_vec
bvec
=
{.
bv_page
=
pages
[
loop
],
.
bv_offset
=
offset
};
msg
->
msg_flags
=
0
;
to
=
PAGE_SIZE
;
if
(
first
+
loop
>=
last
)
to
=
call
->
last_to
;
else
msg
->
msg_flags
=
MSG_MORE
;
iov
->
iov_base
=
kmap
(
pages
[
loop
])
+
offset
;
iov
->
iov_len
=
to
-
offset
;
bvec
.
bv_len
=
to
-
offset
;
offset
=
0
;
_debug
(
"- range %u-%u%s"
,
offset
,
to
,
msg
->
msg_flags
?
" [more]"
:
""
);
iov_iter_
kvec
(
&
msg
->
msg_iter
,
WRITE
|
ITER_K
VEC
,
iov
,
1
,
to
-
offset
);
iov_iter_
bvec
(
&
msg
->
msg_iter
,
WRITE
|
ITER_B
VEC
,
&
bvec
,
1
,
to
-
offset
);
/* have to change the state *before* sending the last
* packet as RxRPC might give us the reply before it
...
...
@@ -295,7 +295,6 @@ static int afs_send_pages(struct afs_call *call, struct msghdr *msg,
call
->
state
=
AFS_CALL_AWAIT_REPLY
;
ret
=
rxrpc_kernel_send_data
(
afs_socket
,
call
->
rxcall
,
msg
,
to
-
offset
);
kunmap
(
pages
[
loop
]);
if
(
ret
<
0
)
break
;
}
while
(
++
loop
<
count
);
...
...
@@ -379,7 +378,7 @@ int afs_make_call(struct in_addr *addr, struct afs_call *call, gfp_t gfp,
goto
error_do_abort
;
if
(
call
->
send_pages
)
{
ret
=
afs_send_pages
(
call
,
&
msg
,
iov
);
ret
=
afs_send_pages
(
call
,
&
msg
);
if
(
ret
<
0
)
goto
error_do_abort
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录