Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
3ef045c3
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
3ef045c3
编写于
4月 03, 2014
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ocfs2: switch to ->write_iter()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
bf97f3bc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
18 deletion
+12
-18
fs/ocfs2/file.c
fs/ocfs2/file.c
+12
-18
未找到文件。
fs/ocfs2/file.c
浏览文件 @
3ef045c3
...
...
@@ -2233,15 +2233,13 @@ static int ocfs2_prepare_inode_for_write(struct file *file,
return
ret
;
}
static
ssize_t
ocfs2_file_aio_write
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
unsigned
long
nr_segs
,
loff_t
pos
)
static
ssize_t
ocfs2_file_write_iter
(
struct
kiocb
*
iocb
,
struct
iov_iter
*
from
)
{
int
ret
,
direct_io
,
appending
,
rw_level
,
have_alloc_sem
=
0
;
int
can_do_direct
,
has_refcount
=
0
;
ssize_t
written
=
0
;
size_t
count
;
/* after file limit checks */
size_t
count
=
iov_iter_count
(
from
);
loff_t
old_size
,
*
ppos
=
&
iocb
->
ki_pos
;
u32
old_clusters
;
struct
file
*
file
=
iocb
->
ki_filp
;
...
...
@@ -2250,16 +2248,12 @@ static ssize_t ocfs2_file_aio_write(struct kiocb *iocb,
int
full_coherency
=
!
(
osb
->
s_mount_opt
&
OCFS2_MOUNT_COHERENCY_BUFFERED
);
int
unaligned_dio
=
0
;
struct
iov_iter
from
;
count
=
iov_length
(
iov
,
nr_segs
);
iov_iter_init
(
&
from
,
WRITE
,
iov
,
nr_segs
,
count
);
trace_ocfs2_file_aio_write
(
inode
,
file
,
file
->
f_path
.
dentry
,
(
unsigned
long
long
)
OCFS2_I
(
inode
)
->
ip_blkno
,
file
->
f_path
.
dentry
->
d_name
.
len
,
file
->
f_path
.
dentry
->
d_name
.
name
,
(
unsigned
int
)
nr_segs
);
(
unsigned
int
)
from
->
nr_segs
);
/* GRRRRR */
if
(
iocb
->
ki_nbytes
==
0
)
return
0
;
...
...
@@ -2362,16 +2356,16 @@ static ssize_t ocfs2_file_aio_write(struct kiocb *iocb,
if
(
ret
)
goto
out_dio
;
iov_iter_truncate
(
&
from
,
count
);
iov_iter_truncate
(
from
,
count
);
if
(
direct_io
)
{
written
=
generic_file_direct_write
(
iocb
,
&
from
,
*
ppos
);
written
=
generic_file_direct_write
(
iocb
,
from
,
*
ppos
);
if
(
written
<
0
)
{
ret
=
written
;
goto
out_dio
;
}
}
else
{
current
->
backing_dev_info
=
file
->
f_mapping
->
backing_dev_info
;
written
=
generic_perform_write
(
file
,
&
from
,
*
ppos
);
written
=
generic_perform_write
(
file
,
from
,
*
ppos
);
if
(
likely
(
written
>=
0
))
iocb
->
ki_pos
=
*
ppos
+
written
;
current
->
backing_dev_info
=
NULL
;
...
...
@@ -2606,7 +2600,7 @@ static ssize_t ocfs2_file_read_iter(struct kiocb *iocb,
/* buffered aio wouldn't have proper lock coverage today */
BUG_ON
(
ret
==
-
EIOCBQUEUED
&&
!
(
filp
->
f_flags
&
O_DIRECT
));
/* see ocfs2_file_
aio_write
*/
/* see ocfs2_file_
write_iter
*/
if
(
ret
==
-
EIOCBQUEUED
||
!
ocfs2_iocb_is_rw_locked
(
iocb
))
{
rw_level
=
-
1
;
have_alloc_sem
=
0
;
...
...
@@ -2700,13 +2694,13 @@ const struct inode_operations ocfs2_special_file_iops = {
const
struct
file_operations
ocfs2_fops
=
{
.
llseek
=
ocfs2_file_llseek
,
.
read
=
new_sync_read
,
.
write
=
do
_sync_write
,
.
write
=
new
_sync_write
,
.
mmap
=
ocfs2_mmap
,
.
fsync
=
ocfs2_sync_file
,
.
release
=
ocfs2_file_release
,
.
open
=
ocfs2_file_open
,
.
read_iter
=
ocfs2_file_read_iter
,
.
aio_write
=
ocfs2_file_aio_write
,
.
write_iter
=
ocfs2_file_write_iter
,
.
unlocked_ioctl
=
ocfs2_ioctl
,
#ifdef CONFIG_COMPAT
.
compat_ioctl
=
ocfs2_compat_ioctl
,
...
...
@@ -2748,13 +2742,13 @@ const struct file_operations ocfs2_dops = {
const
struct
file_operations
ocfs2_fops_no_plocks
=
{
.
llseek
=
ocfs2_file_llseek
,
.
read
=
new_sync_read
,
.
write
=
do
_sync_write
,
.
write
=
new
_sync_write
,
.
mmap
=
ocfs2_mmap
,
.
fsync
=
ocfs2_sync_file
,
.
release
=
ocfs2_file_release
,
.
open
=
ocfs2_file_open
,
.
read_iter
=
ocfs2_file_read_iter
,
.
aio_write
=
ocfs2_file_aio_write
,
.
write_iter
=
ocfs2_file_write_iter
,
.
unlocked_ioctl
=
ocfs2_ioctl
,
#ifdef CONFIG_COMPAT
.
compat_ioctl
=
ocfs2_compat_ioctl
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录