diff options
| author | Jiri Kosina <jkosina@suse.cz> | 2011-09-15 15:08:05 +0200 | 
|---|---|---|
| committer | Jiri Kosina <jkosina@suse.cz> | 2011-09-15 15:08:18 +0200 | 
| commit | e060c38434b2caa78efe7cedaff4191040b65a15 (patch) | |
| tree | 407361230bf6733f63d8e788e4b5e6566ee04818 /drivers/net/gianfar.c | |
| parent | 10e4ac572eeffe5317019bd7330b6058a400dfc2 (diff) | |
| parent | cc39c6a9bbdebfcf1a7dee64d83bf302bc38d941 (diff) | |
| download | olio-linux-3.10-e060c38434b2caa78efe7cedaff4191040b65a15.tar.xz olio-linux-3.10-e060c38434b2caa78efe7cedaff4191040b65a15.zip  | |
Merge branch 'master' into for-next
Fast-forward merge with Linus to be able to merge patches
based on more recent version of the tree.
Diffstat (limited to 'drivers/net/gianfar.c')
| -rw-r--r-- | drivers/net/gianfar.c | 15 | 
1 files changed, 8 insertions, 7 deletions
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 835cd258814..31d5c574e5a 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c @@ -388,12 +388,8 @@ static void gfar_init_mac(struct net_device *ndev)  	if (priv->hwts_rx_en)  		rctrl |= RCTRL_PRSDEP_INIT | RCTRL_TS_ENABLE; -	/* keep vlan related bits if it's enabled */ -	if (ndev->features & NETIF_F_HW_VLAN_TX) -		rctrl |= RCTRL_VLEX | RCTRL_PRSDEP_INIT; -  	if (ndev->features & NETIF_F_HW_VLAN_RX) -		tctrl |= TCTRL_VLINS; +		rctrl |= RCTRL_VLEX | RCTRL_PRSDEP_INIT;  	/* Init rctrl based on our settings */  	gfar_write(®s->rctrl, rctrl); @@ -2714,8 +2710,13 @@ static int gfar_process_frame(struct net_device *dev, struct sk_buff *skb,  	/* Tell the skb what kind of packet this is */  	skb->protocol = eth_type_trans(skb, dev); -	/* Set vlan tag */ -	if (fcb->flags & RXFCB_VLN) +	/* +	 * There's need to check for NETIF_F_HW_VLAN_RX here. +	 * Even if vlan rx accel is disabled, on some chips +	 * RXFCB_VLN is pseudo randomly set. +	 */ +	if (dev->features & NETIF_F_HW_VLAN_RX && +	    fcb->flags & RXFCB_VLN)  		__vlan_hwaccel_put_tag(skb, fcb->vlctl);  	/* Send the packet up the stack */  |