e1000: delete non NAPI code from the driver
Compile-tested only. Signed-off-by: Francois Romieu <romieu@fr.zoreil.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com> Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
This commit is contained in:
parent
63cd31f607
commit
c3570acb53
4 changed files with 16 additions and 173 deletions
|
@ -513,21 +513,11 @@ Additional Configurations
|
||||||
Intel(R) PRO/1000 PT Dual Port Server Connection
|
Intel(R) PRO/1000 PT Dual Port Server Connection
|
||||||
Intel(R) PRO/1000 PT Dual Port Server Adapter
|
Intel(R) PRO/1000 PT Dual Port Server Adapter
|
||||||
Intel(R) PRO/1000 PF Dual Port Server Adapter
|
Intel(R) PRO/1000 PF Dual Port Server Adapter
|
||||||
Intel(R) PRO/1000 PT Quad Port Server Adapter
|
Intel(R) PRO/1000 PT Quad Port Server Adapter
|
||||||
|
|
||||||
NAPI
|
NAPI
|
||||||
----
|
----
|
||||||
NAPI (Rx polling mode) is supported in the e1000 driver. NAPI is enabled
|
NAPI (Rx polling mode) is enabled in the e1000 driver.
|
||||||
or disabled based on the configuration of the kernel. To override
|
|
||||||
the default, use the following compile-time flags.
|
|
||||||
|
|
||||||
To enable NAPI, compile the driver module, passing in a configuration option:
|
|
||||||
|
|
||||||
make CFLAGS_EXTRA=-DE1000_NAPI install
|
|
||||||
|
|
||||||
To disable NAPI, compile the driver module, passing in a configuration option:
|
|
||||||
|
|
||||||
make CFLAGS_EXTRA=-DE1000_NO_NAPI install
|
|
||||||
|
|
||||||
See www.cyberus.ca/~hadi/usenix-paper.tgz for more information on NAPI.
|
See www.cyberus.ca/~hadi/usenix-paper.tgz for more information on NAPI.
|
||||||
|
|
||||||
|
|
|
@ -1926,20 +1926,6 @@ config E1000
|
||||||
To compile this driver as a module, choose M here. The module
|
To compile this driver as a module, choose M here. The module
|
||||||
will be called e1000.
|
will be called e1000.
|
||||||
|
|
||||||
config E1000_NAPI
|
|
||||||
bool "Use Rx Polling (NAPI)"
|
|
||||||
depends on E1000
|
|
||||||
help
|
|
||||||
NAPI is a new driver API designed to reduce CPU and interrupt load
|
|
||||||
when the driver is receiving lots of packets from the card. It is
|
|
||||||
still somewhat experimental and thus not yet enabled by default.
|
|
||||||
|
|
||||||
If your estimated Rx load is 10kpps or more, or if the card will be
|
|
||||||
deployed on potentially unfriendly networks (e.g. in a firewall),
|
|
||||||
then say Y here.
|
|
||||||
|
|
||||||
If in doubt, say N.
|
|
||||||
|
|
||||||
config E1000_DISABLE_PACKET_SPLIT
|
config E1000_DISABLE_PACKET_SPLIT
|
||||||
bool "Disable Packet Split for PCI express adapters"
|
bool "Disable Packet Split for PCI express adapters"
|
||||||
depends on E1000
|
depends on E1000
|
||||||
|
|
|
@ -253,9 +253,7 @@ struct e1000_adapter {
|
||||||
u16 link_speed;
|
u16 link_speed;
|
||||||
u16 link_duplex;
|
u16 link_duplex;
|
||||||
spinlock_t stats_lock;
|
spinlock_t stats_lock;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
spinlock_t tx_queue_lock;
|
spinlock_t tx_queue_lock;
|
||||||
#endif
|
|
||||||
unsigned int total_tx_bytes;
|
unsigned int total_tx_bytes;
|
||||||
unsigned int total_tx_packets;
|
unsigned int total_tx_packets;
|
||||||
unsigned int total_rx_bytes;
|
unsigned int total_rx_bytes;
|
||||||
|
@ -293,22 +291,16 @@ struct e1000_adapter {
|
||||||
bool detect_tx_hung;
|
bool detect_tx_hung;
|
||||||
|
|
||||||
/* RX */
|
/* RX */
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
bool (*clean_rx)(struct e1000_adapter *adapter,
|
bool (*clean_rx)(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int *work_done, int work_to_do);
|
int *work_done, int work_to_do);
|
||||||
#else
|
|
||||||
bool (*clean_rx)(struct e1000_adapter *adapter,
|
|
||||||
struct e1000_rx_ring *rx_ring);
|
|
||||||
#endif
|
|
||||||
void (*alloc_rx_buf)(struct e1000_adapter *adapter,
|
void (*alloc_rx_buf)(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int cleaned_count);
|
int cleaned_count);
|
||||||
struct e1000_rx_ring *rx_ring; /* One per active queue */
|
struct e1000_rx_ring *rx_ring; /* One per active queue */
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
struct napi_struct napi;
|
struct napi_struct napi;
|
||||||
struct net_device *polling_netdev; /* One per active queue */
|
struct net_device *polling_netdev; /* One per active queue */
|
||||||
#endif
|
|
||||||
int num_tx_queues;
|
int num_tx_queues;
|
||||||
int num_rx_queues;
|
int num_rx_queues;
|
||||||
|
|
||||||
|
|
|
@ -31,12 +31,7 @@
|
||||||
|
|
||||||
char e1000_driver_name[] = "e1000";
|
char e1000_driver_name[] = "e1000";
|
||||||
static char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver";
|
static char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver";
|
||||||
#ifndef CONFIG_E1000_NAPI
|
#define DRV_VERSION "7.3.20-k3-NAPI"
|
||||||
#define DRIVERNAPI
|
|
||||||
#else
|
|
||||||
#define DRIVERNAPI "-NAPI"
|
|
||||||
#endif
|
|
||||||
#define DRV_VERSION "7.3.20-k2"DRIVERNAPI
|
|
||||||
const char e1000_driver_version[] = DRV_VERSION;
|
const char e1000_driver_version[] = DRV_VERSION;
|
||||||
static const char e1000_copyright[] = "Copyright (c) 1999-2006 Intel Corporation.";
|
static const char e1000_copyright[] = "Copyright (c) 1999-2006 Intel Corporation.";
|
||||||
|
|
||||||
|
@ -138,7 +133,6 @@ static irqreturn_t e1000_intr(int irq, void *data);
|
||||||
static irqreturn_t e1000_intr_msi(int irq, void *data);
|
static irqreturn_t e1000_intr_msi(int irq, void *data);
|
||||||
static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
||||||
struct e1000_tx_ring *tx_ring);
|
struct e1000_tx_ring *tx_ring);
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
static int e1000_clean(struct napi_struct *napi, int budget);
|
static int e1000_clean(struct napi_struct *napi, int budget);
|
||||||
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
|
@ -146,12 +140,6 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int *work_done, int work_to_do);
|
int *work_done, int work_to_do);
|
||||||
#else
|
|
||||||
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
|
||||||
struct e1000_rx_ring *rx_ring);
|
|
||||||
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
|
||||||
struct e1000_rx_ring *rx_ring);
|
|
||||||
#endif
|
|
||||||
static void e1000_alloc_rx_buffers(struct e1000_adapter *adapter,
|
static void e1000_alloc_rx_buffers(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int cleaned_count);
|
int cleaned_count);
|
||||||
|
@ -512,9 +500,8 @@ int e1000_up(struct e1000_adapter *adapter)
|
||||||
|
|
||||||
clear_bit(__E1000_DOWN, &adapter->flags);
|
clear_bit(__E1000_DOWN, &adapter->flags);
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
napi_enable(&adapter->napi);
|
napi_enable(&adapter->napi);
|
||||||
#endif
|
|
||||||
e1000_irq_enable(adapter);
|
e1000_irq_enable(adapter);
|
||||||
|
|
||||||
/* fire a link change interrupt to start the watchdog */
|
/* fire a link change interrupt to start the watchdog */
|
||||||
|
@ -602,9 +589,8 @@ void e1000_down(struct e1000_adapter *adapter)
|
||||||
* reschedule our watchdog timer */
|
* reschedule our watchdog timer */
|
||||||
set_bit(__E1000_DOWN, &adapter->flags);
|
set_bit(__E1000_DOWN, &adapter->flags);
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
napi_disable(&adapter->napi);
|
napi_disable(&adapter->napi);
|
||||||
#endif
|
|
||||||
e1000_irq_disable(adapter);
|
e1000_irq_disable(adapter);
|
||||||
|
|
||||||
del_timer_sync(&adapter->tx_fifo_stall_timer);
|
del_timer_sync(&adapter->tx_fifo_stall_timer);
|
||||||
|
@ -966,9 +952,7 @@ static int __devinit e1000_probe(struct pci_dev *pdev,
|
||||||
e1000_set_ethtool_ops(netdev);
|
e1000_set_ethtool_ops(netdev);
|
||||||
netdev->tx_timeout = &e1000_tx_timeout;
|
netdev->tx_timeout = &e1000_tx_timeout;
|
||||||
netdev->watchdog_timeo = 5 * HZ;
|
netdev->watchdog_timeo = 5 * HZ;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
netif_napi_add(netdev, &adapter->napi, e1000_clean, 64);
|
netif_napi_add(netdev, &adapter->napi, e1000_clean, 64);
|
||||||
#endif
|
|
||||||
netdev->vlan_rx_register = e1000_vlan_rx_register;
|
netdev->vlan_rx_register = e1000_vlan_rx_register;
|
||||||
netdev->vlan_rx_add_vid = e1000_vlan_rx_add_vid;
|
netdev->vlan_rx_add_vid = e1000_vlan_rx_add_vid;
|
||||||
netdev->vlan_rx_kill_vid = e1000_vlan_rx_kill_vid;
|
netdev->vlan_rx_kill_vid = e1000_vlan_rx_kill_vid;
|
||||||
|
@ -1207,16 +1191,12 @@ static int __devinit e1000_probe(struct pci_dev *pdev,
|
||||||
if (hw->flash_address)
|
if (hw->flash_address)
|
||||||
iounmap(hw->flash_address);
|
iounmap(hw->flash_address);
|
||||||
err_flashmap:
|
err_flashmap:
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
for (i = 0; i < adapter->num_rx_queues; i++)
|
for (i = 0; i < adapter->num_rx_queues; i++)
|
||||||
dev_put(&adapter->polling_netdev[i]);
|
dev_put(&adapter->polling_netdev[i]);
|
||||||
#endif
|
|
||||||
|
|
||||||
kfree(adapter->tx_ring);
|
kfree(adapter->tx_ring);
|
||||||
kfree(adapter->rx_ring);
|
kfree(adapter->rx_ring);
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
kfree(adapter->polling_netdev);
|
kfree(adapter->polling_netdev);
|
||||||
#endif
|
|
||||||
err_sw_init:
|
err_sw_init:
|
||||||
iounmap(hw->hw_addr);
|
iounmap(hw->hw_addr);
|
||||||
err_ioremap:
|
err_ioremap:
|
||||||
|
@ -1244,9 +1224,7 @@ static void __devexit e1000_remove(struct pci_dev *pdev)
|
||||||
struct net_device *netdev = pci_get_drvdata(pdev);
|
struct net_device *netdev = pci_get_drvdata(pdev);
|
||||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
int i;
|
int i;
|
||||||
#endif
|
|
||||||
|
|
||||||
cancel_work_sync(&adapter->reset_task);
|
cancel_work_sync(&adapter->reset_task);
|
||||||
|
|
||||||
|
@ -1256,10 +1234,8 @@ static void __devexit e1000_remove(struct pci_dev *pdev)
|
||||||
* would have already happened in close and is redundant. */
|
* would have already happened in close and is redundant. */
|
||||||
e1000_release_hw_control(adapter);
|
e1000_release_hw_control(adapter);
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
for (i = 0; i < adapter->num_rx_queues; i++)
|
for (i = 0; i < adapter->num_rx_queues; i++)
|
||||||
dev_put(&adapter->polling_netdev[i]);
|
dev_put(&adapter->polling_netdev[i]);
|
||||||
#endif
|
|
||||||
|
|
||||||
unregister_netdev(netdev);
|
unregister_netdev(netdev);
|
||||||
|
|
||||||
|
@ -1268,9 +1244,7 @@ static void __devexit e1000_remove(struct pci_dev *pdev)
|
||||||
|
|
||||||
kfree(adapter->tx_ring);
|
kfree(adapter->tx_ring);
|
||||||
kfree(adapter->rx_ring);
|
kfree(adapter->rx_ring);
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
kfree(adapter->polling_netdev);
|
kfree(adapter->polling_netdev);
|
||||||
#endif
|
|
||||||
|
|
||||||
iounmap(hw->hw_addr);
|
iounmap(hw->hw_addr);
|
||||||
if (hw->flash_address)
|
if (hw->flash_address)
|
||||||
|
@ -1296,9 +1270,7 @@ static int __devinit e1000_sw_init(struct e1000_adapter *adapter)
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
struct net_device *netdev = adapter->netdev;
|
struct net_device *netdev = adapter->netdev;
|
||||||
struct pci_dev *pdev = adapter->pdev;
|
struct pci_dev *pdev = adapter->pdev;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
int i;
|
int i;
|
||||||
#endif
|
|
||||||
|
|
||||||
/* PCI config space info */
|
/* PCI config space info */
|
||||||
|
|
||||||
|
@ -1356,14 +1328,12 @@ static int __devinit e1000_sw_init(struct e1000_adapter *adapter)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
for (i = 0; i < adapter->num_rx_queues; i++) {
|
for (i = 0; i < adapter->num_rx_queues; i++) {
|
||||||
adapter->polling_netdev[i].priv = adapter;
|
adapter->polling_netdev[i].priv = adapter;
|
||||||
dev_hold(&adapter->polling_netdev[i]);
|
dev_hold(&adapter->polling_netdev[i]);
|
||||||
set_bit(__LINK_STATE_START, &adapter->polling_netdev[i].state);
|
set_bit(__LINK_STATE_START, &adapter->polling_netdev[i].state);
|
||||||
}
|
}
|
||||||
spin_lock_init(&adapter->tx_queue_lock);
|
spin_lock_init(&adapter->tx_queue_lock);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Explicitly disable IRQ since the NIC can be in any state. */
|
/* Explicitly disable IRQ since the NIC can be in any state. */
|
||||||
e1000_irq_disable(adapter);
|
e1000_irq_disable(adapter);
|
||||||
|
@ -1398,7 +1368,6 @@ static int __devinit e1000_alloc_queues(struct e1000_adapter *adapter)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
adapter->polling_netdev = kcalloc(adapter->num_rx_queues,
|
adapter->polling_netdev = kcalloc(adapter->num_rx_queues,
|
||||||
sizeof(struct net_device),
|
sizeof(struct net_device),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
|
@ -1407,7 +1376,6 @@ static int __devinit e1000_alloc_queues(struct e1000_adapter *adapter)
|
||||||
kfree(adapter->rx_ring);
|
kfree(adapter->rx_ring);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
return E1000_SUCCESS;
|
return E1000_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -1472,9 +1440,7 @@ static int e1000_open(struct net_device *netdev)
|
||||||
/* From here on the code is the same as e1000_up() */
|
/* From here on the code is the same as e1000_up() */
|
||||||
clear_bit(__E1000_DOWN, &adapter->flags);
|
clear_bit(__E1000_DOWN, &adapter->flags);
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
napi_enable(&adapter->napi);
|
napi_enable(&adapter->napi);
|
||||||
#endif
|
|
||||||
|
|
||||||
e1000_irq_enable(adapter);
|
e1000_irq_enable(adapter);
|
||||||
|
|
||||||
|
@ -2069,11 +2035,9 @@ static void e1000_configure_rx(struct e1000_adapter *adapter)
|
||||||
ctrl_ext = er32(CTRL_EXT);
|
ctrl_ext = er32(CTRL_EXT);
|
||||||
/* Reset delay timers after every interrupt */
|
/* Reset delay timers after every interrupt */
|
||||||
ctrl_ext |= E1000_CTRL_EXT_INT_TIMER_CLR;
|
ctrl_ext |= E1000_CTRL_EXT_INT_TIMER_CLR;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
/* Auto-Mask interrupts upon ICR access */
|
/* Auto-Mask interrupts upon ICR access */
|
||||||
ctrl_ext |= E1000_CTRL_EXT_IAME;
|
ctrl_ext |= E1000_CTRL_EXT_IAME;
|
||||||
ew32(IAM, 0xffffffff);
|
ew32(IAM, 0xffffffff);
|
||||||
#endif
|
|
||||||
ew32(CTRL_EXT, ctrl_ext);
|
ew32(CTRL_EXT, ctrl_ext);
|
||||||
E1000_WRITE_FLUSH();
|
E1000_WRITE_FLUSH();
|
||||||
}
|
}
|
||||||
|
@ -3777,9 +3741,6 @@ static irqreturn_t e1000_intr_msi(int irq, void *data)
|
||||||
struct net_device *netdev = data;
|
struct net_device *netdev = data;
|
||||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
#ifndef CONFIG_E1000_NAPI
|
|
||||||
int i;
|
|
||||||
#endif
|
|
||||||
u32 icr = er32(ICR);
|
u32 icr = er32(ICR);
|
||||||
|
|
||||||
/* in NAPI mode read ICR disables interrupts using IAM */
|
/* in NAPI mode read ICR disables interrupts using IAM */
|
||||||
|
@ -3800,7 +3761,6 @@ static irqreturn_t e1000_intr_msi(int irq, void *data)
|
||||||
mod_timer(&adapter->watchdog_timer, jiffies + 1);
|
mod_timer(&adapter->watchdog_timer, jiffies + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (likely(netif_rx_schedule_prep(netdev, &adapter->napi))) {
|
if (likely(netif_rx_schedule_prep(netdev, &adapter->napi))) {
|
||||||
adapter->total_tx_bytes = 0;
|
adapter->total_tx_bytes = 0;
|
||||||
adapter->total_tx_packets = 0;
|
adapter->total_tx_packets = 0;
|
||||||
|
@ -3809,20 +3769,6 @@ static irqreturn_t e1000_intr_msi(int irq, void *data)
|
||||||
__netif_rx_schedule(netdev, &adapter->napi);
|
__netif_rx_schedule(netdev, &adapter->napi);
|
||||||
} else
|
} else
|
||||||
e1000_irq_enable(adapter);
|
e1000_irq_enable(adapter);
|
||||||
#else
|
|
||||||
adapter->total_tx_bytes = 0;
|
|
||||||
adapter->total_rx_bytes = 0;
|
|
||||||
adapter->total_tx_packets = 0;
|
|
||||||
adapter->total_rx_packets = 0;
|
|
||||||
|
|
||||||
for (i = 0; i < E1000_MAX_INTR; i++)
|
|
||||||
if (unlikely(!adapter->clean_rx(adapter, adapter->rx_ring) &
|
|
||||||
!e1000_clean_tx_irq(adapter, adapter->tx_ring)))
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (likely(adapter->itr_setting & 3))
|
|
||||||
e1000_set_itr(adapter);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
@ -3839,13 +3785,10 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
||||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
u32 rctl, icr = er32(ICR);
|
u32 rctl, icr = er32(ICR);
|
||||||
#ifndef CONFIG_E1000_NAPI
|
|
||||||
int i;
|
|
||||||
#endif
|
|
||||||
if (unlikely(!icr))
|
if (unlikely(!icr))
|
||||||
return IRQ_NONE; /* Not our interrupt */
|
return IRQ_NONE; /* Not our interrupt */
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
/* IMS will not auto-mask if INT_ASSERTED is not set, and if it is
|
/* IMS will not auto-mask if INT_ASSERTED is not set, and if it is
|
||||||
* not set, then the adapter didn't send an interrupt */
|
* not set, then the adapter didn't send an interrupt */
|
||||||
if (unlikely(hw->mac_type >= e1000_82571 &&
|
if (unlikely(hw->mac_type >= e1000_82571 &&
|
||||||
|
@ -3854,7 +3797,6 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
||||||
|
|
||||||
/* Interrupt Auto-Mask...upon reading ICR, interrupts are masked. No
|
/* Interrupt Auto-Mask...upon reading ICR, interrupts are masked. No
|
||||||
* need for the IMC write */
|
* need for the IMC write */
|
||||||
#endif
|
|
||||||
|
|
||||||
if (unlikely(icr & (E1000_ICR_RXSEQ | E1000_ICR_LSC))) {
|
if (unlikely(icr & (E1000_ICR_RXSEQ | E1000_ICR_LSC))) {
|
||||||
hw->get_link_status = 1;
|
hw->get_link_status = 1;
|
||||||
|
@ -3874,7 +3816,6 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
||||||
mod_timer(&adapter->watchdog_timer, jiffies + 1);
|
mod_timer(&adapter->watchdog_timer, jiffies + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (unlikely(hw->mac_type < e1000_82571)) {
|
if (unlikely(hw->mac_type < e1000_82571)) {
|
||||||
/* disable interrupts, without the synchronize_irq bit */
|
/* disable interrupts, without the synchronize_irq bit */
|
||||||
ew32(IMC, ~0);
|
ew32(IMC, ~0);
|
||||||
|
@ -3890,46 +3831,14 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
||||||
/* this really should not happen! if it does it is basically a
|
/* this really should not happen! if it does it is basically a
|
||||||
* bug, but not a hard error, so enable ints and continue */
|
* bug, but not a hard error, so enable ints and continue */
|
||||||
e1000_irq_enable(adapter);
|
e1000_irq_enable(adapter);
|
||||||
#else
|
|
||||||
/* Writing IMC and IMS is needed for 82547.
|
|
||||||
* Due to Hub Link bus being occupied, an interrupt
|
|
||||||
* de-assertion message is not able to be sent.
|
|
||||||
* When an interrupt assertion message is generated later,
|
|
||||||
* two messages are re-ordered and sent out.
|
|
||||||
* That causes APIC to think 82547 is in de-assertion
|
|
||||||
* state, while 82547 is in assertion state, resulting
|
|
||||||
* in dead lock. Writing IMC forces 82547 into
|
|
||||||
* de-assertion state.
|
|
||||||
*/
|
|
||||||
if (hw->mac_type == e1000_82547 || hw->mac_type == e1000_82547_rev_2)
|
|
||||||
ew32(IMC, ~0);
|
|
||||||
|
|
||||||
adapter->total_tx_bytes = 0;
|
|
||||||
adapter->total_rx_bytes = 0;
|
|
||||||
adapter->total_tx_packets = 0;
|
|
||||||
adapter->total_rx_packets = 0;
|
|
||||||
|
|
||||||
for (i = 0; i < E1000_MAX_INTR; i++)
|
|
||||||
if (unlikely(!adapter->clean_rx(adapter, adapter->rx_ring) &
|
|
||||||
!e1000_clean_tx_irq(adapter, adapter->tx_ring)))
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (likely(adapter->itr_setting & 3))
|
|
||||||
e1000_set_itr(adapter);
|
|
||||||
|
|
||||||
if (hw->mac_type == e1000_82547 || hw->mac_type == e1000_82547_rev_2)
|
|
||||||
e1000_irq_enable(adapter);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
/**
|
/**
|
||||||
* e1000_clean - NAPI Rx polling callback
|
* e1000_clean - NAPI Rx polling callback
|
||||||
* @adapter: board private structure
|
* @adapter: board private structure
|
||||||
**/
|
**/
|
||||||
|
|
||||||
static int e1000_clean(struct napi_struct *napi, int budget)
|
static int e1000_clean(struct napi_struct *napi, int budget)
|
||||||
{
|
{
|
||||||
struct e1000_adapter *adapter = container_of(napi, struct e1000_adapter, napi);
|
struct e1000_adapter *adapter = container_of(napi, struct e1000_adapter, napi);
|
||||||
|
@ -3966,12 +3875,10 @@ static int e1000_clean(struct napi_struct *napi, int budget)
|
||||||
return work_done;
|
return work_done;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
/**
|
/**
|
||||||
* e1000_clean_tx_irq - Reclaim resources after transmit completes
|
* e1000_clean_tx_irq - Reclaim resources after transmit completes
|
||||||
* @adapter: board private structure
|
* @adapter: board private structure
|
||||||
**/
|
**/
|
||||||
|
|
||||||
static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
||||||
struct e1000_tx_ring *tx_ring)
|
struct e1000_tx_ring *tx_ring)
|
||||||
{
|
{
|
||||||
|
@ -3980,9 +3887,7 @@ static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
||||||
struct e1000_tx_desc *tx_desc, *eop_desc;
|
struct e1000_tx_desc *tx_desc, *eop_desc;
|
||||||
struct e1000_buffer *buffer_info;
|
struct e1000_buffer *buffer_info;
|
||||||
unsigned int i, eop;
|
unsigned int i, eop;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
unsigned int count = 0;
|
unsigned int count = 0;
|
||||||
#endif
|
|
||||||
bool cleaned = false;
|
bool cleaned = false;
|
||||||
unsigned int total_tx_bytes=0, total_tx_packets=0;
|
unsigned int total_tx_bytes=0, total_tx_packets=0;
|
||||||
|
|
||||||
|
@ -4014,11 +3919,10 @@ static bool e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
||||||
|
|
||||||
eop = tx_ring->buffer_info[i].next_to_watch;
|
eop = tx_ring->buffer_info[i].next_to_watch;
|
||||||
eop_desc = E1000_TX_DESC(*tx_ring, eop);
|
eop_desc = E1000_TX_DESC(*tx_ring, eop);
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
#define E1000_TX_WEIGHT 64
|
#define E1000_TX_WEIGHT 64
|
||||||
/* weight of a sort for tx, to avoid endless transmit cleanup */
|
/* weight of a sort for tx, to avoid endless transmit cleanup */
|
||||||
if (count++ == E1000_TX_WEIGHT) break;
|
if (count++ == E1000_TX_WEIGHT)
|
||||||
#endif
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
tx_ring->next_to_clean = i;
|
tx_ring->next_to_clean = i;
|
||||||
|
@ -4131,14 +4035,9 @@ static void e1000_rx_checksum(struct e1000_adapter *adapter, u32 status_err,
|
||||||
* e1000_clean_rx_irq - Send received data up the network stack; legacy
|
* e1000_clean_rx_irq - Send received data up the network stack; legacy
|
||||||
* @adapter: board private structure
|
* @adapter: board private structure
|
||||||
**/
|
**/
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int *work_done, int work_to_do)
|
int *work_done, int work_to_do)
|
||||||
#else
|
|
||||||
static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
|
||||||
struct e1000_rx_ring *rx_ring)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
struct net_device *netdev = adapter->netdev;
|
struct net_device *netdev = adapter->netdev;
|
||||||
|
@ -4161,11 +4060,10 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u8 status;
|
u8 status;
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (*work_done >= work_to_do)
|
if (*work_done >= work_to_do)
|
||||||
break;
|
break;
|
||||||
(*work_done)++;
|
(*work_done)++;
|
||||||
#endif
|
|
||||||
status = rx_desc->status;
|
status = rx_desc->status;
|
||||||
skb = buffer_info->skb;
|
skb = buffer_info->skb;
|
||||||
buffer_info->skb = NULL;
|
buffer_info->skb = NULL;
|
||||||
|
@ -4251,7 +4149,7 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
le16_to_cpu(rx_desc->csum), skb);
|
le16_to_cpu(rx_desc->csum), skb);
|
||||||
|
|
||||||
skb->protocol = eth_type_trans(skb, netdev);
|
skb->protocol = eth_type_trans(skb, netdev);
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (unlikely(adapter->vlgrp &&
|
if (unlikely(adapter->vlgrp &&
|
||||||
(status & E1000_RXD_STAT_VP))) {
|
(status & E1000_RXD_STAT_VP))) {
|
||||||
vlan_hwaccel_receive_skb(skb, adapter->vlgrp,
|
vlan_hwaccel_receive_skb(skb, adapter->vlgrp,
|
||||||
|
@ -4259,15 +4157,7 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
} else {
|
} else {
|
||||||
netif_receive_skb(skb);
|
netif_receive_skb(skb);
|
||||||
}
|
}
|
||||||
#else /* CONFIG_E1000_NAPI */
|
|
||||||
if (unlikely(adapter->vlgrp &&
|
|
||||||
(status & E1000_RXD_STAT_VP))) {
|
|
||||||
vlan_hwaccel_rx(skb, adapter->vlgrp,
|
|
||||||
le16_to_cpu(rx_desc->special));
|
|
||||||
} else {
|
|
||||||
netif_rx(skb);
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_E1000_NAPI */
|
|
||||||
netdev->last_rx = jiffies;
|
netdev->last_rx = jiffies;
|
||||||
|
|
||||||
next_desc:
|
next_desc:
|
||||||
|
@ -4301,14 +4191,9 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
||||||
* @adapter: board private structure
|
* @adapter: board private structure
|
||||||
**/
|
**/
|
||||||
|
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
||||||
struct e1000_rx_ring *rx_ring,
|
struct e1000_rx_ring *rx_ring,
|
||||||
int *work_done, int work_to_do)
|
int *work_done, int work_to_do)
|
||||||
#else
|
|
||||||
static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
|
||||||
struct e1000_rx_ring *rx_ring)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
union e1000_rx_desc_packet_split *rx_desc, *next_rxd;
|
union e1000_rx_desc_packet_split *rx_desc, *next_rxd;
|
||||||
struct net_device *netdev = adapter->netdev;
|
struct net_device *netdev = adapter->netdev;
|
||||||
|
@ -4331,11 +4216,11 @@ static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
||||||
while (staterr & E1000_RXD_STAT_DD) {
|
while (staterr & E1000_RXD_STAT_DD) {
|
||||||
ps_page = &rx_ring->ps_page[i];
|
ps_page = &rx_ring->ps_page[i];
|
||||||
ps_page_dma = &rx_ring->ps_page_dma[i];
|
ps_page_dma = &rx_ring->ps_page_dma[i];
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (unlikely(*work_done >= work_to_do))
|
if (unlikely(*work_done >= work_to_do))
|
||||||
break;
|
break;
|
||||||
(*work_done)++;
|
(*work_done)++;
|
||||||
#endif
|
|
||||||
skb = buffer_info->skb;
|
skb = buffer_info->skb;
|
||||||
|
|
||||||
/* in the packet split case this is header only */
|
/* in the packet split case this is header only */
|
||||||
|
@ -4437,21 +4322,14 @@ static bool e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
||||||
if (likely(rx_desc->wb.upper.header_status &
|
if (likely(rx_desc->wb.upper.header_status &
|
||||||
cpu_to_le16(E1000_RXDPS_HDRSTAT_HDRSP)))
|
cpu_to_le16(E1000_RXDPS_HDRSTAT_HDRSP)))
|
||||||
adapter->rx_hdr_split++;
|
adapter->rx_hdr_split++;
|
||||||
#ifdef CONFIG_E1000_NAPI
|
|
||||||
if (unlikely(adapter->vlgrp && (staterr & E1000_RXD_STAT_VP))) {
|
if (unlikely(adapter->vlgrp && (staterr & E1000_RXD_STAT_VP))) {
|
||||||
vlan_hwaccel_receive_skb(skb, adapter->vlgrp,
|
vlan_hwaccel_receive_skb(skb, adapter->vlgrp,
|
||||||
le16_to_cpu(rx_desc->wb.middle.vlan));
|
le16_to_cpu(rx_desc->wb.middle.vlan));
|
||||||
} else {
|
} else {
|
||||||
netif_receive_skb(skb);
|
netif_receive_skb(skb);
|
||||||
}
|
}
|
||||||
#else /* CONFIG_E1000_NAPI */
|
|
||||||
if (unlikely(adapter->vlgrp && (staterr & E1000_RXD_STAT_VP))) {
|
|
||||||
vlan_hwaccel_rx(skb, adapter->vlgrp,
|
|
||||||
le16_to_cpu(rx_desc->wb.middle.vlan));
|
|
||||||
} else {
|
|
||||||
netif_rx(skb);
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_E1000_NAPI */
|
|
||||||
netdev->last_rx = jiffies;
|
netdev->last_rx = jiffies;
|
||||||
|
|
||||||
next_desc:
|
next_desc:
|
||||||
|
@ -5218,9 +5096,6 @@ static void e1000_netpoll(struct net_device *netdev)
|
||||||
|
|
||||||
disable_irq(adapter->pdev->irq);
|
disable_irq(adapter->pdev->irq);
|
||||||
e1000_intr(adapter->pdev->irq, netdev);
|
e1000_intr(adapter->pdev->irq, netdev);
|
||||||
#ifndef CONFIG_E1000_NAPI
|
|
||||||
adapter->clean_rx(adapter, adapter->rx_ring);
|
|
||||||
#endif
|
|
||||||
enable_irq(adapter->pdev->irq);
|
enable_irq(adapter->pdev->irq);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue