net/fsl: remove hardcoded clock setting from xgmac_mdio
authorShaohui Xie <Shaohui.Xie@freescale.com>
Tue, 30 Dec 2014 08:28:21 +0000 (16:28 +0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 2 Jan 2015 20:39:49 +0000 (15:39 -0500)
There is no need to set the clock speed in read/write which will be performed
unnecessarily for each mdio access. Init it during probe is enough.

Also, the hardcoded clock value is not a proper way for all SoCs.

Signed-off-by: Shaohui Xie <Shaohui.Xie@freescale.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/freescale/xgmac_mdio.c

index 9de526891da0040df6c833a882a45a047f08abaf..a35244586a631684fc6eb4b33fd8ec7f3935c149 100644 (file)
@@ -94,13 +94,6 @@ static int xgmac_mdio_write(struct mii_bus *bus, int phy_id, int regnum, u16 val
        uint16_t dev_addr = regnum >> 16;
        int ret;
 
-       /* Setup the MII Mgmt clock speed */
-       out_be32(&regs->mdio_stat, MDIO_STAT_CLKDIV(100));
-
-       ret = xgmac_wait_until_free(&bus->dev, regs);
-       if (ret)
-               return ret;
-
        /* Set the port and dev addr */
        out_be32(&regs->mdio_ctl,
                 MDIO_CTL_PORT_ADDR(phy_id) | MDIO_CTL_DEV_ADDR(dev_addr));
@@ -135,13 +128,6 @@ static int xgmac_mdio_read(struct mii_bus *bus, int phy_id, int regnum)
        uint16_t value;
        int ret;
 
-       /* Setup the MII Mgmt clock speed */
-       out_be32(&regs->mdio_stat, MDIO_STAT_CLKDIV(100));
-
-       ret = xgmac_wait_until_free(&bus->dev, regs);
-       if (ret)
-               return ret;
-
        /* Set the Port and Device Addrs */
        mdio_ctl = MDIO_CTL_PORT_ADDR(phy_id) | MDIO_CTL_DEV_ADDR(dev_addr);
        out_be32(&regs->mdio_ctl, mdio_ctl);