Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
1958b856
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
1958b856
编写于
3月 12, 2011
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
net: Put fl6_* macros to struct flowi6 and use them again.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
4c9483b2
变更
13
隐藏空白更改
内联
并排
Showing
13 changed file
with
58 addition
and
61 deletion
+58
-61
include/net/flow.h
include/net/flow.h
+7
-10
net/dccp/ipv6.c
net/dccp/ipv6.c
+10
-10
net/ipv6/af_inet6.c
net/ipv6/af_inet6.c
+2
-2
net/ipv6/datagram.c
net/ipv6/datagram.c
+3
-3
net/ipv6/icmp.c
net/ipv6/icmp.c
+5
-5
net/ipv6/inet6_connection_sock.c
net/ipv6/inet6_connection_sock.c
+4
-4
net/ipv6/mip6.c
net/ipv6/mip6.c
+1
-1
net/ipv6/netfilter/ip6t_REJECT.c
net/ipv6/netfilter/ip6t_REJECT.c
+2
-2
net/ipv6/raw.c
net/ipv6/raw.c
+3
-3
net/ipv6/syncookies.c
net/ipv6/syncookies.c
+2
-2
net/ipv6/tcp_ipv6.c
net/ipv6/tcp_ipv6.c
+8
-8
net/ipv6/udp.c
net/ipv6/udp.c
+5
-5
net/ipv6/xfrm6_policy.c
net/ipv6/xfrm6_policy.c
+6
-6
未找到文件。
include/net/flow.h
浏览文件 @
1958b856
...
...
@@ -84,6 +84,13 @@ struct flowi6 {
struct
in6_addr
saddr
;
__be32
flowlabel
;
union
flowi_uli
uli
;
#define fl6_sport uli.ports.sport
#define fl6_dport uli.ports.dport
#define fl6_icmp_type uli.icmpt.type
#define fl6_icmp_code uli.icmpt.code
#define fl6_ipsec_spi uli.spi
#define fl6_mh_type uli.mht.type
#define fl6_gre_key uli.gre_key
};
struct
flowidn
{
...
...
@@ -112,16 +119,6 @@ struct flowi {
#define fld_dst u.dn.daddr
#define fld_src u.dn.saddr
#define fl6_dst u.ip6.daddr
#define fl6_src u.ip6.saddr
#define fl6_flowlabel u.ip6.flowlabel
#define fl6_sport u.ip6.uli.ports.sport
#define fl6_dport u.ip6.uli.ports.dport
#define fl6_icmp_type u.ip6.uli.icmpt.type
#define fl6_icmp_code u.ip6.uli.icmpt.code
#define fl6_ipsec_spi u.ip6.uli.spi
#define fl6_mh_type u.ip6.uli.mht.type
#define fl6_gre_key u.ip6.uli.gre_key
}
__attribute__
((
__aligned__
(
BITS_PER_LONG
/
8
)));
static
inline
struct
flowi
*
flowi4_to_flowi
(
struct
flowi4
*
fl4
)
...
...
net/dccp/ipv6.c
浏览文件 @
1958b856
...
...
@@ -158,8 +158,8 @@ static void dccp_v6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
ipv6_addr_copy
(
&
fl6
.
daddr
,
&
np
->
daddr
);
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
np
->
saddr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_dst_lookup_flow
(
sk
,
&
fl6
,
NULL
,
false
);
...
...
@@ -253,8 +253,8 @@ static int dccp_v6_send_response(struct sock *sk, struct request_sock *req,
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
ireq6
->
loc_addr
);
fl6
.
flowlabel
=
0
;
fl6
.
flowi6_oif
=
ireq6
->
iif
;
fl6
.
uli
.
ports
.
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
uli
.
ports
.
sport
=
inet_rsk
(
req
)
->
loc_port
;
fl6
.
fl6_
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
fl6_
sport
=
inet_rsk
(
req
)
->
loc_port
;
security_req_classify_flow
(
req
,
flowi6_to_flowi
(
&
fl6
));
opt
=
np
->
opt
;
...
...
@@ -323,8 +323,8 @@ static void dccp_v6_ctl_send_reset(struct sock *sk, struct sk_buff *rxskb)
fl6
.
flowi6_proto
=
IPPROTO_DCCP
;
fl6
.
flowi6_oif
=
inet6_iif
(
rxskb
);
fl6
.
uli
.
ports
.
dport
=
dccp_hdr
(
skb
)
->
dccph_dport
;
fl6
.
uli
.
ports
.
sport
=
dccp_hdr
(
skb
)
->
dccph_sport
;
fl6
.
fl6_
dport
=
dccp_hdr
(
skb
)
->
dccph_dport
;
fl6
.
fl6_
sport
=
dccp_hdr
(
skb
)
->
dccph_sport
;
security_skb_classify_flow
(
rxskb
,
flowi6_to_flowi
(
&
fl6
));
/* sk = NULL, but it is safe for now. RST socket required. */
...
...
@@ -535,8 +535,8 @@ static struct sock *dccp_v6_request_recv_sock(struct sock *sk,
final_p
=
fl6_update_dst
(
&
fl6
,
opt
,
&
final
);
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
ireq6
->
loc_addr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
uli
.
ports
.
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
uli
.
ports
.
sport
=
inet_rsk
(
req
)
->
loc_port
;
fl6
.
fl6_
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
fl6_
sport
=
inet_rsk
(
req
)
->
loc_port
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_dst_lookup_flow
(
sk
,
&
fl6
,
final_p
,
false
);
...
...
@@ -957,8 +957,8 @@ static int dccp_v6_connect(struct sock *sk, struct sockaddr *uaddr,
ipv6_addr_copy
(
&
fl6
.
daddr
,
&
np
->
daddr
);
ipv6_addr_copy
(
&
fl6
.
saddr
,
saddr
?
saddr
:
&
np
->
saddr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
uli
.
ports
.
dport
=
usin
->
sin6_port
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
usin
->
sin6_port
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
&
fl6
));
final_p
=
fl6_update_dst
(
&
fl6
,
np
->
opt
,
&
final
);
...
...
net/ipv6/af_inet6.c
浏览文件 @
1958b856
...
...
@@ -661,8 +661,8 @@ int inet6_sk_rebuild_header(struct sock *sk)
fl6
.
flowlabel
=
np
->
flow_label
;
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
&
fl6
));
final_p
=
fl6_update_dst
(
&
fl6
,
np
->
opt
,
&
final
);
...
...
net/ipv6/datagram.c
浏览文件 @
1958b856
...
...
@@ -151,8 +151,8 @@ int ip6_datagram_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len)
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
np
->
saddr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
if
(
!
fl6
.
flowi6_oif
&&
(
addr_type
&
IPV6_ADDR_MULTICAST
))
fl6
.
flowi6_oif
=
np
->
mcast_oif
;
...
...
@@ -261,7 +261,7 @@ void ipv6_local_error(struct sock *sk, int err, struct flowi6 *fl6, u32 info)
serr
->
ee
.
ee_info
=
info
;
serr
->
ee
.
ee_data
=
0
;
serr
->
addr_offset
=
(
u8
*
)
&
iph
->
daddr
-
skb_network_header
(
skb
);
serr
->
port
=
fl6
->
uli
.
ports
.
dport
;
serr
->
port
=
fl6
->
fl6_
dport
;
__skb_pull
(
skb
,
skb_tail_pointer
(
skb
)
-
skb
->
data
);
skb_reset_transport_header
(
skb
);
...
...
net/ipv6/icmp.c
浏览文件 @
1958b856
...
...
@@ -448,8 +448,8 @@ void icmpv6_send(struct sk_buff *skb, u8 type, u8 code, __u32 info)
if
(
saddr
)
ipv6_addr_copy
(
&
fl6
.
saddr
,
saddr
);
fl6
.
flowi6_oif
=
iif
;
fl6
.
uli
.
icmpt
.
type
=
type
;
fl6
.
uli
.
icmpt
.
code
=
code
;
fl6
.
fl6_icmp_
type
=
type
;
fl6
.
fl6_icmp_
code
=
code
;
security_skb_classify_flow
(
skb
,
flowi6_to_flowi
(
&
fl6
));
sk
=
icmpv6_xmit_lock
(
net
);
...
...
@@ -544,7 +544,7 @@ static void icmpv6_echo_reply(struct sk_buff *skb)
if
(
saddr
)
ipv6_addr_copy
(
&
fl6
.
saddr
,
saddr
);
fl6
.
flowi6_oif
=
skb
->
dev
->
ifindex
;
fl6
.
uli
.
icmpt
.
type
=
ICMPV6_ECHO_REPLY
;
fl6
.
fl6_icmp_
type
=
ICMPV6_ECHO_REPLY
;
security_skb_classify_flow
(
skb
,
flowi6_to_flowi
(
&
fl6
));
sk
=
icmpv6_xmit_lock
(
net
);
...
...
@@ -794,8 +794,8 @@ void icmpv6_flow_init(struct sock *sk, struct flowi6 *fl6,
ipv6_addr_copy
(
&
fl6
->
saddr
,
saddr
);
ipv6_addr_copy
(
&
fl6
->
daddr
,
daddr
);
fl6
->
flowi6_proto
=
IPPROTO_ICMPV6
;
fl6
->
uli
.
icmpt
.
type
=
type
;
fl6
->
uli
.
icmpt
.
code
=
0
;
fl6
->
fl6_icmp_
type
=
type
;
fl6
->
fl6_icmp_
code
=
0
;
fl6
->
flowi6_oif
=
oif
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
fl6
));
}
...
...
net/ipv6/inet6_connection_sock.c
浏览文件 @
1958b856
...
...
@@ -70,8 +70,8 @@ struct dst_entry *inet6_csk_route_req(struct sock *sk,
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
treq
->
loc_addr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
uli
.
ports
.
sport
=
inet_rsk
(
req
)
->
loc_port
;
fl6
.
fl6_
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
fl6_
sport
=
inet_rsk
(
req
)
->
loc_port
;
security_req_classify_flow
(
req
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_dst_lookup_flow
(
sk
,
&
fl6
,
final_p
,
false
);
...
...
@@ -220,8 +220,8 @@ int inet6_csk_xmit(struct sk_buff *skb)
IP6_ECN_flow_xmit
(
sk
,
fl6
.
flowlabel
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
security_sk_classify_flow
(
sk
,
flowi6_to_flowi
(
&
fl6
));
final_p
=
fl6_update_dst
(
&
fl6
,
np
->
opt
,
&
final
);
...
...
net/ipv6/mip6.c
浏览文件 @
1958b856
...
...
@@ -216,7 +216,7 @@ static int mip6_destopt_reject(struct xfrm_state *x, struct sk_buff *skb,
int
err
=
0
;
if
(
unlikely
(
fl6
->
flowi6_proto
==
IPPROTO_MH
&&
fl6
->
uli
.
mht
.
type
<=
IP6_MH_TYPE_MAX
))
fl6
->
fl6_mh_
type
<=
IP6_MH_TYPE_MAX
))
goto
out
;
if
(
likely
(
opt
->
dsthao
))
{
...
...
net/ipv6/netfilter/ip6t_REJECT.c
浏览文件 @
1958b856
...
...
@@ -93,8 +93,8 @@ static void send_reset(struct net *net, struct sk_buff *oldskb)
fl6
.
flowi6_proto
=
IPPROTO_TCP
;
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
oip6h
->
daddr
);
ipv6_addr_copy
(
&
fl6
.
daddr
,
&
oip6h
->
saddr
);
fl6
.
uli
.
ports
.
sport
=
otcph
.
dest
;
fl6
.
uli
.
ports
.
dport
=
otcph
.
source
;
fl6
.
fl6_
sport
=
otcph
.
dest
;
fl6
.
fl6_
dport
=
otcph
.
source
;
security_skb_classify_flow
(
oldskb
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_route_output
(
net
,
NULL
,
&
fl6
);
if
(
dst
==
NULL
||
dst
->
error
)
{
...
...
net/ipv6/raw.c
浏览文件 @
1958b856
...
...
@@ -693,8 +693,8 @@ static int rawv6_probe_proto_opt(struct flowi6 *fl6, struct msghdr *msg)
code
=
iov
->
iov_base
;
if
(
type
&&
code
)
{
if
(
get_user
(
fl6
->
uli
.
icmpt
.
type
,
type
)
||
get_user
(
fl6
->
uli
.
icmpt
.
code
,
code
))
if
(
get_user
(
fl6
->
fl6_icmp_
type
,
type
)
||
get_user
(
fl6
->
fl6_icmp_
code
,
code
))
return
-
EFAULT
;
probed
=
1
;
}
...
...
@@ -705,7 +705,7 @@ static int rawv6_probe_proto_opt(struct flowi6 *fl6, struct msghdr *msg)
/* check if type field is readable or not. */
if
(
iov
->
iov_len
>
2
-
len
)
{
u8
__user
*
p
=
iov
->
iov_base
;
if
(
get_user
(
fl6
->
uli
.
mht
.
type
,
&
p
[
2
-
len
]))
if
(
get_user
(
fl6
->
fl6_mh_
type
,
&
p
[
2
-
len
]))
return
-
EFAULT
;
probed
=
1
;
}
else
...
...
net/ipv6/syncookies.c
浏览文件 @
1958b856
...
...
@@ -240,8 +240,8 @@ struct sock *cookie_v6_check(struct sock *sk, struct sk_buff *skb)
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
ireq6
->
loc_addr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
uli
.
ports
.
sport
=
inet_sk
(
sk
)
->
inet_sport
;
fl6
.
fl6_
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
fl6_
sport
=
inet_sk
(
sk
)
->
inet_sport
;
security_req_classify_flow
(
req
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_dst_lookup_flow
(
sk
,
&
fl6
,
final_p
,
false
);
...
...
net/ipv6/tcp_ipv6.c
浏览文件 @
1958b856
...
...
@@ -248,8 +248,8 @@ static int tcp_v6_connect(struct sock *sk, struct sockaddr *uaddr,
(
saddr
?
saddr
:
&
np
->
saddr
));
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
usin
->
sin6_port
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
usin
->
sin6_port
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
final_p
=
fl6_update_dst
(
&
fl6
,
np
->
opt
,
&
final
);
...
...
@@ -401,8 +401,8 @@ static void tcp_v6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
np
->
saddr
);
fl6
.
flowi6_oif
=
sk
->
sk_bound_dev_if
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
security_skb_classify_flow
(
skb
,
flowi6_to_flowi
(
&
fl6
));
dst
=
ip6_dst_lookup_flow
(
sk
,
&
fl6
,
NULL
,
false
);
...
...
@@ -493,8 +493,8 @@ static int tcp_v6_send_synack(struct sock *sk, struct request_sock *req,
fl6
.
flowlabel
=
0
;
fl6
.
flowi6_oif
=
treq
->
iif
;
fl6
.
flowi6_mark
=
sk
->
sk_mark
;
fl6
.
uli
.
ports
.
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
uli
.
ports
.
sport
=
inet_rsk
(
req
)
->
loc_port
;
fl6
.
fl6_
dport
=
inet_rsk
(
req
)
->
rmt_port
;
fl6
.
fl6_
sport
=
inet_rsk
(
req
)
->
loc_port
;
security_req_classify_flow
(
req
,
flowi6_to_flowi
(
&
fl6
));
opt
=
np
->
opt
;
...
...
@@ -1057,8 +1057,8 @@ static void tcp_v6_send_response(struct sk_buff *skb, u32 seq, u32 ack, u32 win,
fl6
.
flowi6_proto
=
IPPROTO_TCP
;
fl6
.
flowi6_oif
=
inet6_iif
(
skb
);
fl6
.
uli
.
ports
.
dport
=
t1
->
dest
;
fl6
.
uli
.
ports
.
sport
=
t1
->
source
;
fl6
.
fl6_
dport
=
t1
->
dest
;
fl6
.
fl6_
sport
=
t1
->
source
;
security_skb_classify_flow
(
skb
,
flowi6_to_flowi
(
&
fl6
));
/* Pass a socket to ip6_dst_lookup either it is for RST
...
...
net/ipv6/udp.c
浏览文件 @
1958b856
...
...
@@ -899,8 +899,8 @@ static int udp_v6_push_pending_frames(struct sock *sk)
* Create a UDP header
*/
uh
=
udp_hdr
(
skb
);
uh
->
source
=
fl6
->
uli
.
ports
.
sport
;
uh
->
dest
=
fl6
->
uli
.
ports
.
dport
;
uh
->
source
=
fl6
->
fl6_
sport
;
uh
->
dest
=
fl6
->
fl6_
dport
;
uh
->
len
=
htons
(
up
->
len
);
uh
->
check
=
0
;
...
...
@@ -1036,7 +1036,7 @@ int udpv6_sendmsg(struct kiocb *iocb, struct sock *sk,
if
(
sin6
->
sin6_port
==
0
)
return
-
EINVAL
;
fl6
.
uli
.
ports
.
dport
=
sin6
->
sin6_port
;
fl6
.
fl6_
dport
=
sin6
->
sin6_port
;
daddr
=
&
sin6
->
sin6_addr
;
if
(
np
->
sndflow
)
{
...
...
@@ -1065,7 +1065,7 @@ int udpv6_sendmsg(struct kiocb *iocb, struct sock *sk,
if
(
sk
->
sk_state
!=
TCP_ESTABLISHED
)
return
-
EDESTADDRREQ
;
fl6
.
uli
.
ports
.
dport
=
inet
->
inet_dport
;
fl6
.
fl6_
dport
=
inet
->
inet_dport
;
daddr
=
&
np
->
daddr
;
fl6
.
flowlabel
=
np
->
flow_label
;
connected
=
1
;
...
...
@@ -1112,7 +1112,7 @@ int udpv6_sendmsg(struct kiocb *iocb, struct sock *sk,
fl6
.
daddr
.
s6_addr
[
15
]
=
0x1
;
/* :: means loopback (BSD'ism) */
if
(
ipv6_addr_any
(
&
fl6
.
saddr
)
&&
!
ipv6_addr_any
(
&
np
->
saddr
))
ipv6_addr_copy
(
&
fl6
.
saddr
,
&
np
->
saddr
);
fl6
.
uli
.
ports
.
sport
=
inet
->
inet_sport
;
fl6
.
fl6_
sport
=
inet
->
inet_sport
;
final_p
=
fl6_update_dst
(
&
fl6
,
opt
,
&
final
);
if
(
final_p
)
...
...
net/ipv6/xfrm6_policy.c
浏览文件 @
1958b856
...
...
@@ -160,8 +160,8 @@ _decode_session6(struct sk_buff *skb, struct flowi *fl, int reverse)
pskb_may_pull
(
skb
,
nh
+
offset
+
4
-
skb
->
data
)))
{
__be16
*
ports
=
(
__be16
*
)
exthdr
;
fl6
->
uli
.
ports
.
sport
=
ports
[
!!
reverse
];
fl6
->
uli
.
ports
.
dport
=
ports
[
!
reverse
];
fl6
->
fl6_
sport
=
ports
[
!!
reverse
];
fl6
->
fl6_
dport
=
ports
[
!
reverse
];
}
fl6
->
flowi6_proto
=
nexthdr
;
return
;
...
...
@@ -170,8 +170,8 @@ _decode_session6(struct sk_buff *skb, struct flowi *fl, int reverse)
if
(
!
onlyproto
&&
pskb_may_pull
(
skb
,
nh
+
offset
+
2
-
skb
->
data
))
{
u8
*
icmp
=
(
u8
*
)
exthdr
;
fl6
->
uli
.
icmpt
.
type
=
icmp
[
0
];
fl6
->
uli
.
icmpt
.
code
=
icmp
[
1
];
fl6
->
fl6_icmp_
type
=
icmp
[
0
];
fl6
->
fl6_icmp_
code
=
icmp
[
1
];
}
fl6
->
flowi6_proto
=
nexthdr
;
return
;
...
...
@@ -182,7 +182,7 @@ _decode_session6(struct sk_buff *skb, struct flowi *fl, int reverse)
struct
ip6_mh
*
mh
;
mh
=
(
struct
ip6_mh
*
)
exthdr
;
fl6
->
uli
.
mht
.
type
=
mh
->
ip6mh_type
;
fl6
->
fl6_mh_
type
=
mh
->
ip6mh_type
;
}
fl6
->
flowi6_proto
=
nexthdr
;
return
;
...
...
@@ -193,7 +193,7 @@ _decode_session6(struct sk_buff *skb, struct flowi *fl, int reverse)
case
IPPROTO_ESP
:
case
IPPROTO_COMP
:
default:
fl6
->
uli
.
spi
=
0
;
fl6
->
fl6_ipsec_
spi
=
0
;
fl6
->
flowi6_proto
=
nexthdr
;
return
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录