diff options
Diffstat (limited to 'drivers/net/ethernet/rdc/r6040.c')
| -rw-r--r-- | drivers/net/ethernet/rdc/r6040.c | 12 | 
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/net/ethernet/rdc/r6040.c b/drivers/net/ethernet/rdc/r6040.c index 5b4103db70f..e9dc84943cf 100644 --- a/drivers/net/ethernet/rdc/r6040.c +++ b/drivers/net/ethernet/rdc/r6040.c @@ -224,11 +224,14 @@ static int r6040_phy_read(void __iomem *ioaddr, int phy_addr, int reg)  			break;  	} +	if (limit < 0) +		return -ETIMEDOUT; +  	return ioread16(ioaddr + MMRD);  }  /* Write a word data from PHY Chip */ -static void r6040_phy_write(void __iomem *ioaddr, +static int r6040_phy_write(void __iomem *ioaddr,  					int phy_addr, int reg, u16 val)  {  	int limit = MAC_DEF_TIMEOUT; @@ -243,6 +246,8 @@ static void r6040_phy_write(void __iomem *ioaddr,  		if (!(cmd & MDIO_WRITE))  			break;  	} + +	return (limit < 0) ? -ETIMEDOUT : 0;  }  static int r6040_mdiobus_read(struct mii_bus *bus, int phy_addr, int reg) @@ -261,9 +266,7 @@ static int r6040_mdiobus_write(struct mii_bus *bus, int phy_addr,  	struct r6040_private *lp = netdev_priv(dev);  	void __iomem *ioaddr = lp->base; -	r6040_phy_write(ioaddr, phy_addr, reg, value); - -	return 0; +	return r6040_phy_write(ioaddr, phy_addr, reg, value);  }  static int r6040_mdiobus_reset(struct mii_bus *bus) @@ -347,7 +350,6 @@ static int r6040_alloc_rxbufs(struct net_device *dev)  	do {  		skb = netdev_alloc_skb(dev, MAX_BUF_SIZE);  		if (!skb) { -			netdev_err(dev, "failed to alloc skb for rx\n");  			rc = -ENOMEM;  			goto err_exit;  		}  |