---- linux-2.6.24/drivers/net/cpmac.c 2008-01-25 02:20:37.000000000 +0100
-+++ linux-2.6.24/drivers/net/cpmac.c 2008-02-08 20:04:58.000000000 +0100
+--- /usr/src/linux-2.6.24/drivers/net/cpmac.c 2008-01-25 02:20:37.000000000 +0100
++++ cpmac.c 2008-04-06 21:30:03.000000000 +0200
@@ -38,6 +38,7 @@
#include <linux/platform_device.h>
#include <linux/dma-mapping.h>
@@ -38,6 +38,7 @@
#include <linux/platform_device.h>
#include <linux/dma-mapping.h>
struct cpmac_priv *priv =
container_of(work, struct cpmac_priv, reset_work);
struct cpmac_priv *priv =
container_of(work, struct cpmac_priv, reset_work);
spin_unlock(&priv->rx_lock);
cpmac_clear_tx(priv->dev);
cpmac_hw_start(priv->dev);
spin_unlock(&priv->rx_lock);
cpmac_clear_tx(priv->dev);
cpmac_hw_start(priv->dev);
+- napi_enable(&priv->napi);
+- netif_start_queue(priv->dev);
+ barrier();
+ atomic_dec(&priv->reset_pending);
+
+ barrier();
+ atomic_dec(&priv->reset_pending);
+
+ netif_wake_subqueue(priv->dev, i);
+ }
+ netif_wake_queue(priv->dev);
+ netif_wake_subqueue(priv->dev, i);
+ }
+ netif_wake_queue(priv->dev);
++ cpmac_write(priv->regs, CPMAC_MAC_INT_ENABLE, 3);
+}
+
+static void cpmac_check_status(struct net_device *dev)
+}
+
+static void cpmac_check_status(struct net_device *dev)
+ netif_stop_queue(dev);
+ cpmac_hw_stop(dev);
+ if (schedule_work(&priv->reset_work))
+ netif_stop_queue(dev);
+ cpmac_hw_stop(dev);
+ if (schedule_work(&priv->reset_work))
-+ atomic_inc(&priv->reset_pending);
++ atomic_inc(&priv->reset_pending);
+ if (unlikely(netif_msg_hw(priv)))
+ cpmac_dump_regs(dev);
+ }
+ if (unlikely(netif_msg_hw(priv)))
+ cpmac_dump_regs(dev);
+ }
- napi_enable(&priv->napi);
-- netif_start_queue(priv->dev);
++ cpmac_write(priv->regs, CPMAC_MAC_INT_CLEAR, 0xff);
}
static irqreturn_t cpmac_irq(int irq, void *dev_id)
}
static irqreturn_t cpmac_irq(int irq, void *dev_id)
priv = netdev_priv(dev);
status = cpmac_read(priv->regs, CPMAC_MAC_INT_VECTOR);
priv = netdev_priv(dev);
status = cpmac_read(priv->regs, CPMAC_MAC_INT_VECTOR);
cpmac_write(priv->regs, CPMAC_MAC_EOI_VECTOR, 0);
cpmac_write(priv->regs, CPMAC_MAC_EOI_VECTOR, 0);
}
static int cpmac_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
}
static int cpmac_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
spin_unlock(&priv->lock);
}
spin_unlock(&priv->lock);
}
static int cpmac_open(struct net_device *dev)
{
int i, size, res;
static int cpmac_open(struct net_device *dev)
{
int i, size, res;
INIT_WORK(&priv->reset_work, cpmac_hw_error);
cpmac_hw_start(dev);
INIT_WORK(&priv->reset_work, cpmac_hw_error);
cpmac_hw_start(dev);
static int __devinit cpmac_probe(struct platform_device *pdev)
{
int rc, phy_id, i;
static int __devinit cpmac_probe(struct platform_device *pdev)
{
int rc, phy_id, i;
DECLARE_MAC_BUF(mac);
pdata = pdev->dev.platform_data;
DECLARE_MAC_BUF(mac);
pdata = pdev->dev.platform_data;
}
if (phy_id == PHY_MAX_ADDR) {
}
if (phy_id == PHY_MAX_ADDR) {
printk(KERN_ERR "cpmac: no PHY present\n");
return -ENODEV;
}
printk(KERN_ERR "cpmac: no PHY present\n");
return -ENODEV;
}
priv->msg_enable = netif_msg_init(debug_level, 0xff);
memcpy(dev->dev_addr, pdata->dev_addr, sizeof(dev->dev_addr));
priv->msg_enable = netif_msg_init(debug_level, 0xff);
memcpy(dev->dev_addr, pdata->dev_addr, sizeof(dev->dev_addr));