diff options
Diffstat (limited to 'drivers/net/gianfar.c')
| -rw-r--r-- | drivers/net/gianfar.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 1b8deca8b9f8..ea530673236e 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
| @@ -296,6 +296,20 @@ err_out: | |||
| 296 | return err; | 296 | return err; |
| 297 | } | 297 | } |
| 298 | 298 | ||
| 299 | /* Ioctl MII Interface */ | ||
| 300 | static int gfar_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) | ||
| 301 | { | ||
| 302 | struct gfar_private *priv = netdev_priv(dev); | ||
| 303 | |||
| 304 | if (!netif_running(dev)) | ||
| 305 | return -EINVAL; | ||
| 306 | |||
| 307 | if (!priv->phydev) | ||
| 308 | return -ENODEV; | ||
| 309 | |||
| 310 | return phy_mii_ioctl(priv->phydev, if_mii(rq), cmd); | ||
| 311 | } | ||
| 312 | |||
| 299 | /* Set up the ethernet device structure, private data, | 313 | /* Set up the ethernet device structure, private data, |
| 300 | * and anything else we need before we start */ | 314 | * and anything else we need before we start */ |
| 301 | static int gfar_probe(struct of_device *ofdev, | 315 | static int gfar_probe(struct of_device *ofdev, |
| @@ -366,6 +380,7 @@ static int gfar_probe(struct of_device *ofdev, | |||
| 366 | dev->set_multicast_list = gfar_set_multi; | 380 | dev->set_multicast_list = gfar_set_multi; |
| 367 | 381 | ||
| 368 | dev->ethtool_ops = &gfar_ethtool_ops; | 382 | dev->ethtool_ops = &gfar_ethtool_ops; |
| 383 | dev->do_ioctl = gfar_ioctl; | ||
| 369 | 384 | ||
| 370 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_CSUM) { | 385 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_CSUM) { |
| 371 | priv->rx_csum_enable = 1; | 386 | priv->rx_csum_enable = 1; |
| @@ -1607,10 +1622,18 @@ static int gfar_clean_tx_ring(struct net_device *dev) | |||
| 1607 | static void gfar_schedule_cleanup(struct net_device *dev) | 1622 | static void gfar_schedule_cleanup(struct net_device *dev) |
| 1608 | { | 1623 | { |
| 1609 | struct gfar_private *priv = netdev_priv(dev); | 1624 | struct gfar_private *priv = netdev_priv(dev); |
| 1625 | unsigned long flags; | ||
| 1626 | |||
| 1627 | spin_lock_irqsave(&priv->txlock, flags); | ||
| 1628 | spin_lock(&priv->rxlock); | ||
| 1629 | |||
| 1610 | if (netif_rx_schedule_prep(&priv->napi)) { | 1630 | if (netif_rx_schedule_prep(&priv->napi)) { |
| 1611 | gfar_write(&priv->regs->imask, IMASK_RTX_DISABLED); | 1631 | gfar_write(&priv->regs->imask, IMASK_RTX_DISABLED); |
| 1612 | __netif_rx_schedule(&priv->napi); | 1632 | __netif_rx_schedule(&priv->napi); |
| 1613 | } | 1633 | } |
| 1634 | |||
| 1635 | spin_unlock(&priv->rxlock); | ||
| 1636 | spin_unlock_irqrestore(&priv->txlock, flags); | ||
| 1614 | } | 1637 | } |
| 1615 | 1638 | ||
| 1616 | /* Interrupt Handler for Transmit complete */ | 1639 | /* Interrupt Handler for Transmit complete */ |
