Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
2ba5bbed
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
2ba5bbed
编写于
4月 02, 2014
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
shmem: switch to ->read_iter()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
fb9096a3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
10 deletion
+5
-10
mm/shmem.c
mm/shmem.c
+5
-10
未找到文件。
mm/shmem.c
浏览文件 @
2ba5bbed
...
...
@@ -1402,8 +1402,7 @@ shmem_write_end(struct file *file, struct address_space *mapping,
return
copied
;
}
static
ssize_t
shmem_file_aio_read
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
unsigned
long
nr_segs
,
loff_t
pos
)
static
ssize_t
shmem_file_read_iter
(
struct
kiocb
*
iocb
,
struct
iov_iter
*
to
)
{
struct
file
*
file
=
iocb
->
ki_filp
;
struct
inode
*
inode
=
file_inode
(
file
);
...
...
@@ -1413,11 +1412,7 @@ static ssize_t shmem_file_aio_read(struct kiocb *iocb,
enum
sgp_type
sgp
=
SGP_READ
;
int
error
=
0
;
ssize_t
retval
=
0
;
size_t
count
=
iov_length
(
iov
,
nr_segs
);
loff_t
*
ppos
=
&
iocb
->
ki_pos
;
struct
iov_iter
iter
;
iov_iter_init
(
&
iter
,
READ
,
iov
,
nr_segs
,
count
);
/*
* Might this read be for a stacking filesystem? Then when reading
...
...
@@ -1493,14 +1488,14 @@ static ssize_t shmem_file_aio_read(struct kiocb *iocb,
* Ok, we have the page, and it's up-to-date, so
* now we can copy it to user space...
*/
ret
=
copy_page_to_iter
(
page
,
offset
,
nr
,
&
iter
);
ret
=
copy_page_to_iter
(
page
,
offset
,
nr
,
to
);
retval
+=
ret
;
offset
+=
ret
;
index
+=
offset
>>
PAGE_CACHE_SHIFT
;
offset
&=
~
PAGE_CACHE_MASK
;
page_cache_release
(
page
);
if
(
!
iov_iter_count
(
&
iter
))
if
(
!
iov_iter_count
(
to
))
break
;
if
(
ret
<
nr
)
{
error
=
-
EFAULT
;
...
...
@@ -2622,9 +2617,9 @@ static const struct file_operations shmem_file_operations = {
.
mmap
=
shmem_mmap
,
#ifdef CONFIG_TMPFS
.
llseek
=
shmem_file_llseek
,
.
read
=
do
_sync_read
,
.
read
=
new
_sync_read
,
.
write
=
do_sync_write
,
.
aio_read
=
shmem_file_aio_read
,
.
read_iter
=
shmem_file_read_iter
,
.
aio_write
=
generic_file_aio_write
,
.
fsync
=
noop_fsync
,
.
splice_read
=
shmem_file_splice_read
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录