mirror of
https://github.com/torvalds/linux.git
synced 2026-06-07 22:14:04 +02:00
netfilter: flowtable: reload ip{v6}h in nf_flow_tuple_ip{v6}
commit41e9ec5a54upstream. Since pskb_may_pull may change skb->data, so we need to reload ip{v6}h at the right place. Fixes:a908fdec3d("netfilter: nf_flow_table: move ipv6 offload hook code to nf_flow_table") Fixes:7d20868717("netfilter: nf_flow_table: move ipv4 offload hook code to nf_flow_table") Signed-off-by: Haishuang Yan <yanhaishuang@cmss.chinamobile.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
ef21d2431f
commit
113df2c58a
|
|
@ -188,6 +188,7 @@ static int nf_flow_tuple_ip(struct sk_buff *skb, const struct net_device *dev,
|
|||
if (!pskb_may_pull(skb, thoff + sizeof(*ports)))
|
||||
return -1;
|
||||
|
||||
iph = ip_hdr(skb);
|
||||
ports = (struct flow_ports *)(skb_network_header(skb) + thoff);
|
||||
|
||||
tuple->src_v4.s_addr = iph->saddr;
|
||||
|
|
@ -421,6 +422,7 @@ static int nf_flow_tuple_ipv6(struct sk_buff *skb, const struct net_device *dev,
|
|||
if (!pskb_may_pull(skb, thoff + sizeof(*ports)))
|
||||
return -1;
|
||||
|
||||
ip6h = ipv6_hdr(skb);
|
||||
ports = (struct flow_ports *)(skb_network_header(skb) + thoff);
|
||||
|
||||
tuple->src_v6 = ip6h->saddr;
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user