diff options
Diffstat (limited to 'drivers/net/ipvlan/ipvlan_core.c')
| -rw-r--r-- | drivers/net/ipvlan/ipvlan_core.c | 19 | 
1 files changed, 11 insertions, 8 deletions
| diff --git a/drivers/net/ipvlan/ipvlan_core.c b/drivers/net/ipvlan/ipvlan_core.c index 30cd0c4f0be0..8801d093135c 100644 --- a/drivers/net/ipvlan/ipvlan_core.c +++ b/drivers/net/ipvlan/ipvlan_core.c @@ -293,6 +293,7 @@ void ipvlan_process_multicast(struct work_struct *work)  		}  		if (dev)  			dev_put(dev); +		cond_resched();  	}  } @@ -498,19 +499,21 @@ static int ipvlan_process_outbound(struct sk_buff *skb)  	struct ethhdr *ethh = eth_hdr(skb);  	int ret = NET_XMIT_DROP; -	/* In this mode we dont care about multicast and broadcast traffic */ -	if (is_multicast_ether_addr(ethh->h_dest)) { -		pr_debug_ratelimited("Dropped {multi|broad}cast of type=[%x]\n", -				     ntohs(skb->protocol)); -		kfree_skb(skb); -		goto out; -	} -  	/* The ipvlan is a pseudo-L2 device, so the packets that we receive  	 * will have L2; which need to discarded and processed further  	 * in the net-ns of the main-device.  	 */  	if (skb_mac_header_was_set(skb)) { +		/* In this mode we dont care about +		 * multicast and broadcast traffic */ +		if (is_multicast_ether_addr(ethh->h_dest)) { +			pr_debug_ratelimited( +				"Dropped {multi|broad}cast of type=[%x]\n", +				ntohs(skb->protocol)); +			kfree_skb(skb); +			goto out; +		} +  		skb_pull(skb, sizeof(*ethh));  		skb->mac_header = (typeof(skb->mac_header))~0U;  		skb_reset_network_header(skb); | 
