Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
227158db
cloud-kernel
项目概览
openanolis
/
cloud-kernel
接近 2 年 前同步成功
通知
169
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看板
提交
227158db
编写于
4月 06, 2014
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
new helper: skb_copy_and_csum_datagram_msg()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
c33d23c2
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
9 addition
and
5 deletion
+9
-5
include/linux/skbuff.h
include/linux/skbuff.h
+5
-0
net/ipv4/udp.c
net/ipv4/udp.c
+2
-3
net/ipv6/raw.c
net/ipv6/raw.c
+1
-1
net/ipv6/udp.c
net/ipv6/udp.c
+1
-1
未找到文件。
include/linux/skbuff.h
浏览文件 @
227158db
...
@@ -2651,6 +2651,11 @@ static inline int skb_copy_datagram_msg(const struct sk_buff *from, int offset,
...
@@ -2651,6 +2651,11 @@ static inline int skb_copy_datagram_msg(const struct sk_buff *from, int offset,
}
}
int
skb_copy_and_csum_datagram_iovec
(
struct
sk_buff
*
skb
,
int
hlen
,
int
skb_copy_and_csum_datagram_iovec
(
struct
sk_buff
*
skb
,
int
hlen
,
struct
iovec
*
iov
);
struct
iovec
*
iov
);
static
inline
int
skb_copy_and_csum_datagram_msg
(
struct
sk_buff
*
skb
,
int
hlen
,
struct
msghdr
*
msg
)
{
return
skb_copy_and_csum_datagram_iovec
(
skb
,
hlen
,
msg
->
msg_iov
);
}
int
skb_copy_datagram_from_iovec
(
struct
sk_buff
*
skb
,
int
offset
,
int
skb_copy_datagram_from_iovec
(
struct
sk_buff
*
skb
,
int
offset
,
const
struct
iovec
*
from
,
int
from_offset
,
const
struct
iovec
*
from
,
int
from_offset
,
int
len
);
int
len
);
...
...
net/ipv4/udp.c
浏览文件 @
227158db
...
@@ -1284,9 +1284,8 @@ int udp_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
...
@@ -1284,9 +1284,8 @@ int udp_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
err
=
skb_copy_datagram_msg
(
skb
,
sizeof
(
struct
udphdr
),
err
=
skb_copy_datagram_msg
(
skb
,
sizeof
(
struct
udphdr
),
msg
,
copied
);
msg
,
copied
);
else
{
else
{
err
=
skb_copy_and_csum_datagram_iovec
(
skb
,
err
=
skb_copy_and_csum_datagram_msg
(
skb
,
sizeof
(
struct
udphdr
),
sizeof
(
struct
udphdr
),
msg
);
msg
->
msg_iov
);
if
(
err
==
-
EINVAL
)
if
(
err
==
-
EINVAL
)
goto
csum_copy_err
;
goto
csum_copy_err
;
...
...
net/ipv6/raw.c
浏览文件 @
227158db
...
@@ -492,7 +492,7 @@ static int rawv6_recvmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -492,7 +492,7 @@ static int rawv6_recvmsg(struct kiocb *iocb, struct sock *sk,
goto
csum_copy_err
;
goto
csum_copy_err
;
err
=
skb_copy_datagram_msg
(
skb
,
0
,
msg
,
copied
);
err
=
skb_copy_datagram_msg
(
skb
,
0
,
msg
,
copied
);
}
else
{
}
else
{
err
=
skb_copy_and_csum_datagram_
iovec
(
skb
,
0
,
msg
->
msg_iov
);
err
=
skb_copy_and_csum_datagram_
msg
(
skb
,
0
,
msg
);
if
(
err
==
-
EINVAL
)
if
(
err
==
-
EINVAL
)
goto
csum_copy_err
;
goto
csum_copy_err
;
}
}
...
...
net/ipv6/udp.c
浏览文件 @
227158db
...
@@ -428,7 +428,7 @@ int udpv6_recvmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -428,7 +428,7 @@ int udpv6_recvmsg(struct kiocb *iocb, struct sock *sk,
err
=
skb_copy_datagram_msg
(
skb
,
sizeof
(
struct
udphdr
),
err
=
skb_copy_datagram_msg
(
skb
,
sizeof
(
struct
udphdr
),
msg
,
copied
);
msg
,
copied
);
else
{
else
{
err
=
skb_copy_and_csum_datagram_
iovec
(
skb
,
sizeof
(
struct
udphdr
),
msg
->
msg_iov
);
err
=
skb_copy_and_csum_datagram_
msg
(
skb
,
sizeof
(
struct
udphdr
),
msg
);
if
(
err
==
-
EINVAL
)
if
(
err
==
-
EINVAL
)
goto
csum_copy_err
;
goto
csum_copy_err
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录