diff options
-rw-r--r-- | MAINTAINERS | 2 | ||||
-rw-r--r-- | drivers/net/ethernet/intel/e1000e/netdev.c | 11 | ||||
-rw-r--r-- | drivers/net/ethernet/intel/igb/e1000_phy.c | 20 | ||||
-rw-r--r-- | drivers/net/ethernet/intel/igb/igb_main.c | 2 | ||||
-rw-r--r-- | drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c | 59 |
5 files changed, 64 insertions, 30 deletions
diff --git a/MAINTAINERS b/MAINTAINERS index 41c53491db60..5655bcc1964c 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
@@ -3869,7 +3869,9 @@ M: Greg Rose <gregory.v.rose@intel.com> | |||
3869 | M: Peter P Waskiewicz Jr <peter.p.waskiewicz.jr@intel.com> | 3869 | M: Peter P Waskiewicz Jr <peter.p.waskiewicz.jr@intel.com> |
3870 | M: Alex Duyck <alexander.h.duyck@intel.com> | 3870 | M: Alex Duyck <alexander.h.duyck@intel.com> |
3871 | M: John Ronciak <john.ronciak@intel.com> | 3871 | M: John Ronciak <john.ronciak@intel.com> |
3872 | M: Tushar Dave <tushar.n.dave@intel.com> | ||
3872 | L: e1000-devel@lists.sourceforge.net | 3873 | L: e1000-devel@lists.sourceforge.net |
3874 | W: http://www.intel.com/support/feedback.htm | ||
3873 | W: http://e1000.sourceforge.net/ | 3875 | W: http://e1000.sourceforge.net/ |
3874 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net.git | 3876 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net.git |
3875 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net-next.git | 3877 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net-next.git |
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c index f444eb0b76d8..dadb13be479a 100644 --- a/drivers/net/ethernet/intel/e1000e/netdev.c +++ b/drivers/net/ethernet/intel/e1000e/netdev.c | |||
@@ -5067,6 +5067,17 @@ static netdev_tx_t e1000_xmit_frame(struct sk_buff *skb, | |||
5067 | return NETDEV_TX_OK; | 5067 | return NETDEV_TX_OK; |
5068 | } | 5068 | } |
5069 | 5069 | ||
5070 | /* | ||
5071 | * The minimum packet size with TCTL.PSP set is 17 bytes so | ||
5072 | * pad skb in order to meet this minimum size requirement | ||
5073 | */ | ||
5074 | if (unlikely(skb->len < 17)) { | ||
5075 | if (skb_pad(skb, 17 - skb->len)) | ||
5076 | return NETDEV_TX_OK; | ||
5077 | skb->len = 17; | ||
5078 | skb_set_tail_pointer(skb, 17); | ||
5079 | } | ||
5080 | |||
5070 | mss = skb_shinfo(skb)->gso_size; | 5081 | mss = skb_shinfo(skb)->gso_size; |
5071 | if (mss) { | 5082 | if (mss) { |
5072 | u8 hdr_len; | 5083 | u8 hdr_len; |
diff --git a/drivers/net/ethernet/intel/igb/e1000_phy.c b/drivers/net/ethernet/intel/igb/e1000_phy.c index 3404bc79f4ca..c62a4c388194 100644 --- a/drivers/net/ethernet/intel/igb/e1000_phy.c +++ b/drivers/net/ethernet/intel/igb/e1000_phy.c | |||
@@ -1710,6 +1710,26 @@ s32 igb_get_cable_length_m88_gen2(struct e1000_hw *hw) | |||
1710 | 1710 | ||
1711 | switch (hw->phy.id) { | 1711 | switch (hw->phy.id) { |
1712 | case I210_I_PHY_ID: | 1712 | case I210_I_PHY_ID: |
1713 | /* Get cable length from PHY Cable Diagnostics Control Reg */ | ||
1714 | ret_val = phy->ops.read_reg(hw, (0x7 << GS40G_PAGE_SHIFT) + | ||
1715 | (I347AT4_PCDL + phy->addr), | ||
1716 | &phy_data); | ||
1717 | if (ret_val) | ||
1718 | return ret_val; | ||
1719 | |||
1720 | /* Check if the unit of cable length is meters or cm */ | ||
1721 | ret_val = phy->ops.read_reg(hw, (0x7 << GS40G_PAGE_SHIFT) + | ||
1722 | I347AT4_PCDC, &phy_data2); | ||
1723 | if (ret_val) | ||
1724 | return ret_val; | ||
1725 | |||
1726 | is_cm = !(phy_data2 & I347AT4_PCDC_CABLE_LENGTH_UNIT); | ||
1727 | |||
1728 | /* Populate the phy structure with cable length in meters */ | ||
1729 | phy->min_cable_length = phy_data / (is_cm ? 100 : 1); | ||
1730 | phy->max_cable_length = phy_data / (is_cm ? 100 : 1); | ||
1731 | phy->cable_length = phy_data / (is_cm ? 100 : 1); | ||
1732 | break; | ||
1713 | case I347AT4_E_PHY_ID: | 1733 | case I347AT4_E_PHY_ID: |
1714 | /* Remember the original page select and set it to 7 */ | 1734 | /* Remember the original page select and set it to 7 */ |
1715 | ret_val = phy->ops.read_reg(hw, I347AT4_PAGE_SELECT, | 1735 | ret_val = phy->ops.read_reg(hw, I347AT4_PAGE_SELECT, |
diff --git a/drivers/net/ethernet/intel/igb/igb_main.c b/drivers/net/ethernet/intel/igb/igb_main.c index 87abb5735852..b07d679b46f2 100644 --- a/drivers/net/ethernet/intel/igb/igb_main.c +++ b/drivers/net/ethernet/intel/igb/igb_main.c | |||
@@ -61,7 +61,7 @@ | |||
61 | 61 | ||
62 | #define MAJ 4 | 62 | #define MAJ 4 |
63 | #define MIN 0 | 63 | #define MIN 0 |
64 | #define BUILD 1 | 64 | #define BUILD 17 |
65 | #define DRV_VERSION __stringify(MAJ) "." __stringify(MIN) "." \ | 65 | #define DRV_VERSION __stringify(MAJ) "." __stringify(MIN) "." \ |
66 | __stringify(BUILD) "-k" | 66 | __stringify(BUILD) "-k" |
67 | char igb_driver_name[] = "igb"; | 67 | char igb_driver_name[] = "igb"; |
diff --git a/drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c b/drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c index 33444b5b5105..07d7eaba6f1b 100644 --- a/drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c +++ b/drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c | |||
@@ -58,7 +58,7 @@ const char ixgbevf_driver_name[] = "ixgbevf"; | |||
58 | static const char ixgbevf_driver_string[] = | 58 | static const char ixgbevf_driver_string[] = |
59 | "Intel(R) 10 Gigabit PCI Express Virtual Function Network Driver"; | 59 | "Intel(R) 10 Gigabit PCI Express Virtual Function Network Driver"; |
60 | 60 | ||
61 | #define DRV_VERSION "2.6.0-k" | 61 | #define DRV_VERSION "2.7.12-k" |
62 | const char ixgbevf_driver_version[] = DRV_VERSION; | 62 | const char ixgbevf_driver_version[] = DRV_VERSION; |
63 | static char ixgbevf_copyright[] = | 63 | static char ixgbevf_copyright[] = |
64 | "Copyright (c) 2009 - 2012 Intel Corporation."; | 64 | "Copyright (c) 2009 - 2012 Intel Corporation."; |
@@ -359,6 +359,12 @@ static void ixgbevf_alloc_rx_buffers(struct ixgbevf_adapter *adapter, | |||
359 | bi->dma = dma_map_single(&pdev->dev, skb->data, | 359 | bi->dma = dma_map_single(&pdev->dev, skb->data, |
360 | rx_ring->rx_buf_len, | 360 | rx_ring->rx_buf_len, |
361 | DMA_FROM_DEVICE); | 361 | DMA_FROM_DEVICE); |
362 | if (dma_mapping_error(&pdev->dev, bi->dma)) { | ||
363 | dev_kfree_skb(skb); | ||
364 | bi->skb = NULL; | ||
365 | dev_err(&pdev->dev, "RX DMA map failed\n"); | ||
366 | break; | ||
367 | } | ||
362 | } | 368 | } |
363 | rx_desc->read.pkt_addr = cpu_to_le64(bi->dma); | 369 | rx_desc->read.pkt_addr = cpu_to_le64(bi->dma); |
364 | 370 | ||
@@ -1132,12 +1138,12 @@ static int ixgbevf_vlan_rx_add_vid(struct net_device *netdev, u16 vid) | |||
1132 | if (!hw->mac.ops.set_vfta) | 1138 | if (!hw->mac.ops.set_vfta) |
1133 | return -EOPNOTSUPP; | 1139 | return -EOPNOTSUPP; |
1134 | 1140 | ||
1135 | spin_lock(&adapter->mbx_lock); | 1141 | spin_lock_bh(&adapter->mbx_lock); |
1136 | 1142 | ||
1137 | /* add VID to filter table */ | 1143 | /* add VID to filter table */ |
1138 | err = hw->mac.ops.set_vfta(hw, vid, 0, true); | 1144 | err = hw->mac.ops.set_vfta(hw, vid, 0, true); |
1139 | 1145 | ||
1140 | spin_unlock(&adapter->mbx_lock); | 1146 | spin_unlock_bh(&adapter->mbx_lock); |
1141 | 1147 | ||
1142 | /* translate error return types so error makes sense */ | 1148 | /* translate error return types so error makes sense */ |
1143 | if (err == IXGBE_ERR_MBX) | 1149 | if (err == IXGBE_ERR_MBX) |
@@ -1157,13 +1163,13 @@ static int ixgbevf_vlan_rx_kill_vid(struct net_device *netdev, u16 vid) | |||
1157 | struct ixgbe_hw *hw = &adapter->hw; | 1163 | struct ixgbe_hw *hw = &adapter->hw; |
1158 | int err = -EOPNOTSUPP; | 1164 | int err = -EOPNOTSUPP; |
1159 | 1165 | ||
1160 | spin_lock(&adapter->mbx_lock); | 1166 | spin_lock_bh(&adapter->mbx_lock); |
1161 | 1167 | ||
1162 | /* remove VID from filter table */ | 1168 | /* remove VID from filter table */ |
1163 | if (hw->mac.ops.set_vfta) | 1169 | if (hw->mac.ops.set_vfta) |
1164 | err = hw->mac.ops.set_vfta(hw, vid, 0, false); | 1170 | err = hw->mac.ops.set_vfta(hw, vid, 0, false); |
1165 | 1171 | ||
1166 | spin_unlock(&adapter->mbx_lock); | 1172 | spin_unlock_bh(&adapter->mbx_lock); |
1167 | 1173 | ||
1168 | clear_bit(vid, adapter->active_vlans); | 1174 | clear_bit(vid, adapter->active_vlans); |
1169 | 1175 | ||
@@ -1219,7 +1225,7 @@ static void ixgbevf_set_rx_mode(struct net_device *netdev) | |||
1219 | struct ixgbevf_adapter *adapter = netdev_priv(netdev); | 1225 | struct ixgbevf_adapter *adapter = netdev_priv(netdev); |
1220 | struct ixgbe_hw *hw = &adapter->hw; | 1226 | struct ixgbe_hw *hw = &adapter->hw; |
1221 | 1227 | ||
1222 | spin_lock(&adapter->mbx_lock); | 1228 | spin_lock_bh(&adapter->mbx_lock); |
1223 | 1229 | ||
1224 | /* reprogram multicast list */ | 1230 | /* reprogram multicast list */ |
1225 | if (hw->mac.ops.update_mc_addr_list) | 1231 | if (hw->mac.ops.update_mc_addr_list) |
@@ -1227,7 +1233,7 @@ static void ixgbevf_set_rx_mode(struct net_device *netdev) | |||
1227 | 1233 | ||
1228 | ixgbevf_write_uc_addr_list(netdev); | 1234 | ixgbevf_write_uc_addr_list(netdev); |
1229 | 1235 | ||
1230 | spin_unlock(&adapter->mbx_lock); | 1236 | spin_unlock_bh(&adapter->mbx_lock); |
1231 | } | 1237 | } |
1232 | 1238 | ||
1233 | static void ixgbevf_napi_enable_all(struct ixgbevf_adapter *adapter) | 1239 | static void ixgbevf_napi_enable_all(struct ixgbevf_adapter *adapter) |
@@ -1341,7 +1347,7 @@ static void ixgbevf_negotiate_api(struct ixgbevf_adapter *adapter) | |||
1341 | ixgbe_mbox_api_unknown }; | 1347 | ixgbe_mbox_api_unknown }; |
1342 | int err = 0, idx = 0; | 1348 | int err = 0, idx = 0; |
1343 | 1349 | ||
1344 | spin_lock(&adapter->mbx_lock); | 1350 | spin_lock_bh(&adapter->mbx_lock); |
1345 | 1351 | ||
1346 | while (api[idx] != ixgbe_mbox_api_unknown) { | 1352 | while (api[idx] != ixgbe_mbox_api_unknown) { |
1347 | err = ixgbevf_negotiate_api_version(hw, api[idx]); | 1353 | err = ixgbevf_negotiate_api_version(hw, api[idx]); |
@@ -1350,7 +1356,7 @@ static void ixgbevf_negotiate_api(struct ixgbevf_adapter *adapter) | |||
1350 | idx++; | 1356 | idx++; |
1351 | } | 1357 | } |
1352 | 1358 | ||
1353 | spin_unlock(&adapter->mbx_lock); | 1359 | spin_unlock_bh(&adapter->mbx_lock); |
1354 | } | 1360 | } |
1355 | 1361 | ||
1356 | static void ixgbevf_up_complete(struct ixgbevf_adapter *adapter) | 1362 | static void ixgbevf_up_complete(struct ixgbevf_adapter *adapter) |
@@ -1391,7 +1397,7 @@ static void ixgbevf_up_complete(struct ixgbevf_adapter *adapter) | |||
1391 | 1397 | ||
1392 | ixgbevf_configure_msix(adapter); | 1398 | ixgbevf_configure_msix(adapter); |
1393 | 1399 | ||
1394 | spin_lock(&adapter->mbx_lock); | 1400 | spin_lock_bh(&adapter->mbx_lock); |
1395 | 1401 | ||
1396 | if (hw->mac.ops.set_rar) { | 1402 | if (hw->mac.ops.set_rar) { |
1397 | if (is_valid_ether_addr(hw->mac.addr)) | 1403 | if (is_valid_ether_addr(hw->mac.addr)) |
@@ -1400,7 +1406,7 @@ static void ixgbevf_up_complete(struct ixgbevf_adapter *adapter) | |||
1400 | hw->mac.ops.set_rar(hw, 0, hw->mac.perm_addr, 0); | 1406 | hw->mac.ops.set_rar(hw, 0, hw->mac.perm_addr, 0); |
1401 | } | 1407 | } |
1402 | 1408 | ||
1403 | spin_unlock(&adapter->mbx_lock); | 1409 | spin_unlock_bh(&adapter->mbx_lock); |
1404 | 1410 | ||
1405 | clear_bit(__IXGBEVF_DOWN, &adapter->state); | 1411 | clear_bit(__IXGBEVF_DOWN, &adapter->state); |
1406 | ixgbevf_napi_enable_all(adapter); | 1412 | ixgbevf_napi_enable_all(adapter); |
@@ -1424,12 +1430,12 @@ static int ixgbevf_reset_queues(struct ixgbevf_adapter *adapter) | |||
1424 | unsigned int num_rx_queues = 1; | 1430 | unsigned int num_rx_queues = 1; |
1425 | int err, i; | 1431 | int err, i; |
1426 | 1432 | ||
1427 | spin_lock(&adapter->mbx_lock); | 1433 | spin_lock_bh(&adapter->mbx_lock); |
1428 | 1434 | ||
1429 | /* fetch queue configuration from the PF */ | 1435 | /* fetch queue configuration from the PF */ |
1430 | err = ixgbevf_get_queues(hw, &num_tcs, &def_q); | 1436 | err = ixgbevf_get_queues(hw, &num_tcs, &def_q); |
1431 | 1437 | ||
1432 | spin_unlock(&adapter->mbx_lock); | 1438 | spin_unlock_bh(&adapter->mbx_lock); |
1433 | 1439 | ||
1434 | if (err) | 1440 | if (err) |
1435 | return err; | 1441 | return err; |
@@ -1688,14 +1694,14 @@ void ixgbevf_reset(struct ixgbevf_adapter *adapter) | |||
1688 | struct ixgbe_hw *hw = &adapter->hw; | 1694 | struct ixgbe_hw *hw = &adapter->hw; |
1689 | struct net_device *netdev = adapter->netdev; | 1695 | struct net_device *netdev = adapter->netdev; |
1690 | 1696 | ||
1691 | spin_lock(&adapter->mbx_lock); | 1697 | spin_lock_bh(&adapter->mbx_lock); |
1692 | 1698 | ||
1693 | if (hw->mac.ops.reset_hw(hw)) | 1699 | if (hw->mac.ops.reset_hw(hw)) |
1694 | hw_dbg(hw, "PF still resetting\n"); | 1700 | hw_dbg(hw, "PF still resetting\n"); |
1695 | else | 1701 | else |
1696 | hw->mac.ops.init_hw(hw); | 1702 | hw->mac.ops.init_hw(hw); |
1697 | 1703 | ||
1698 | spin_unlock(&adapter->mbx_lock); | 1704 | spin_unlock_bh(&adapter->mbx_lock); |
1699 | 1705 | ||
1700 | if (is_valid_ether_addr(adapter->hw.mac.addr)) { | 1706 | if (is_valid_ether_addr(adapter->hw.mac.addr)) { |
1701 | memcpy(netdev->dev_addr, adapter->hw.mac.addr, | 1707 | memcpy(netdev->dev_addr, adapter->hw.mac.addr, |
@@ -1912,18 +1918,13 @@ err_out: | |||
1912 | **/ | 1918 | **/ |
1913 | static void ixgbevf_free_q_vectors(struct ixgbevf_adapter *adapter) | 1919 | static void ixgbevf_free_q_vectors(struct ixgbevf_adapter *adapter) |
1914 | { | 1920 | { |
1915 | int q_idx, num_q_vectors; | 1921 | int q_idx, num_q_vectors = adapter->num_msix_vectors - NON_Q_VECTORS; |
1916 | int napi_vectors; | ||
1917 | |||
1918 | num_q_vectors = adapter->num_msix_vectors - NON_Q_VECTORS; | ||
1919 | napi_vectors = adapter->num_rx_queues; | ||
1920 | 1922 | ||
1921 | for (q_idx = 0; q_idx < num_q_vectors; q_idx++) { | 1923 | for (q_idx = 0; q_idx < num_q_vectors; q_idx++) { |
1922 | struct ixgbevf_q_vector *q_vector = adapter->q_vector[q_idx]; | 1924 | struct ixgbevf_q_vector *q_vector = adapter->q_vector[q_idx]; |
1923 | 1925 | ||
1924 | adapter->q_vector[q_idx] = NULL; | 1926 | adapter->q_vector[q_idx] = NULL; |
1925 | if (q_idx < napi_vectors) | 1927 | netif_napi_del(&q_vector->napi); |
1926 | netif_napi_del(&q_vector->napi); | ||
1927 | kfree(q_vector); | 1928 | kfree(q_vector); |
1928 | } | 1929 | } |
1929 | } | 1930 | } |
@@ -2194,12 +2195,12 @@ static void ixgbevf_watchdog_task(struct work_struct *work) | |||
2194 | if (hw->mac.ops.check_link) { | 2195 | if (hw->mac.ops.check_link) { |
2195 | s32 need_reset; | 2196 | s32 need_reset; |
2196 | 2197 | ||
2197 | spin_lock(&adapter->mbx_lock); | 2198 | spin_lock_bh(&adapter->mbx_lock); |
2198 | 2199 | ||
2199 | need_reset = hw->mac.ops.check_link(hw, &link_speed, | 2200 | need_reset = hw->mac.ops.check_link(hw, &link_speed, |
2200 | &link_up, false); | 2201 | &link_up, false); |
2201 | 2202 | ||
2202 | spin_unlock(&adapter->mbx_lock); | 2203 | spin_unlock_bh(&adapter->mbx_lock); |
2203 | 2204 | ||
2204 | if (need_reset) { | 2205 | if (need_reset) { |
2205 | adapter->link_up = link_up; | 2206 | adapter->link_up = link_up; |
@@ -2467,12 +2468,12 @@ static int ixgbevf_setup_queues(struct ixgbevf_adapter *adapter) | |||
2467 | unsigned int num_rx_queues = 1; | 2468 | unsigned int num_rx_queues = 1; |
2468 | int err, i; | 2469 | int err, i; |
2469 | 2470 | ||
2470 | spin_lock(&adapter->mbx_lock); | 2471 | spin_lock_bh(&adapter->mbx_lock); |
2471 | 2472 | ||
2472 | /* fetch queue configuration from the PF */ | 2473 | /* fetch queue configuration from the PF */ |
2473 | err = ixgbevf_get_queues(hw, &num_tcs, &def_q); | 2474 | err = ixgbevf_get_queues(hw, &num_tcs, &def_q); |
2474 | 2475 | ||
2475 | spin_unlock(&adapter->mbx_lock); | 2476 | spin_unlock_bh(&adapter->mbx_lock); |
2476 | 2477 | ||
2477 | if (err) | 2478 | if (err) |
2478 | return err; | 2479 | return err; |
@@ -2822,10 +2823,10 @@ static int ixgbevf_tx_map(struct ixgbevf_ring *tx_ring, | |||
2822 | tx_buffer_info->dma = | 2823 | tx_buffer_info->dma = |
2823 | skb_frag_dma_map(tx_ring->dev, frag, | 2824 | skb_frag_dma_map(tx_ring->dev, frag, |
2824 | offset, size, DMA_TO_DEVICE); | 2825 | offset, size, DMA_TO_DEVICE); |
2825 | tx_buffer_info->mapped_as_page = true; | ||
2826 | if (dma_mapping_error(tx_ring->dev, | 2826 | if (dma_mapping_error(tx_ring->dev, |
2827 | tx_buffer_info->dma)) | 2827 | tx_buffer_info->dma)) |
2828 | goto dma_error; | 2828 | goto dma_error; |
2829 | tx_buffer_info->mapped_as_page = true; | ||
2829 | tx_buffer_info->next_to_watch = i; | 2830 | tx_buffer_info->next_to_watch = i; |
2830 | 2831 | ||
2831 | len -= size; | 2832 | len -= size; |
@@ -3046,12 +3047,12 @@ static int ixgbevf_set_mac(struct net_device *netdev, void *p) | |||
3046 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); | 3047 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); |
3047 | memcpy(hw->mac.addr, addr->sa_data, netdev->addr_len); | 3048 | memcpy(hw->mac.addr, addr->sa_data, netdev->addr_len); |
3048 | 3049 | ||
3049 | spin_lock(&adapter->mbx_lock); | 3050 | spin_lock_bh(&adapter->mbx_lock); |
3050 | 3051 | ||
3051 | if (hw->mac.ops.set_rar) | 3052 | if (hw->mac.ops.set_rar) |
3052 | hw->mac.ops.set_rar(hw, 0, hw->mac.addr, 0); | 3053 | hw->mac.ops.set_rar(hw, 0, hw->mac.addr, 0); |
3053 | 3054 | ||
3054 | spin_unlock(&adapter->mbx_lock); | 3055 | spin_unlock_bh(&adapter->mbx_lock); |
3055 | 3056 | ||
3056 | return 0; | 3057 | return 0; |
3057 | } | 3058 | } |