aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ixgb/ixgb_main.c
diff options
context:
space:
mode:
authorEmil Tantilov <emil.s.tantilov@intel.com>2011-01-27 04:14:18 -0500
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>2011-03-11 04:16:23 -0500
commite2444d92083cc1ceb07487425897d6d51a13e9dd (patch)
tree0ef862edfb70906a0bedafd599943645303c3692 /drivers/net/ixgb/ixgb_main.c
parent1b7fe59322bef9e7a2c05b64a07a66b875299736 (diff)
ixgb: convert to new VLAN model
Based on a patch from Jesse Gross <jesse@nicira.com> This switches the ixgb driver to use the new VLAN interfaces. In doing this, it completes the work begun in ae54496f9e8d40c89e5668205c181dccfa9ecda1 allowing the use of hardware VLAN insertion without having a VLAN group configured. CC: Jesse Gross <jesse@nicira.com> Signed-off-by: Emil Tantilov <emil.s.tantilov@intel.com> Tested-by: Jeff Pieper <jeffrey.e.pieper@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'drivers/net/ixgb/ixgb_main.c')
-rw-r--r--drivers/net/ixgb/ixgb_main.c54
1 files changed, 12 insertions, 42 deletions
diff --git a/drivers/net/ixgb/ixgb_main.c b/drivers/net/ixgb/ixgb_main.c
index 5639cccb4935..0f681ac2da8d 100644
--- a/drivers/net/ixgb/ixgb_main.c
+++ b/drivers/net/ixgb/ixgb_main.c
@@ -100,8 +100,6 @@ static void ixgb_tx_timeout_task(struct work_struct *work);
100 100
101static void ixgb_vlan_strip_enable(struct ixgb_adapter *adapter); 101static void ixgb_vlan_strip_enable(struct ixgb_adapter *adapter);
102static void ixgb_vlan_strip_disable(struct ixgb_adapter *adapter); 102static void ixgb_vlan_strip_disable(struct ixgb_adapter *adapter);
103static void ixgb_vlan_rx_register(struct net_device *netdev,
104 struct vlan_group *grp);
105static void ixgb_vlan_rx_add_vid(struct net_device *netdev, u16 vid); 103static void ixgb_vlan_rx_add_vid(struct net_device *netdev, u16 vid);
106static void ixgb_vlan_rx_kill_vid(struct net_device *netdev, u16 vid); 104static void ixgb_vlan_rx_kill_vid(struct net_device *netdev, u16 vid);
107static void ixgb_restore_vlan(struct ixgb_adapter *adapter); 105static void ixgb_restore_vlan(struct ixgb_adapter *adapter);
@@ -336,7 +334,6 @@ static const struct net_device_ops ixgb_netdev_ops = {
336 .ndo_set_mac_address = ixgb_set_mac, 334 .ndo_set_mac_address = ixgb_set_mac,
337 .ndo_change_mtu = ixgb_change_mtu, 335 .ndo_change_mtu = ixgb_change_mtu,
338 .ndo_tx_timeout = ixgb_tx_timeout, 336 .ndo_tx_timeout = ixgb_tx_timeout,
339 .ndo_vlan_rx_register = ixgb_vlan_rx_register,
340 .ndo_vlan_rx_add_vid = ixgb_vlan_rx_add_vid, 337 .ndo_vlan_rx_add_vid = ixgb_vlan_rx_add_vid,
341 .ndo_vlan_rx_kill_vid = ixgb_vlan_rx_kill_vid, 338 .ndo_vlan_rx_kill_vid = ixgb_vlan_rx_kill_vid,
342#ifdef CONFIG_NET_POLL_CONTROLLER 339#ifdef CONFIG_NET_POLL_CONTROLLER
@@ -1508,7 +1505,7 @@ ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
1508 DESC_NEEDED))) 1505 DESC_NEEDED)))
1509 return NETDEV_TX_BUSY; 1506 return NETDEV_TX_BUSY;
1510 1507
1511 if (adapter->vlgrp && vlan_tx_tag_present(skb)) { 1508 if (vlan_tx_tag_present(skb)) {
1512 tx_flags |= IXGB_TX_FLAGS_VLAN; 1509 tx_flags |= IXGB_TX_FLAGS_VLAN;
1513 vlan_id = vlan_tx_tag_get(skb); 1510 vlan_id = vlan_tx_tag_get(skb);
1514 } 1511 }
@@ -2049,12 +2046,11 @@ ixgb_clean_rx_irq(struct ixgb_adapter *adapter, int *work_done, int work_to_do)
2049 ixgb_rx_checksum(adapter, rx_desc, skb); 2046 ixgb_rx_checksum(adapter, rx_desc, skb);
2050 2047
2051 skb->protocol = eth_type_trans(skb, netdev); 2048 skb->protocol = eth_type_trans(skb, netdev);
2052 if (adapter->vlgrp && (status & IXGB_RX_DESC_STATUS_VP)) { 2049 if (status & IXGB_RX_DESC_STATUS_VP)
2053 vlan_hwaccel_receive_skb(skb, adapter->vlgrp, 2050 __vlan_hwaccel_put_tag(skb,
2054 le16_to_cpu(rx_desc->special)); 2051 le16_to_cpu(rx_desc->special));
2055 } else { 2052
2056 netif_receive_skb(skb); 2053 netif_receive_skb(skb);
2057 }
2058 2054
2059rxdesc_done: 2055rxdesc_done:
2060 /* clean up descriptor, might be written over by hw */ 2056 /* clean up descriptor, might be written over by hw */
@@ -2152,20 +2148,6 @@ map_skb:
2152 } 2148 }
2153} 2149}
2154 2150
2155/**
2156 * ixgb_vlan_rx_register - enables or disables vlan tagging/stripping.
2157 *
2158 * @param netdev network interface device structure
2159 * @param grp indicates to enable or disable tagging/stripping
2160 **/
2161static void
2162ixgb_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
2163{
2164 struct ixgb_adapter *adapter = netdev_priv(netdev);
2165
2166 adapter->vlgrp = grp;
2167}
2168
2169static void 2151static void
2170ixgb_vlan_strip_enable(struct ixgb_adapter *adapter) 2152ixgb_vlan_strip_enable(struct ixgb_adapter *adapter)
2171{ 2153{
@@ -2200,6 +2182,7 @@ ixgb_vlan_rx_add_vid(struct net_device *netdev, u16 vid)
2200 vfta = IXGB_READ_REG_ARRAY(&adapter->hw, VFTA, index); 2182 vfta = IXGB_READ_REG_ARRAY(&adapter->hw, VFTA, index);
2201 vfta |= (1 << (vid & 0x1F)); 2183 vfta |= (1 << (vid & 0x1F));
2202 ixgb_write_vfta(&adapter->hw, index, vfta); 2184 ixgb_write_vfta(&adapter->hw, index, vfta);
2185 set_bit(vid, adapter->active_vlans);
2203} 2186}
2204 2187
2205static void 2188static void
@@ -2208,35 +2191,22 @@ ixgb_vlan_rx_kill_vid(struct net_device *netdev, u16 vid)
2208 struct ixgb_adapter *adapter = netdev_priv(netdev); 2191 struct ixgb_adapter *adapter = netdev_priv(netdev);
2209 u32 vfta, index; 2192 u32 vfta, index;
2210 2193
2211 ixgb_irq_disable(adapter);
2212
2213 vlan_group_set_device(adapter->vlgrp, vid, NULL);
2214
2215 /* don't enable interrupts unless we are UP */
2216 if (adapter->netdev->flags & IFF_UP)
2217 ixgb_irq_enable(adapter);
2218
2219 /* remove VID from filter table */ 2194 /* remove VID from filter table */
2220 2195
2221 index = (vid >> 5) & 0x7F; 2196 index = (vid >> 5) & 0x7F;
2222 vfta = IXGB_READ_REG_ARRAY(&adapter->hw, VFTA, index); 2197 vfta = IXGB_READ_REG_ARRAY(&adapter->hw, VFTA, index);
2223 vfta &= ~(1 << (vid & 0x1F)); 2198 vfta &= ~(1 << (vid & 0x1F));
2224 ixgb_write_vfta(&adapter->hw, index, vfta); 2199 ixgb_write_vfta(&adapter->hw, index, vfta);
2200 clear_bit(vid, adapter->active_vlans);
2225} 2201}
2226 2202
2227static void 2203static void
2228ixgb_restore_vlan(struct ixgb_adapter *adapter) 2204ixgb_restore_vlan(struct ixgb_adapter *adapter)
2229{ 2205{
2230 ixgb_vlan_rx_register(adapter->netdev, adapter->vlgrp); 2206 u16 vid;
2231 2207
2232 if (adapter->vlgrp) { 2208 for_each_set_bit(vid, adapter->active_vlans, VLAN_N_VID)
2233 u16 vid; 2209 ixgb_vlan_rx_add_vid(adapter->netdev, vid);
2234 for (vid = 0; vid < VLAN_N_VID; vid++) {
2235 if (!vlan_group_get_device(adapter->vlgrp, vid))
2236 continue;
2237 ixgb_vlan_rx_add_vid(adapter->netdev, vid);
2238 }
2239 }
2240} 2210}
2241 2211
2242#ifdef CONFIG_NET_POLL_CONTROLLER 2212#ifdef CONFIG_NET_POLL_CONTROLLER