aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/e1000e/netdev.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/e1000e/netdev.c')
-rw-r--r--drivers/net/e1000e/netdev.c50
1 files changed, 44 insertions, 6 deletions
diff --git a/drivers/net/e1000e/netdev.c b/drivers/net/e1000e/netdev.c
index 1aa4228e860a..992b622fe205 100644
--- a/drivers/net/e1000e/netdev.c
+++ b/drivers/net/e1000e/netdev.c
@@ -2290,6 +2290,11 @@ static void e1000_set_itr(struct e1000_adapter *adapter)
2290 goto set_itr_now; 2290 goto set_itr_now;
2291 } 2291 }
2292 2292
2293 if (adapter->flags2 & FLAG2_DISABLE_AIM) {
2294 new_itr = 0;
2295 goto set_itr_now;
2296 }
2297
2293 adapter->tx_itr = e1000_update_itr(adapter, 2298 adapter->tx_itr = e1000_update_itr(adapter,
2294 adapter->tx_itr, 2299 adapter->tx_itr,
2295 adapter->total_tx_packets, 2300 adapter->total_tx_packets,
@@ -2338,7 +2343,10 @@ set_itr_now:
2338 if (adapter->msix_entries) 2343 if (adapter->msix_entries)
2339 adapter->rx_ring->set_itr = 1; 2344 adapter->rx_ring->set_itr = 1;
2340 else 2345 else
2341 ew32(ITR, 1000000000 / (new_itr * 256)); 2346 if (new_itr)
2347 ew32(ITR, 1000000000 / (new_itr * 256));
2348 else
2349 ew32(ITR, 0);
2342 } 2350 }
2343} 2351}
2344 2352
@@ -2920,7 +2928,7 @@ static void e1000_configure_rx(struct e1000_adapter *adapter)
2920 2928
2921 /* irq moderation */ 2929 /* irq moderation */
2922 ew32(RADV, adapter->rx_abs_int_delay); 2930 ew32(RADV, adapter->rx_abs_int_delay);
2923 if (adapter->itr_setting != 0) 2931 if ((adapter->itr_setting != 0) && (adapter->itr != 0))
2924 ew32(ITR, 1000000000 / (adapter->itr * 256)); 2932 ew32(ITR, 1000000000 / (adapter->itr * 256));
2925 2933
2926 ctrl_ext = er32(CTRL_EXT); 2934 ctrl_ext = er32(CTRL_EXT);
@@ -2965,11 +2973,13 @@ static void e1000_configure_rx(struct e1000_adapter *adapter)
2965 * packet size is equal or larger than the specified value (in 8 byte 2973 * packet size is equal or larger than the specified value (in 8 byte
2966 * units), e.g. using jumbo frames when setting to E1000_ERT_2048 2974 * units), e.g. using jumbo frames when setting to E1000_ERT_2048
2967 */ 2975 */
2968 if (adapter->flags & FLAG_HAS_ERT) { 2976 if ((adapter->flags & FLAG_HAS_ERT) ||
2977 (adapter->hw.mac.type == e1000_pch2lan)) {
2969 if (adapter->netdev->mtu > ETH_DATA_LEN) { 2978 if (adapter->netdev->mtu > ETH_DATA_LEN) {
2970 u32 rxdctl = er32(RXDCTL(0)); 2979 u32 rxdctl = er32(RXDCTL(0));
2971 ew32(RXDCTL(0), rxdctl | 0x3); 2980 ew32(RXDCTL(0), rxdctl | 0x3);
2972 ew32(ERT, E1000_ERT_2048 | (1 << 13)); 2981 if (adapter->flags & FLAG_HAS_ERT)
2982 ew32(ERT, E1000_ERT_2048 | (1 << 13));
2973 /* 2983 /*
2974 * With jumbo frames and early-receive enabled, 2984 * With jumbo frames and early-receive enabled,
2975 * excessive C-state transition latencies result in 2985 * excessive C-state transition latencies result in
@@ -3232,9 +3242,35 @@ void e1000e_reset(struct e1000_adapter *adapter)
3232 fc->low_water = 0x05048; 3242 fc->low_water = 0x05048;
3233 fc->pause_time = 0x0650; 3243 fc->pause_time = 0x0650;
3234 fc->refresh_time = 0x0400; 3244 fc->refresh_time = 0x0400;
3245 if (adapter->netdev->mtu > ETH_DATA_LEN) {
3246 pba = 14;
3247 ew32(PBA, pba);
3248 }
3235 break; 3249 break;
3236 } 3250 }
3237 3251
3252 /*
3253 * Disable Adaptive Interrupt Moderation if 2 full packets cannot
3254 * fit in receive buffer and early-receive not supported.
3255 */
3256 if (adapter->itr_setting & 0x3) {
3257 if (((adapter->max_frame_size * 2) > (pba << 10)) &&
3258 !(adapter->flags & FLAG_HAS_ERT)) {
3259 if (!(adapter->flags2 & FLAG2_DISABLE_AIM)) {
3260 dev_info(&adapter->pdev->dev,
3261 "Interrupt Throttle Rate turned off\n");
3262 adapter->flags2 |= FLAG2_DISABLE_AIM;
3263 ew32(ITR, 0);
3264 }
3265 } else if (adapter->flags2 & FLAG2_DISABLE_AIM) {
3266 dev_info(&adapter->pdev->dev,
3267 "Interrupt Throttle Rate turned on\n");
3268 adapter->flags2 &= ~FLAG2_DISABLE_AIM;
3269 adapter->itr = 20000;
3270 ew32(ITR, 1000000000 / (adapter->itr * 256));
3271 }
3272 }
3273
3238 /* Allow time for pending master requests to run */ 3274 /* Allow time for pending master requests to run */
3239 mac->ops.reset_hw(hw); 3275 mac->ops.reset_hw(hw);
3240 3276
@@ -3553,7 +3589,8 @@ static int e1000_open(struct net_device *netdev)
3553 e1000_update_mng_vlan(adapter); 3589 e1000_update_mng_vlan(adapter);
3554 3590
3555 /* DMA latency requirement to workaround early-receive/jumbo issue */ 3591 /* DMA latency requirement to workaround early-receive/jumbo issue */
3556 if (adapter->flags & FLAG_HAS_ERT) 3592 if ((adapter->flags & FLAG_HAS_ERT) ||
3593 (adapter->hw.mac.type == e1000_pch2lan))
3557 pm_qos_add_request(&adapter->netdev->pm_qos_req, 3594 pm_qos_add_request(&adapter->netdev->pm_qos_req,
3558 PM_QOS_CPU_DMA_LATENCY, 3595 PM_QOS_CPU_DMA_LATENCY,
3559 PM_QOS_DEFAULT_VALUE); 3596 PM_QOS_DEFAULT_VALUE);
@@ -3662,7 +3699,8 @@ static int e1000_close(struct net_device *netdev)
3662 if (adapter->flags & FLAG_HAS_AMT) 3699 if (adapter->flags & FLAG_HAS_AMT)
3663 e1000_release_hw_control(adapter); 3700 e1000_release_hw_control(adapter);
3664 3701
3665 if (adapter->flags & FLAG_HAS_ERT) 3702 if ((adapter->flags & FLAG_HAS_ERT) ||
3703 (adapter->hw.mac.type == e1000_pch2lan))
3666 pm_qos_remove_request(&adapter->netdev->pm_qos_req); 3704 pm_qos_remove_request(&adapter->netdev->pm_qos_req);
3667 3705
3668 pm_runtime_put_sync(&pdev->dev); 3706 pm_runtime_put_sync(&pdev->dev);