|
@@ -565,6 +565,7 @@ static struct sk_buff **vxlan_gro_receive(struct sk_buff **head, struct sk_buff
|
|
goto out;
|
|
goto out;
|
|
}
|
|
}
|
|
skb_gro_pull(skb, sizeof(struct vxlanhdr)); /* pull vxlan header */
|
|
skb_gro_pull(skb, sizeof(struct vxlanhdr)); /* pull vxlan header */
|
|
|
|
+ skb_gro_postpull_rcsum(skb, vh, sizeof(struct vxlanhdr));
|
|
|
|
|
|
off_eth = skb_gro_offset(skb);
|
|
off_eth = skb_gro_offset(skb);
|
|
hlen = off_eth + sizeof(*eh);
|
|
hlen = off_eth + sizeof(*eh);
|
|
@@ -599,6 +600,7 @@ static struct sk_buff **vxlan_gro_receive(struct sk_buff **head, struct sk_buff
|
|
}
|
|
}
|
|
|
|
|
|
skb_gro_pull(skb, sizeof(*eh)); /* pull inner eth header */
|
|
skb_gro_pull(skb, sizeof(*eh)); /* pull inner eth header */
|
|
|
|
+ skb_gro_postpull_rcsum(skb, eh, sizeof(*eh));
|
|
pp = ptype->callbacks.gro_receive(head, skb);
|
|
pp = ptype->callbacks.gro_receive(head, skb);
|
|
|
|
|
|
out_unlock:
|
|
out_unlock:
|