diff options
| -rw-r--r-- | net/bridge/br_netfilter.c | 13 | 
1 files changed, 9 insertions, 4 deletions
| diff --git a/net/bridge/br_netfilter.c b/net/bridge/br_netfilter.c index 223f8270daee..7cac3fb9f809 100644 --- a/net/bridge/br_netfilter.c +++ b/net/bridge/br_netfilter.c @@ -394,8 +394,9 @@ inhdr_error:   * target in particular.  Save the original destination IP   * address to be able to detect DNAT afterwards. */  static unsigned int br_nf_pre_routing(unsigned int hook, struct sk_buff **pskb, -   const struct net_device *in, const struct net_device *out, -   int (*okfn)(struct sk_buff *)) +				      const struct net_device *in, +				      const struct net_device *out, +				      int (*okfn)(struct sk_buff *))  {  	struct iphdr *iph;  	__u32 len; @@ -412,8 +413,10 @@ static unsigned int br_nf_pre_routing(unsigned int hook, struct sk_buff **pskb,  			goto out;  		if (skb->protocol == __constant_htons(ETH_P_8021Q)) { +			u8 *vhdr = skb->data;  			skb_pull(skb, VLAN_HLEN); -			(skb)->nh.raw += VLAN_HLEN; +			skb_postpull_rcsum(skb, vhdr, VLAN_HLEN); +			skb->nh.raw += VLAN_HLEN;  		}  		return br_nf_pre_routing_ipv6(hook, skb, in, out, okfn);  	} @@ -429,8 +432,10 @@ static unsigned int br_nf_pre_routing(unsigned int hook, struct sk_buff **pskb,  		goto out;  	if (skb->protocol == __constant_htons(ETH_P_8021Q)) { +		u8 *vhdr = skb->data;  		skb_pull(skb, VLAN_HLEN); -		(skb)->nh.raw += VLAN_HLEN; +		skb_postpull_rcsum(skb, vhdr, VLAN_HLEN); +		skb->nh.raw += VLAN_HLEN;  	}  	if (!pskb_may_pull(skb, sizeof(struct iphdr))) | 
