aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ixgbe/ixgbe_main.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/ixgbe/ixgbe_main.c')
-rw-r--r--drivers/net/ixgbe/ixgbe_main.c108
1 files changed, 60 insertions, 48 deletions
diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c
index 520b95fc4d41..841ef9827ec6 100644
--- a/drivers/net/ixgbe/ixgbe_main.c
+++ b/drivers/net/ixgbe/ixgbe_main.c
@@ -2695,25 +2695,15 @@ static void ixgbe_setup_psrtype(struct ixgbe_adapter *adapter)
2695 psrtype); 2695 psrtype);
2696} 2696}
2697 2697
2698/** 2698static void ixgbe_set_rx_buffer_len(struct ixgbe_adapter *adapter)
2699 * ixgbe_configure_rx - Configure 8259x Receive Unit after Reset
2700 * @adapter: board private structure
2701 *
2702 * Configure the Rx unit of the MAC after a reset.
2703 **/
2704static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
2705{ 2699{
2706 struct ixgbe_hw *hw = &adapter->hw; 2700 struct ixgbe_hw *hw = &adapter->hw;
2707 struct ixgbe_ring *rx_ring;
2708 struct net_device *netdev = adapter->netdev; 2701 struct net_device *netdev = adapter->netdev;
2709 int max_frame = netdev->mtu + ETH_HLEN + ETH_FCS_LEN; 2702 int max_frame = netdev->mtu + ETH_HLEN + ETH_FCS_LEN;
2710 int i;
2711 u32 rxctrl;
2712 u32 hlreg0, gcr_ext;
2713 u32 rdrxctl;
2714 int rx_buf_len; 2703 int rx_buf_len;
2715 2704 struct ixgbe_ring *rx_ring;
2716 ixgbe_setup_psrtype(adapter); 2705 int i;
2706 u32 mhadd, hlreg0;
2717 2707
2718 /* Decide whether to use packet split mode or not */ 2708 /* Decide whether to use packet split mode or not */
2719 /* Do not use packet split if we're in SR-IOV Mode */ 2709 /* Do not use packet split if we're in SR-IOV Mode */
@@ -2728,23 +2718,28 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
2728 (netdev->mtu <= ETH_DATA_LEN)) 2718 (netdev->mtu <= ETH_DATA_LEN))
2729 rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE; 2719 rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE;
2730 else 2720 else
2731 rx_buf_len = ALIGN(max_frame, 1024); 2721 rx_buf_len = ALIGN(max_frame + VLAN_HLEN, 1024);
2732 } 2722 }
2733 2723
2734 hlreg0 = IXGBE_READ_REG(hw, IXGBE_HLREG0);
2735 if (adapter->netdev->mtu <= ETH_DATA_LEN)
2736 hlreg0 &= ~IXGBE_HLREG0_JUMBOEN;
2737 else
2738 hlreg0 |= IXGBE_HLREG0_JUMBOEN;
2739#ifdef IXGBE_FCOE 2724#ifdef IXGBE_FCOE
2740 if (netdev->features & NETIF_F_FCOE_MTU) 2725 /* adjust max frame to be able to do baby jumbo for FCoE */
2741 hlreg0 |= IXGBE_HLREG0_JUMBOEN; 2726 if ((adapter->flags & IXGBE_FLAG_FCOE_ENABLED) &&
2742#endif 2727 (max_frame < IXGBE_FCOE_JUMBO_FRAME_SIZE))
2743 IXGBE_WRITE_REG(hw, IXGBE_HLREG0, hlreg0); 2728 max_frame = IXGBE_FCOE_JUMBO_FRAME_SIZE;
2744 2729
2745 /* disable receives while setting up the descriptors */ 2730#endif /* IXGBE_FCOE */
2746 rxctrl = IXGBE_READ_REG(hw, IXGBE_RXCTRL); 2731 mhadd = IXGBE_READ_REG(hw, IXGBE_MHADD);
2747 IXGBE_WRITE_REG(hw, IXGBE_RXCTRL, rxctrl & ~IXGBE_RXCTRL_RXEN); 2732 if (max_frame != (mhadd >> IXGBE_MHADD_MFS_SHIFT)) {
2733 mhadd &= ~IXGBE_MHADD_MFS_MASK;
2734 mhadd |= max_frame << IXGBE_MHADD_MFS_SHIFT;
2735
2736 IXGBE_WRITE_REG(hw, IXGBE_MHADD, mhadd);
2737 }
2738
2739 hlreg0 = IXGBE_READ_REG(hw, IXGBE_HLREG0);
2740 /* set jumbo enable since MHADD.MFS is keeping size locked at max_frame */
2741 hlreg0 |= IXGBE_HLREG0_JUMBOEN;
2742 IXGBE_WRITE_REG(hw, IXGBE_HLREG0, hlreg0);
2748 2743
2749 /* 2744 /*
2750 * Setup the HW Rx Head and Tail Descriptor Pointers and 2745 * Setup the HW Rx Head and Tail Descriptor Pointers and
@@ -2760,7 +2755,8 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
2760 rx_ring->flags &= ~IXGBE_RING_RX_PS_ENABLED; 2755 rx_ring->flags &= ~IXGBE_RING_RX_PS_ENABLED;
2761 2756
2762#ifdef IXGBE_FCOE 2757#ifdef IXGBE_FCOE
2763 if (netdev->features & NETIF_F_FCOE_MTU) { 2758 if (netdev->features & NETIF_F_FCOE_MTU)
2759 {
2764 struct ixgbe_ring_feature *f; 2760 struct ixgbe_ring_feature *f;
2765 f = &adapter->ring_feature[RING_F_FCOE]; 2761 f = &adapter->ring_feature[RING_F_FCOE];
2766 if ((i >= f->mask) && (i < f->mask + f->indices)) { 2762 if ((i >= f->mask) && (i < f->mask + f->indices)) {
@@ -2770,8 +2766,41 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
2770 IXGBE_FCOE_JUMBO_FRAME_SIZE; 2766 IXGBE_FCOE_JUMBO_FRAME_SIZE;
2771 } 2767 }
2772 } 2768 }
2773
2774#endif /* IXGBE_FCOE */ 2769#endif /* IXGBE_FCOE */
2770 }
2771
2772}
2773
2774/**
2775 * ixgbe_configure_rx - Configure 8259x Receive Unit after Reset
2776 * @adapter: board private structure
2777 *
2778 * Configure the Rx unit of the MAC after a reset.
2779 **/
2780static void ixgbe_configure_rx(struct ixgbe_adapter *adapter)
2781{
2782 struct ixgbe_hw *hw = &adapter->hw;
2783 struct ixgbe_ring *rx_ring;
2784 int i;
2785 u32 rxctrl;
2786 u32 gcr_ext;
2787 u32 rdrxctl;
2788
2789 /* disable receives while setting up the descriptors */
2790 rxctrl = IXGBE_READ_REG(hw, IXGBE_RXCTRL);
2791 IXGBE_WRITE_REG(hw, IXGBE_RXCTRL, rxctrl & ~IXGBE_RXCTRL_RXEN);
2792
2793 ixgbe_setup_psrtype(adapter);
2794
2795 /* set_rx_buffer_len must be called before ring initialization */
2796 ixgbe_set_rx_buffer_len(adapter);
2797
2798 /*
2799 * Setup the HW Rx Head and Tail Descriptor Pointers and
2800 * the Base and Length of the Rx Descriptor Ring
2801 */
2802 for (i = 0; i < adapter->num_rx_queues; i++) {
2803 rx_ring = adapter->rx_ring[i];
2775 ixgbe_configure_rx_ring(adapter, rx_ring); 2804 ixgbe_configure_rx_ring(adapter, rx_ring);
2776 ixgbe_configure_srrctl(adapter, rx_ring); 2805 ixgbe_configure_srrctl(adapter, rx_ring);
2777 } 2806 }
@@ -3322,13 +3351,11 @@ static inline void ixgbe_rx_desc_queue_enable(struct ixgbe_adapter *adapter,
3322 3351
3323static int ixgbe_up_complete(struct ixgbe_adapter *adapter) 3352static int ixgbe_up_complete(struct ixgbe_adapter *adapter)
3324{ 3353{
3325 struct net_device *netdev = adapter->netdev;
3326 struct ixgbe_hw *hw = &adapter->hw; 3354 struct ixgbe_hw *hw = &adapter->hw;
3327 int i, j = 0; 3355 int i, j = 0;
3328 int num_rx_rings = adapter->num_rx_queues; 3356 int num_rx_rings = adapter->num_rx_queues;
3329 int err; 3357 int err;
3330 int max_frame = netdev->mtu + ETH_HLEN + ETH_FCS_LEN; 3358 u32 txdctl, rxdctl;
3331 u32 txdctl, rxdctl, mhadd;
3332 u32 dmatxctl; 3359 u32 dmatxctl;
3333 u32 gpie; 3360 u32 gpie;
3334 u32 ctrl_ext; 3361 u32 ctrl_ext;
@@ -3395,21 +3422,6 @@ static int ixgbe_up_complete(struct ixgbe_adapter *adapter)
3395 IXGBE_WRITE_REG(hw, IXGBE_GPIE, gpie); 3422 IXGBE_WRITE_REG(hw, IXGBE_GPIE, gpie);
3396 } 3423 }
3397 3424
3398#ifdef IXGBE_FCOE
3399 /* adjust max frame to be able to do baby jumbo for FCoE */
3400 if ((netdev->features & NETIF_F_FCOE_MTU) &&
3401 (max_frame < IXGBE_FCOE_JUMBO_FRAME_SIZE))
3402 max_frame = IXGBE_FCOE_JUMBO_FRAME_SIZE;
3403
3404#endif /* IXGBE_FCOE */
3405 mhadd = IXGBE_READ_REG(hw, IXGBE_MHADD);
3406 if (max_frame != (mhadd >> IXGBE_MHADD_MFS_SHIFT)) {
3407 mhadd &= ~IXGBE_MHADD_MFS_MASK;
3408 mhadd |= max_frame << IXGBE_MHADD_MFS_SHIFT;
3409
3410 IXGBE_WRITE_REG(hw, IXGBE_MHADD, mhadd);
3411 }
3412
3413 if (hw->mac.type == ixgbe_mac_82599EB) { 3425 if (hw->mac.type == ixgbe_mac_82599EB) {
3414 /* DMATXCTL.EN must be set after all Tx queue config is done */ 3426 /* DMATXCTL.EN must be set after all Tx queue config is done */
3415 dmatxctl = IXGBE_READ_REG(hw, IXGBE_DMATXCTL); 3427 dmatxctl = IXGBE_READ_REG(hw, IXGBE_DMATXCTL);
@@ -3522,7 +3534,7 @@ static int ixgbe_up_complete(struct ixgbe_adapter *adapter)
3522 &(adapter->tx_ring[i]->reinit_state)); 3534 &(adapter->tx_ring[i]->reinit_state));
3523 3535
3524 /* enable transmits */ 3536 /* enable transmits */
3525 netif_tx_start_all_queues(netdev); 3537 netif_tx_start_all_queues(adapter->netdev);
3526 3538
3527 /* bring the link up in the watchdog, this could race with our first 3539 /* bring the link up in the watchdog, this could race with our first
3528 * link up interrupt but shouldn't be a problem */ 3540 * link up interrupt but shouldn't be a problem */