Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
629e42bc
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看板
提交
629e42bc
编写于
9月 23, 2017
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
... and with iov_iter_get_pages_alloc() it becomes even simpler
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
076098e5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
16 deletion
+5
-16
block/bio.c
block/bio.c
+5
-16
未找到文件。
block/bio.c
浏览文件 @
629e42bc
...
...
@@ -1325,9 +1325,7 @@ struct bio *bio_map_user_iov(struct request_queue *q,
{
int
j
;
int
nr_pages
=
0
;
struct
page
**
pages
;
struct
bio
*
bio
;
int
cur_page
=
0
;
int
ret
;
struct
iov_iter
i
;
struct
iovec
iov
;
...
...
@@ -1360,19 +1358,14 @@ struct bio *bio_map_user_iov(struct request_queue *q,
if
(
!
bio
)
return
ERR_PTR
(
-
ENOMEM
);
ret
=
-
ENOMEM
;
pages
=
kcalloc
(
nr_pages
,
sizeof
(
struct
page
*
),
gfp_mask
);
if
(
!
pages
)
goto
out
;
i
=
*
iter
;
while
(
iov_iter_count
(
&
i
))
{
struct
page
**
pages
;
ssize_t
bytes
;
size_t
offs
,
added
=
0
;
int
npages
;
bytes
=
iov_iter_get_pages
(
&
i
,
pages
+
cur_page
,
LONG_MAX
,
nr_pages
-
cur_page
,
&
offs
);
bytes
=
iov_iter_get_pages_alloc
(
&
i
,
&
pages
,
LONG_MAX
,
&
offs
);
if
(
unlikely
(
bytes
<=
0
))
{
ret
=
bytes
?
bytes
:
-
EFAULT
;
goto
out_unmap
;
...
...
@@ -1380,7 +1373,7 @@ struct bio *bio_map_user_iov(struct request_queue *q,
npages
=
DIV_ROUND_UP
(
offs
+
bytes
,
PAGE_SIZE
);
for
(
j
=
cur_page
;
j
<
cur_page
+
npages
;
j
++
)
{
for
(
j
=
0
;
j
<
npages
;
j
++
)
{
unsigned
int
n
=
PAGE_SIZE
-
offs
;
unsigned
short
prev_bi_vcnt
=
bio
->
bi_vcnt
;
...
...
@@ -1409,13 +1402,11 @@ struct bio *bio_map_user_iov(struct request_queue *q,
/*
* release the pages we didn't map into the bio, if any
*/
while
(
j
<
cur_page
+
npages
)
while
(
j
<
npages
)
put_page
(
pages
[
j
++
]);
cur_page
=
j
;
kvfree
(
pages
)
;
}
kfree
(
pages
);
bio_set_flag
(
bio
,
BIO_USER_MAPPED
);
/*
...
...
@@ -1431,8 +1422,6 @@ struct bio *bio_map_user_iov(struct request_queue *q,
bio_for_each_segment_all
(
bvec
,
bio
,
j
)
{
put_page
(
bvec
->
bv_page
);
}
out:
kfree
(
pages
);
bio_put
(
bio
);
return
ERR_PTR
(
ret
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录