aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/ixgbe/ixgbe.h4
-rw-r--r--drivers/net/ixgbe/ixgbe_ethtool.c24
-rw-r--r--drivers/net/ixgbe/ixgbe_main.c121
-rw-r--r--drivers/net/ixgbe/ixgbe_type.h15
4 files changed, 152 insertions, 12 deletions
diff --git a/drivers/net/ixgbe/ixgbe.h b/drivers/net/ixgbe/ixgbe.h
index c26433d14605..4b44a8efac8c 100644
--- a/drivers/net/ixgbe/ixgbe.h
+++ b/drivers/net/ixgbe/ixgbe.h
@@ -147,6 +147,7 @@ struct ixgbe_ring {
147 147
148 u16 work_limit; /* max work per interrupt */ 148 u16 work_limit; /* max work per interrupt */
149 u16 rx_buf_len; 149 u16 rx_buf_len;
150 u64 rsc_count; /* stat for coalesced packets */
150}; 151};
151 152
152enum ixgbe_ring_f_enum { 153enum ixgbe_ring_f_enum {
@@ -294,6 +295,8 @@ struct ixgbe_adapter {
294#define IXGBE_FLAG_IN_WATCHDOG_TASK (u32)(1 << 23) 295#define IXGBE_FLAG_IN_WATCHDOG_TASK (u32)(1 << 23)
295#define IXGBE_FLAG_IN_SFP_LINK_TASK (u32)(1 << 24) 296#define IXGBE_FLAG_IN_SFP_LINK_TASK (u32)(1 << 24)
296#define IXGBE_FLAG_IN_SFP_MOD_TASK (u32)(1 << 25) 297#define IXGBE_FLAG_IN_SFP_MOD_TASK (u32)(1 << 25)
298#define IXGBE_FLAG_RSC_CAPABLE (u32)(1 << 26)
299#define IXGBE_FLAG_RSC_ENABLED (u32)(1 << 27)
297 300
298/* default to trying for four seconds */ 301/* default to trying for four seconds */
299#define IXGBE_TRY_LINK_TIMEOUT (4 * HZ) 302#define IXGBE_TRY_LINK_TIMEOUT (4 * HZ)
@@ -325,6 +328,7 @@ struct ixgbe_adapter {
325 struct timer_list sfp_timer; 328 struct timer_list sfp_timer;
326 struct work_struct multispeed_fiber_task; 329 struct work_struct multispeed_fiber_task;
327 struct work_struct sfp_config_module_task; 330 struct work_struct sfp_config_module_task;
331 u64 rsc_count;
328 u32 wol; 332 u32 wol;
329 u16 eeprom_version; 333 u16 eeprom_version;
330}; 334};
diff --git a/drivers/net/ixgbe/ixgbe_ethtool.c b/drivers/net/ixgbe/ixgbe_ethtool.c
index a499b6b31ca2..d822c92058c3 100644
--- a/drivers/net/ixgbe/ixgbe_ethtool.c
+++ b/drivers/net/ixgbe/ixgbe_ethtool.c
@@ -67,6 +67,7 @@ static struct ixgbe_stats ixgbe_gstrings_stats[] = {
67 {"rx_over_errors", IXGBE_STAT(net_stats.rx_over_errors)}, 67 {"rx_over_errors", IXGBE_STAT(net_stats.rx_over_errors)},
68 {"rx_crc_errors", IXGBE_STAT(net_stats.rx_crc_errors)}, 68 {"rx_crc_errors", IXGBE_STAT(net_stats.rx_crc_errors)},
69 {"rx_frame_errors", IXGBE_STAT(net_stats.rx_frame_errors)}, 69 {"rx_frame_errors", IXGBE_STAT(net_stats.rx_frame_errors)},
70 {"hw_rsc_count", IXGBE_STAT(rsc_count)},
70 {"rx_fifo_errors", IXGBE_STAT(net_stats.rx_fifo_errors)}, 71 {"rx_fifo_errors", IXGBE_STAT(net_stats.rx_fifo_errors)},
71 {"rx_missed_errors", IXGBE_STAT(net_stats.rx_missed_errors)}, 72 {"rx_missed_errors", IXGBE_STAT(net_stats.rx_missed_errors)},
72 {"tx_aborted_errors", IXGBE_STAT(net_stats.tx_aborted_errors)}, 73 {"tx_aborted_errors", IXGBE_STAT(net_stats.tx_aborted_errors)},
@@ -1127,6 +1128,27 @@ static int ixgbe_set_coalesce(struct net_device *netdev,
1127 return 0; 1128 return 0;
1128} 1129}
1129 1130
1131static int ixgbe_set_flags(struct net_device *netdev, u32 data)
1132{
1133 struct ixgbe_adapter *adapter = netdev_priv(netdev);
1134
1135 ethtool_op_set_flags(netdev, data);
1136
1137 if (!(adapter->flags & IXGBE_FLAG_RSC_CAPABLE))
1138 return 0;
1139
1140 /* if state changes we need to update adapter->flags and reset */
1141 if ((!!(data & ETH_FLAG_LRO)) !=
1142 (!!(adapter->flags & IXGBE_FLAG_RSC_ENABLED))) {
1143 adapter->flags ^= IXGBE_FLAG_RSC_ENABLED;
1144 if (netif_running(netdev))
1145 ixgbe_reinit_locked(adapter);
1146 else
1147 ixgbe_reset(adapter);
1148 }
1149 return 0;
1150
1151}
1130 1152
1131static const struct ethtool_ops ixgbe_ethtool_ops = { 1153static const struct ethtool_ops ixgbe_ethtool_ops = {
1132 .get_settings = ixgbe_get_settings, 1154 .get_settings = ixgbe_get_settings,
@@ -1161,7 +1183,7 @@ static const struct ethtool_ops ixgbe_ethtool_ops = {
1161 .get_coalesce = ixgbe_get_coalesce, 1183 .get_coalesce = ixgbe_get_coalesce,
1162 .set_coalesce = ixgbe_set_coalesce, 1184 .set_coalesce = ixgbe_set_coalesce,
1163 .get_flags = ethtool_op_get_flags, 1185 .get_flags = ethtool_op_get_flags,
1164 .set_flags = ethtool_op_set_flags, 1186 .set_flags = ixgbe_set_flags,
1165}; 1187};
1166 1188
1167void ixgbe_set_ethtool_ops(struct net_device *netdev) 1189void ixgbe_set_ethtool_ops(struct net_device *netdev)
diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c
index c3dff8f02e33..419ce472cef8 100644
--- a/drivers/net/ixgbe/ixgbe_main.c
+++ b/drivers/net/ixgbe/ixgbe_main.c
@@ -615,6 +615,40 @@ static inline u16 ixgbe_get_pkt_info(union ixgbe_adv_rx_desc *rx_desc)
615 return rx_desc->wb.lower.lo_dword.hs_rss.pkt_info; 615 return rx_desc->wb.lower.lo_dword.hs_rss.pkt_info;
616} 616}
617 617
618static inline u32 ixgbe_get_rsc_count(union ixgbe_adv_rx_desc *rx_desc)
619{
620 return (le32_to_cpu(rx_desc->wb.lower.lo_dword.data) &
621 IXGBE_RXDADV_RSCCNT_MASK) >>
622 IXGBE_RXDADV_RSCCNT_SHIFT;
623}
624
625/**
626 * ixgbe_transform_rsc_queue - change rsc queue into a full packet
627 * @skb: pointer to the last skb in the rsc queue
628 *
629 * This function changes a queue full of hw rsc buffers into a completed
630 * packet. It uses the ->prev pointers to find the first packet and then
631 * turns it into the frag list owner.
632 **/
633static inline struct sk_buff *ixgbe_transform_rsc_queue(struct sk_buff *skb)
634{
635 unsigned int frag_list_size = 0;
636
637 while (skb->prev) {
638 struct sk_buff *prev = skb->prev;
639 frag_list_size += skb->len;
640 skb->prev = NULL;
641 skb = prev;
642 }
643
644 skb_shinfo(skb)->frag_list = skb->next;
645 skb->next = NULL;
646 skb->len += frag_list_size;
647 skb->data_len += frag_list_size;
648 skb->truesize += frag_list_size;
649 return skb;
650}
651
618static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, 652static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector,
619 struct ixgbe_ring *rx_ring, 653 struct ixgbe_ring *rx_ring,
620 int *work_done, int work_to_do) 654 int *work_done, int work_to_do)
@@ -624,7 +658,7 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector,
624 union ixgbe_adv_rx_desc *rx_desc, *next_rxd; 658 union ixgbe_adv_rx_desc *rx_desc, *next_rxd;
625 struct ixgbe_rx_buffer *rx_buffer_info, *next_buffer; 659 struct ixgbe_rx_buffer *rx_buffer_info, *next_buffer;
626 struct sk_buff *skb; 660 struct sk_buff *skb;
627 unsigned int i; 661 unsigned int i, rsc_count = 0;
628 u32 len, staterr; 662 u32 len, staterr;
629 u16 hdr_info; 663 u16 hdr_info;
630 bool cleaned = false; 664 bool cleaned = false;
@@ -690,20 +724,38 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector,
690 i++; 724 i++;
691 if (i == rx_ring->count) 725 if (i == rx_ring->count)
692 i = 0; 726 i = 0;
693 next_buffer = &rx_ring->rx_buffer_info[i];
694 727
695 next_rxd = IXGBE_RX_DESC_ADV(*rx_ring, i); 728 next_rxd = IXGBE_RX_DESC_ADV(*rx_ring, i);
696 prefetch(next_rxd); 729 prefetch(next_rxd);
697
698 cleaned_count++; 730 cleaned_count++;
731
732 if (adapter->flags & IXGBE_FLAG_RSC_CAPABLE)
733 rsc_count = ixgbe_get_rsc_count(rx_desc);
734
735 if (rsc_count) {
736 u32 nextp = (staterr & IXGBE_RXDADV_NEXTP_MASK) >>
737 IXGBE_RXDADV_NEXTP_SHIFT;
738 next_buffer = &rx_ring->rx_buffer_info[nextp];
739 rx_ring->rsc_count += (rsc_count - 1);
740 } else {
741 next_buffer = &rx_ring->rx_buffer_info[i];
742 }
743
699 if (staterr & IXGBE_RXD_STAT_EOP) { 744 if (staterr & IXGBE_RXD_STAT_EOP) {
745 if (skb->prev)
746 skb = ixgbe_transform_rsc_queue(skb);
700 rx_ring->stats.packets++; 747 rx_ring->stats.packets++;
701 rx_ring->stats.bytes += skb->len; 748 rx_ring->stats.bytes += skb->len;
702 } else { 749 } else {
703 rx_buffer_info->skb = next_buffer->skb; 750 if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) {
704 rx_buffer_info->dma = next_buffer->dma; 751 rx_buffer_info->skb = next_buffer->skb;
705 next_buffer->skb = skb; 752 rx_buffer_info->dma = next_buffer->dma;
706 next_buffer->dma = 0; 753 next_buffer->skb = skb;
754 next_buffer->dma = 0;
755 } else {
756 skb->next = next_buffer->skb;
757 skb->next->prev = skb;
758 }
707 adapter->non_eop_descs++; 759 adapter->non_eop_descs++;
708 goto next_desc; 760 goto next_desc;
709 } 761 }
@@ -733,7 +785,7 @@ next_desc:
733 785
734 /* use prefetched values */ 786 /* use prefetched values */
735 rx_desc = next_rxd; 787 rx_desc = next_rxd;
736 rx_buffer_info = next_buffer; 788 rx_buffer_info = &rx_ring->rx_buffer_info[i];
737 789
738 staterr = le32_to_cpu(rx_desc->wb.upper.status_error); 790 staterr = le32_to_cpu(rx_desc->wb.upper.status_error);
739 } 791 }
@@ -1729,6 +1781,7 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
1729 u32 fctrl, hlreg0; 1781 u32 fctrl, hlreg0;
1730 u32 reta = 0, mrqc = 0; 1782 u32 reta = 0, mrqc = 0;
1731 u32 rdrxctl; 1783 u32 rdrxctl;
1784 u32 rscctrl;
1732 int rx_buf_len; 1785 int rx_buf_len;
1733 1786
1734 /* Decide whether to use packet split mode or not */ 1787 /* Decide whether to use packet split mode or not */
@@ -1746,7 +1799,8 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
1746 IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), psrtype); 1799 IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), psrtype);
1747 } 1800 }
1748 } else { 1801 } else {
1749 if (netdev->mtu <= ETH_DATA_LEN) 1802 if (!(adapter->flags & IXGBE_FLAG_RSC_ENABLED) &&
1803 (netdev->mtu <= ETH_DATA_LEN))
1750 rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE; 1804 rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE;
1751 else 1805 else
1752 rx_buf_len = ALIGN(max_frame, 1024); 1806 rx_buf_len = ALIGN(max_frame, 1024);
@@ -1868,8 +1922,38 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
1868 if (hw->mac.type == ixgbe_mac_82599EB) { 1922 if (hw->mac.type == ixgbe_mac_82599EB) {
1869 rdrxctl = IXGBE_READ_REG(hw, IXGBE_RDRXCTL); 1923 rdrxctl = IXGBE_READ_REG(hw, IXGBE_RDRXCTL);
1870 rdrxctl |= IXGBE_RDRXCTL_CRCSTRIP; 1924 rdrxctl |= IXGBE_RDRXCTL_CRCSTRIP;
1925 rdrxctl &= ~IXGBE_RDRXCTL_RSCFRSTSIZE;
1871 IXGBE_WRITE_REG(hw, IXGBE_RDRXCTL, rdrxctl); 1926 IXGBE_WRITE_REG(hw, IXGBE_RDRXCTL, rdrxctl);
1872 } 1927 }
1928
1929 if (adapter->flags & IXGBE_FLAG_RSC_ENABLED) {
1930 /* Enable 82599 HW-RSC */
1931 for (i = 0; i < adapter->num_rx_queues; i++) {
1932 j = adapter->rx_ring[i].reg_idx;
1933 rscctrl = IXGBE_READ_REG(hw, IXGBE_RSCCTL(j));
1934 rscctrl |= IXGBE_RSCCTL_RSCEN;
1935 /*
1936 * if packet split is enabled we can only support up
1937 * to max frags + 1 descriptors.
1938 */
1939 if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED)
1940#if (MAX_SKB_FRAGS < 3)
1941 rscctrl |= IXGBE_RSCCTL_MAXDESC_1;
1942#elif (MAX_SKB_FRAGS < 7)
1943 rscctrl |= IXGBE_RSCCTL_MAXDESC_4;
1944#elif (MAX_SKB_FRAGS < 15)
1945 rscctrl |= IXGBE_RSCCTL_MAXDESC_8;
1946#else
1947 rscctrl |= IXGBE_RSCCTL_MAXDESC_16;
1948#endif
1949 else
1950 rscctrl |= IXGBE_RSCCTL_MAXDESC_16;
1951 IXGBE_WRITE_REG(hw, IXGBE_RSCCTL(j), rscctrl);
1952 }
1953 /* Disable RSC for ACK packets */
1954 IXGBE_WRITE_REG(hw, IXGBE_RSCDBU,
1955 (IXGBE_RSCDBU_RSCACKDIS | IXGBE_READ_REG(hw, IXGBE_RSCDBU)));
1956 }
1873} 1957}
1874 1958
1875static void ixgbe_vlan_rx_add_vid(struct net_device *netdev, u16 vid) 1959static void ixgbe_vlan_rx_add_vid(struct net_device *netdev, u16 vid)
@@ -2438,8 +2522,13 @@ static void ixgbe_clean_rx_ring(struct ixgbe_adapter *adapter,
2438 rx_buffer_info->dma = 0; 2522 rx_buffer_info->dma = 0;
2439 } 2523 }
2440 if (rx_buffer_info->skb) { 2524 if (rx_buffer_info->skb) {
2441 dev_kfree_skb(rx_buffer_info->skb); 2525 struct sk_buff *skb = rx_buffer_info->skb;
2442 rx_buffer_info->skb = NULL; 2526 rx_buffer_info->skb = NULL;
2527 do {
2528 struct sk_buff *this = skb;
2529 skb = skb->prev;
2530 dev_kfree_skb(this);
2531 } while (skb);
2443 } 2532 }
2444 if (!rx_buffer_info->page) 2533 if (!rx_buffer_info->page)
2445 continue; 2534 continue;
@@ -3180,8 +3269,11 @@ static int __devinit ixgbe_sw_init(struct ixgbe_adapter *adapter)
3180 adapter->ring_feature[RING_F_DCB].indices = IXGBE_MAX_DCB_INDICES; 3269 adapter->ring_feature[RING_F_DCB].indices = IXGBE_MAX_DCB_INDICES;
3181 if (hw->mac.type == ixgbe_mac_82598EB) 3270 if (hw->mac.type == ixgbe_mac_82598EB)
3182 adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82598; 3271 adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82598;
3183 else if (hw->mac.type == ixgbe_mac_82599EB) 3272 else if (hw->mac.type == ixgbe_mac_82599EB) {
3184 adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82599; 3273 adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82599;
3274 adapter->flags |= IXGBE_FLAG_RSC_CAPABLE;
3275 adapter->flags |= IXGBE_FLAG_RSC_ENABLED;
3276 }
3185 3277
3186#ifdef CONFIG_IXGBE_DCB 3278#ifdef CONFIG_IXGBE_DCB
3187 /* Configure DCB traffic classes */ 3279 /* Configure DCB traffic classes */
@@ -3765,9 +3857,13 @@ void ixgbe_update_stats(struct ixgbe_adapter *adapter)
3765 u32 i, missed_rx = 0, mpc, bprc, lxon, lxoff, xon_off_tot; 3857 u32 i, missed_rx = 0, mpc, bprc, lxon, lxoff, xon_off_tot;
3766 3858
3767 if (hw->mac.type == ixgbe_mac_82599EB) { 3859 if (hw->mac.type == ixgbe_mac_82599EB) {
3860 u64 rsc_count = 0;
3768 for (i = 0; i < 16; i++) 3861 for (i = 0; i < 16; i++)
3769 adapter->hw_rx_no_dma_resources += 3862 adapter->hw_rx_no_dma_resources +=
3770 IXGBE_READ_REG(hw, IXGBE_QPRDC(i)); 3863 IXGBE_READ_REG(hw, IXGBE_QPRDC(i));
3864 for (i = 0; i < adapter->num_rx_queues; i++)
3865 rsc_count += adapter->rx_ring[i].rsc_count;
3866 adapter->rsc_count = rsc_count;
3771 } 3867 }
3772 3868
3773 adapter->stats.crcerrs += IXGBE_READ_REG(hw, IXGBE_CRCERRS); 3869 adapter->stats.crcerrs += IXGBE_READ_REG(hw, IXGBE_CRCERRS);
@@ -4742,6 +4838,9 @@ static int __devinit ixgbe_probe(struct pci_dev *pdev,
4742 if (pci_using_dac) 4838 if (pci_using_dac)
4743 netdev->features |= NETIF_F_HIGHDMA; 4839 netdev->features |= NETIF_F_HIGHDMA;
4744 4840
4841 if (adapter->flags & IXGBE_FLAG_RSC_ENABLED)
4842 netdev->features |= NETIF_F_LRO;
4843
4745 /* make sure the EEPROM is good */ 4844 /* make sure the EEPROM is good */
4746 if (hw->eeprom.ops.validate_checksum(hw, NULL) < 0) { 4845 if (hw->eeprom.ops.validate_checksum(hw, NULL) < 0) {
4747 dev_err(&pdev->dev, "The EEPROM Checksum Is Not Valid\n"); 4846 dev_err(&pdev->dev, "The EEPROM Checksum Is Not Valid\n");
diff --git a/drivers/net/ixgbe/ixgbe_type.h b/drivers/net/ixgbe/ixgbe_type.h
index 375f0d4ad965..bdfdf3bca273 100644
--- a/drivers/net/ixgbe/ixgbe_type.h
+++ b/drivers/net/ixgbe/ixgbe_type.h
@@ -443,6 +443,21 @@
443 443
444#define IXGBE_SECTXCTRL_STORE_FORWARD_ENABLE 0x4 444#define IXGBE_SECTXCTRL_STORE_FORWARD_ENABLE 0x4
445 445
446/* HW RSC registers */
447#define IXGBE_RSCCTL(_i) (((_i) < 64) ? (0x0102C + ((_i) * 0x40)) : \
448 (0x0D02C + ((_i - 64) * 0x40)))
449#define IXGBE_RSCDBU 0x03028
450#define IXGBE_RSCCTL_RSCEN 0x01
451#define IXGBE_RSCCTL_MAXDESC_1 0x00
452#define IXGBE_RSCCTL_MAXDESC_4 0x04
453#define IXGBE_RSCCTL_MAXDESC_8 0x08
454#define IXGBE_RSCCTL_MAXDESC_16 0x0C
455#define IXGBE_RXDADV_RSCCNT_SHIFT 17
456#define IXGBE_GPIE_RSC_DELAY_SHIFT 11
457#define IXGBE_RXDADV_RSCCNT_MASK 0x001E0000
458#define IXGBE_RSCDBU_RSCACKDIS 0x00000080
459#define IXGBE_RDRXCTL_RSCFRSTSIZE 0x003E0000
460
446/* DCB registers */ 461/* DCB registers */
447#define IXGBE_RTRPCS 0x02430 462#define IXGBE_RTRPCS 0x02430
448#define IXGBE_RTTDCS 0x04900 463#define IXGBE_RTTDCS 0x04900