Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
6d652330
K
Kernel
项目概览
openeuler
/
Kernel
接近 2 年 前同步成功
通知
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看板
提交
6d652330
编写于
1月 30, 2015
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
net/socket.c: fold do_sock_{read,write} into callers
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
1d10eb2f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
35 deletion
+21
-35
net/socket.c
net/socket.c
+21
-35
未找到文件。
net/socket.c
浏览文件 @
6d652330
...
@@ -845,25 +845,11 @@ static ssize_t sock_splice_read(struct file *file, loff_t *ppos,
...
@@ -845,25 +845,11 @@ static ssize_t sock_splice_read(struct file *file, loff_t *ppos,
return
sock
->
ops
->
splice_read
(
sock
,
ppos
,
pipe
,
len
,
flags
);
return
sock
->
ops
->
splice_read
(
sock
,
ppos
,
pipe
,
len
,
flags
);
}
}
static
ssize_t
do_sock_read
(
struct
msghdr
*
msg
,
struct
kiocb
*
iocb
,
struct
file
*
file
,
const
struct
iovec
*
iov
,
unsigned
long
nr_segs
)
{
struct
socket
*
sock
=
file
->
private_data
;
msg
->
msg_name
=
NULL
;
msg
->
msg_namelen
=
0
;
msg
->
msg_control
=
NULL
;
msg
->
msg_controllen
=
0
;
iov_iter_init
(
&
msg
->
msg_iter
,
READ
,
iov
,
nr_segs
,
iocb
->
ki_nbytes
);
msg
->
msg_flags
=
(
file
->
f_flags
&
O_NONBLOCK
)
?
MSG_DONTWAIT
:
0
;
return
__sock_recvmsg
(
iocb
,
sock
,
msg
,
iocb
->
ki_nbytes
,
msg
->
msg_flags
);
}
static
ssize_t
sock_aio_read
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
static
ssize_t
sock_aio_read
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
unsigned
long
nr_segs
,
loff_t
pos
)
unsigned
long
nr_segs
,
loff_t
pos
)
{
{
struct
file
*
file
=
iocb
->
ki_filp
;
struct
socket
*
sock
=
file
->
private_data
;
struct
msghdr
msg
;
struct
msghdr
msg
;
if
(
pos
!=
0
)
if
(
pos
!=
0
)
...
@@ -872,36 +858,36 @@ static ssize_t sock_aio_read(struct kiocb *iocb, const struct iovec *iov,
...
@@ -872,36 +858,36 @@ static ssize_t sock_aio_read(struct kiocb *iocb, const struct iovec *iov,
if
(
iocb
->
ki_nbytes
==
0
)
/* Match SYS5 behaviour */
if
(
iocb
->
ki_nbytes
==
0
)
/* Match SYS5 behaviour */
return
0
;
return
0
;
return
do_sock_read
(
&
msg
,
iocb
,
iocb
->
ki_filp
,
iov
,
nr_segs
);
msg
.
msg_name
=
NULL
;
}
msg
.
msg_namelen
=
0
;
msg
.
msg_control
=
NULL
;
static
ssize_t
do_sock_write
(
struct
msghdr
*
msg
,
struct
kiocb
*
iocb
,
msg
.
msg_controllen
=
0
;
struct
file
*
file
,
const
struct
iovec
*
iov
,
iov_iter_init
(
&
msg
.
msg_iter
,
READ
,
iov
,
nr_segs
,
iocb
->
ki_nbytes
);
unsigned
long
nr_segs
)
msg
.
msg_flags
=
(
file
->
f_flags
&
O_NONBLOCK
)
?
MSG_DONTWAIT
:
0
;
{
struct
socket
*
sock
=
file
->
private_data
;
msg
->
msg_name
=
NULL
;
msg
->
msg_namelen
=
0
;
msg
->
msg_control
=
NULL
;
msg
->
msg_controllen
=
0
;
iov_iter_init
(
&
msg
->
msg_iter
,
WRITE
,
iov
,
nr_segs
,
iocb
->
ki_nbytes
);
msg
->
msg_flags
=
(
file
->
f_flags
&
O_NONBLOCK
)
?
MSG_DONTWAIT
:
0
;
if
(
sock
->
type
==
SOCK_SEQPACKET
)
msg
->
msg_flags
|=
MSG_EOR
;
return
__sock_
sendmsg
(
iocb
,
sock
,
msg
,
iocb
->
ki_nbyte
s
);
return
__sock_
recvmsg
(
iocb
,
sock
,
&
msg
,
iocb
->
ki_nbytes
,
msg
.
msg_flag
s
);
}
}
static
ssize_t
sock_aio_write
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
static
ssize_t
sock_aio_write
(
struct
kiocb
*
iocb
,
const
struct
iovec
*
iov
,
unsigned
long
nr_segs
,
loff_t
pos
)
unsigned
long
nr_segs
,
loff_t
pos
)
{
{
struct
file
*
file
=
iocb
->
ki_filp
;
struct
socket
*
sock
=
file
->
private_data
;
struct
msghdr
msg
;
struct
msghdr
msg
;
if
(
pos
!=
0
)
if
(
pos
!=
0
)
return
-
ESPIPE
;
return
-
ESPIPE
;
return
do_sock_write
(
&
msg
,
iocb
,
iocb
->
ki_filp
,
iov
,
nr_segs
);
msg
.
msg_name
=
NULL
;
msg
.
msg_namelen
=
0
;
msg
.
msg_control
=
NULL
;
msg
.
msg_controllen
=
0
;
iov_iter_init
(
&
msg
.
msg_iter
,
WRITE
,
iov
,
nr_segs
,
iocb
->
ki_nbytes
);
msg
.
msg_flags
=
(
file
->
f_flags
&
O_NONBLOCK
)
?
MSG_DONTWAIT
:
0
;
if
(
sock
->
type
==
SOCK_SEQPACKET
)
msg
.
msg_flags
|=
MSG_EOR
;
return
__sock_sendmsg
(
iocb
,
sock
,
&
msg
,
iocb
->
ki_nbytes
);
}
}
/*
/*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录