|
@@ -3500,17 +3500,22 @@ bool skb_try_coalesce(struct sk_buff *to, struct sk_buff *from,
|
|
|
EXPORT_SYMBOL(skb_try_coalesce);
|
|
|
|
|
|
/**
|
|
|
- * skb_scrub_packet - scrub an skb before sending it to another netns
|
|
|
+ * skb_scrub_packet - scrub an skb
|
|
|
*
|
|
|
* @skb: buffer to clean
|
|
|
- *
|
|
|
- * skb_scrub_packet can be used to clean an skb before injecting it in
|
|
|
- * another namespace. We have to clear all information in the skb that
|
|
|
- * could impact namespace isolation.
|
|
|
+ * @xnet: packet is crossing netns
|
|
|
+ *
|
|
|
+ * skb_scrub_packet can be used after encapsulating or decapsulting a packet
|
|
|
+ * into/from a tunnel. Some information have to be cleared during these
|
|
|
+ * operations.
|
|
|
+ * skb_scrub_packet can also be used to clean a skb before injecting it in
|
|
|
+ * another namespace (@xnet == true). We have to clear all information in the
|
|
|
+ * skb that could impact namespace isolation.
|
|
|
*/
|
|
|
-void skb_scrub_packet(struct sk_buff *skb)
|
|
|
+void skb_scrub_packet(struct sk_buff *skb, bool xnet)
|
|
|
{
|
|
|
- skb_orphan(skb);
|
|
|
+ if (xnet)
|
|
|
+ skb_orphan(skb);
|
|
|
skb->tstamp.tv64 = 0;
|
|
|
skb->pkt_type = PACKET_HOST;
|
|
|
skb->skb_iif = 0;
|