|
@@ -86,7 +86,8 @@ void iptunnel_xmit(struct sock *sk, struct rtable *rt, struct sk_buff *skb,
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(iptunnel_xmit);
|
|
|
|
|
|
-int iptunnel_pull_header(struct sk_buff *skb, int hdr_len, __be16 inner_proto)
|
|
|
+int iptunnel_pull_header(struct sk_buff *skb, int hdr_len, __be16 inner_proto,
|
|
|
+ bool xnet)
|
|
|
{
|
|
|
if (unlikely(!pskb_may_pull(skb, hdr_len)))
|
|
|
return -ENOMEM;
|
|
@@ -109,13 +110,10 @@ int iptunnel_pull_header(struct sk_buff *skb, int hdr_len, __be16 inner_proto)
|
|
|
skb->protocol = inner_proto;
|
|
|
}
|
|
|
|
|
|
- nf_reset(skb);
|
|
|
- secpath_reset(skb);
|
|
|
skb_clear_hash_if_not_l4(skb);
|
|
|
- skb_dst_drop(skb);
|
|
|
skb->vlan_tci = 0;
|
|
|
skb_set_queue_mapping(skb, 0);
|
|
|
- skb->pkt_type = PACKET_HOST;
|
|
|
+ skb_scrub_packet(skb, xnet);
|
|
|
return 0;
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(iptunnel_pull_header);
|