Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
c9c37e2e
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看板
提交
c9c37e2e
编写于
3月 16, 2014
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fuse: switch to iov_iter_get_pages()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
d22a943f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
21 deletion
+12
-21
fs/fuse/file.c
fs/fuse/file.c
+12
-21
未找到文件。
fs/fuse/file.c
浏览文件 @
c9c37e2e
...
...
@@ -1294,7 +1294,7 @@ static int fuse_get_user_pages(struct fuse_req *req, struct iov_iter *ii,
size_t
nbytes
=
0
;
/* # bytes already packed in req */
/* Special case for kernel I/O: can copy directly into the buffer */
if
(
segment_eq
(
get_fs
(),
KERNEL_DS
)
)
{
if
(
ii
->
type
&
REQ_KERNEL
)
{
unsigned
long
user_addr
=
fuse_get_user_addr
(
ii
);
size_t
frag_size
=
fuse_get_frag_size
(
ii
,
*
nbytesp
);
...
...
@@ -1310,35 +1310,26 @@ static int fuse_get_user_pages(struct fuse_req *req, struct iov_iter *ii,
while
(
nbytes
<
*
nbytesp
&&
req
->
num_pages
<
req
->
max_pages
)
{
unsigned
npages
;
unsigned
long
user_addr
=
fuse_get_user_addr
(
ii
);
unsigned
offset
=
user_addr
&
~
PAGE_MASK
;
size_t
frag_size
=
fuse_get_frag_size
(
ii
,
*
nbytesp
-
nbytes
);
int
ret
;
size_t
start
,
end
,
frag_size
;
unsigned
n
=
req
->
max_pages
-
req
->
num_pages
;
frag_size
=
min_t
(
size_t
,
frag_size
,
n
<<
PAGE_SHIFT
);
npages
=
(
frag_size
+
offset
+
PAGE_SIZE
-
1
)
>>
PAGE_SHIFT
;
npages
=
clamp
(
npages
,
1U
,
n
);
ret
=
get_user_pages_fast
(
user_addr
,
npages
,
!
write
,
&
req
->
pages
[
req
->
num_pages
]);
ssize_t
ret
=
iov_iter_get_pages
(
ii
,
&
req
->
pages
[
req
->
num_pages
],
n
*
PAGE_SIZE
,
&
start
);
if
(
ret
<
0
)
return
ret
;
npages
=
ret
;
frag_size
=
min_t
(
size_t
,
frag_size
,
(
npages
<<
PAGE_SHIFT
)
-
offset
);
iov_iter_advance
(
ii
,
frag_size
);
iov_iter_advance
(
ii
,
ret
);
nbytes
+=
ret
;
req
->
page_descs
[
req
->
num_pages
].
offset
=
offset
;
ret
+=
start
;
npages
=
(
ret
+
PAGE_SIZE
-
1
)
/
PAGE_SIZE
;
req
->
page_descs
[
req
->
num_pages
].
offset
=
start
;
fuse_page_descs_length_init
(
req
,
req
->
num_pages
,
npages
);
req
->
num_pages
+=
npages
;
req
->
page_descs
[
req
->
num_pages
-
1
].
length
-=
(
npages
<<
PAGE_SHIFT
)
-
offset
-
frag_size
;
nbytes
+=
frag_size
;
(
PAGE_SIZE
-
ret
)
&
(
PAGE_SIZE
-
1
);
}
if
(
write
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录