<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;"> 25-akpm/drivers/net/eepro100.c |   22 ++++++++++++++++++++++
 1 files changed, 22 insertions(+)

diff -puN drivers/net/eepro100.c~eepro100-poll-controller drivers/net/eepro100.c
--- 25/drivers/net/eepro100.c~eepro100-poll-controller	Wed Oct 15 13:17:50 2003
+++ 25-akpm/drivers/net/eepro100.c	Wed Oct 15 13:17:50 2003
@@ -543,6 +543,9 @@ static void speedo_refill_rx_buffers(str
 static int speedo_rx(struct net_device *dev);
 static void speedo_tx_buffer_gc(struct net_device *dev);
 static irqreturn_t speedo_interrupt(int irq, void *dev_instance, struct pt_regs *regs);
+#ifdef CONFIG_NET_POLL_CONTROLLER
+static void poll_speedo (struct net_device *dev);
+#endif
 static int speedo_close(struct net_device *dev);
 static struct net_device_stats *speedo_get_stats(struct net_device *dev);
 static int speedo_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
@@ -885,6 +888,9 @@ static int __devinit speedo_found1(struc
 	dev-&gt;get_stats = &amp;speedo_get_stats;
 	dev-&gt;set_multicast_list = &amp;set_rx_mode;
 	dev-&gt;do_ioctl = &amp;speedo_ioctl;
+#ifdef CONFIG_NET_POLL_CONTROLLER
+	dev-&gt;poll_controller = &amp;poll_speedo;
+#endif
 
 	if (register_netdevice(dev))
 		goto err_free_unlock;
@@ -1675,6 +1681,22 @@ static irqreturn_t speedo_interrupt(int 
 	return IRQ_RETVAL(handled);
 }
 
+#ifdef CONFIG_NET_POLL_CONTROLLER
+
+/*
+ * Polling 'interrupt' - used by things like netconsole to send skbs
+ * without having to re-enable interrupts. It's not called while
+ * the interrupt routine is executing.
+ */
+
+static void poll_speedo (struct net_device *dev)
+{
+	disable_irq(dev-&gt;irq);
+	speedo_interrupt (dev-&gt;irq, dev, NULL);
+	enable_irq(dev-&gt;irq);
+}
+#endif
+
 static inline struct RxFD *speedo_rx_alloc(struct net_device *dev, int entry)
 {
 	struct speedo_private *sp = (struct speedo_private *)dev-&gt;priv;

_
</pre></body></html>