aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/igb
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/igb')
-rw-r--r--drivers/net/igb/igb.h3
-rw-r--r--drivers/net/igb/igb_main.c35
2 files changed, 19 insertions, 19 deletions
diff --git a/drivers/net/igb/igb.h b/drivers/net/igb/igb.h
index 8b189a0c52ef..6c35c9029a50 100644
--- a/drivers/net/igb/igb.h
+++ b/drivers/net/igb/igb.h
@@ -349,6 +349,9 @@ extern void igb_configure_tx_ring(struct igb_adapter *, struct igb_ring *);
349extern void igb_configure_rx_ring(struct igb_adapter *, struct igb_ring *); 349extern void igb_configure_rx_ring(struct igb_adapter *, struct igb_ring *);
350extern void igb_setup_tctl(struct igb_adapter *); 350extern void igb_setup_tctl(struct igb_adapter *);
351extern void igb_setup_rctl(struct igb_adapter *); 351extern void igb_setup_rctl(struct igb_adapter *);
352extern netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *, struct igb_ring *);
353extern void igb_unmap_and_free_tx_resource(struct igb_ring *,
354 struct igb_buffer *);
352extern void igb_alloc_rx_buffers_adv(struct igb_ring *, int); 355extern void igb_alloc_rx_buffers_adv(struct igb_ring *, int);
353extern void igb_update_stats(struct igb_adapter *); 356extern void igb_update_stats(struct igb_adapter *);
354extern void igb_set_ethtool_ops(struct net_device *); 357extern void igb_set_ethtool_ops(struct net_device *);
diff --git a/drivers/net/igb/igb_main.c b/drivers/net/igb/igb_main.c
index 576a4fac51d1..c9fda113abe6 100644
--- a/drivers/net/igb/igb_main.c
+++ b/drivers/net/igb/igb_main.c
@@ -99,10 +99,7 @@ static void igb_set_rx_mode(struct net_device *);
99static void igb_update_phy_info(unsigned long); 99static void igb_update_phy_info(unsigned long);
100static void igb_watchdog(unsigned long); 100static void igb_watchdog(unsigned long);
101static void igb_watchdog_task(struct work_struct *); 101static void igb_watchdog_task(struct work_struct *);
102static netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *, 102static netdev_tx_t igb_xmit_frame_adv(struct sk_buff *skb, struct net_device *);
103 struct igb_ring *);
104static netdev_tx_t igb_xmit_frame_adv(struct sk_buff *skb,
105 struct net_device *);
106static struct net_device_stats *igb_get_stats(struct net_device *); 103static struct net_device_stats *igb_get_stats(struct net_device *);
107static int igb_change_mtu(struct net_device *, int); 104static int igb_change_mtu(struct net_device *, int);
108static int igb_set_mac(struct net_device *, void *); 105static int igb_set_mac(struct net_device *, void *);
@@ -2521,8 +2518,8 @@ static void igb_free_all_tx_resources(struct igb_adapter *adapter)
2521 igb_free_tx_resources(&adapter->tx_ring[i]); 2518 igb_free_tx_resources(&adapter->tx_ring[i]);
2522} 2519}
2523 2520
2524static void igb_unmap_and_free_tx_resource(struct igb_ring *tx_ring, 2521void igb_unmap_and_free_tx_resource(struct igb_ring *tx_ring,
2525 struct igb_buffer *buffer_info) 2522 struct igb_buffer *buffer_info)
2526{ 2523{
2527 buffer_info->dma = 0; 2524 buffer_info->dma = 0;
2528 if (buffer_info->skb) { 2525 if (buffer_info->skb) {
@@ -3585,8 +3582,8 @@ static int igb_maybe_stop_tx(struct igb_ring *tx_ring, int size)
3585 return __igb_maybe_stop_tx(tx_ring, size); 3582 return __igb_maybe_stop_tx(tx_ring, size);
3586} 3583}
3587 3584
3588static netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb, 3585netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb,
3589 struct igb_ring *tx_ring) 3586 struct igb_ring *tx_ring)
3590{ 3587{
3591 struct igb_adapter *adapter = netdev_priv(tx_ring->netdev); 3588 struct igb_adapter *adapter = netdev_priv(tx_ring->netdev);
3592 unsigned int first; 3589 unsigned int first;
@@ -3596,16 +3593,6 @@ static netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb,
3596 int tso = 0; 3593 int tso = 0;
3597 union skb_shared_tx *shtx; 3594 union skb_shared_tx *shtx;
3598 3595
3599 if (test_bit(__IGB_DOWN, &adapter->state)) {
3600 dev_kfree_skb_any(skb);
3601 return NETDEV_TX_OK;
3602 }
3603
3604 if (skb->len <= 0) {
3605 dev_kfree_skb_any(skb);
3606 return NETDEV_TX_OK;
3607 }
3608
3609 /* need: 1 descriptor per page, 3596 /* need: 1 descriptor per page,
3610 * + 2 desc gap to keep tail from touching head, 3597 * + 2 desc gap to keep tail from touching head,
3611 * + 1 desc for skb->data, 3598 * + 1 desc for skb->data,
@@ -3680,8 +3667,18 @@ static netdev_tx_t igb_xmit_frame_adv(struct sk_buff *skb,
3680{ 3667{
3681 struct igb_adapter *adapter = netdev_priv(netdev); 3668 struct igb_adapter *adapter = netdev_priv(netdev);
3682 struct igb_ring *tx_ring; 3669 struct igb_ring *tx_ring;
3683
3684 int r_idx = 0; 3670 int r_idx = 0;
3671
3672 if (test_bit(__IGB_DOWN, &adapter->state)) {
3673 dev_kfree_skb_any(skb);
3674 return NETDEV_TX_OK;
3675 }
3676
3677 if (skb->len <= 0) {
3678 dev_kfree_skb_any(skb);
3679 return NETDEV_TX_OK;
3680 }
3681
3685 r_idx = skb->queue_mapping & (IGB_ABS_MAX_TX_QUEUES - 1); 3682 r_idx = skb->queue_mapping & (IGB_ABS_MAX_TX_QUEUES - 1);
3686 tx_ring = adapter->multi_tx_table[r_idx]; 3683 tx_ring = adapter->multi_tx_table[r_idx];
3687 3684