summaryrefslogtreecommitdiffstats
path: root/drivers/net/sis190.c
diff options
context:
space:
mode:
authorFrancois Romieu <romieu@fr.zoreil.com>2005-07-30 13:09:20 +0200
committerJeff Garzik <jgarzik@pobox.com>2005-07-31 00:20:59 +0200
commit4405d3b5ef0a870e8d70ee4a3d050c89fcc40a86 (patch)
tree1948cc6cd7acdee92a837ecd452d0c16c88e9267 /drivers/net/sis190.c
parent[PATCH] sis190: resurrection (diff)
downloadlinux-4405d3b5ef0a870e8d70ee4a3d050c89fcc40a86.tar.xz
linux-4405d3b5ef0a870e8d70ee4a3d050c89fcc40a86.zip
[PATCH] sis190: netconsole support.
netconsole support. This stuff should be factored out of every driver. Signed-off-by: Francois Romieu <romieu@fr.zoreil.com> Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/net/sis190.c')
-rw-r--r--drivers/net/sis190.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/drivers/net/sis190.c b/drivers/net/sis190.c
index fd303e7408ac..e374cf43fed0 100644
--- a/drivers/net/sis190.c
+++ b/drivers/net/sis190.c
@@ -629,6 +629,18 @@ out:
return IRQ_RETVAL(handled);
}
+#ifdef CONFIG_NET_POLL_CONTROLLER
+static void sis190_netpoll(struct net_device *dev)
+{
+ struct sis190_private *tp = netdev_priv(dev);
+ struct pci_dev *pdev = tp->pci_dev;
+
+ disable_irq(pdev->irq);
+ sis190_interrupt(pdev->irq, dev, NULL);
+ enable_irq(pdev->irq);
+}
+#endif
+
static void sis190_free_rx_skb(struct sis190_private *tp,
struct sk_buff **sk_buff, struct RxDesc *desc)
{
@@ -1300,6 +1312,9 @@ static int __devinit sis190_init_one(struct pci_dev *pdev,
dev->tx_timeout = sis190_tx_timeout;
dev->watchdog_timeo = SIS190_TX_TIMEOUT;
dev->hard_start_xmit = sis190_start_xmit;
+#ifdef CONFIG_NET_POLL_CONTROLLER
+ dev->poll_controller = sis190_netpoll;
+#endif
dev->set_multicast_list = sis190_set_rx_mode;
SET_ETHTOOL_OPS(dev, &sis190_ethtool_ops);
dev->irq = pdev->irq;