Commit 7c5e37d7 authored by Arınç ÜNAL's avatar Arınç ÜNAL Committed by Paolo Abeni

net: dsa: mt7530: simplify core operations

The core_rmw() function calls core_read_mmd_indirect() to read the
requested register, and then calls core_write_mmd_indirect() to write the
requested value to the register. Because Clause 22 is used to access Clause
45 registers, some operations on core_write_mmd_indirect() are
unnecessarily run. Get rid of core_read_mmd_indirect() and
core_write_mmd_indirect(), and run only the necessary operations on
core_write() and core_rmw().
Reviewed-by: default avatarDaniel Golle <daniel@makrotopia.org>
Tested-by: default avatarDaniel Golle <daniel@makrotopia.org>
Signed-off-by: default avatarArınç ÜNAL <arinc.unal@arinc9.com>
Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent 868ff5f4
...@@ -74,116 +74,94 @@ static const struct mt7530_mib_desc mt7530_mib[] = { ...@@ -74,116 +74,94 @@ static const struct mt7530_mib_desc mt7530_mib[] = {
MIB_DESC(1, 0xb8, "RxArlDrop"), MIB_DESC(1, 0xb8, "RxArlDrop"),
}; };
/* Since phy_device has not yet been created and static void
* phy_{read,write}_mmd_indirect is not available, we provide our own mt7530_mutex_lock(struct mt7530_priv *priv)
* core_{read,write}_mmd_indirect with core_{clear,write,set} wrappers {
* to complete this function. if (priv->bus)
*/ mutex_lock_nested(&priv->bus->mdio_lock, MDIO_MUTEX_NESTED);
static int }
core_read_mmd_indirect(struct mt7530_priv *priv, int prtad, int devad)
static void
mt7530_mutex_unlock(struct mt7530_priv *priv)
{
if (priv->bus)
mutex_unlock(&priv->bus->mdio_lock);
}
static void
core_write(struct mt7530_priv *priv, u32 reg, u32 val)
{ {
struct mii_bus *bus = priv->bus; struct mii_bus *bus = priv->bus;
int value, ret; int ret;
mt7530_mutex_lock(priv);
/* Write the desired MMD Devad */ /* Write the desired MMD Devad */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_CTRL, devad); MII_MMD_CTRL, MDIO_MMD_VEND2);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Write the desired MMD register address */ /* Write the desired MMD register address */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_DATA, prtad); MII_MMD_DATA, reg);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Select the Function : DATA with no post increment */ /* Select the Function : DATA with no post increment */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_CTRL, devad | MII_MMD_CTRL_NOINCR); MII_MMD_CTRL, MDIO_MMD_VEND2 | MII_MMD_CTRL_NOINCR);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Read the content of the MMD's selected register */ /* Write the data into MMD's selected register */
value = bus->read(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_DATA); MII_MMD_DATA, val);
return value;
err: err:
dev_err(&bus->dev, "failed to read mmd register\n"); if (ret < 0)
dev_err(&bus->dev, "failed to write mmd register\n");
return ret; mt7530_mutex_unlock(priv);
} }
static int static void
core_write_mmd_indirect(struct mt7530_priv *priv, int prtad, core_rmw(struct mt7530_priv *priv, u32 reg, u32 mask, u32 set)
int devad, u32 data)
{ {
struct mii_bus *bus = priv->bus; struct mii_bus *bus = priv->bus;
u32 val;
int ret; int ret;
mt7530_mutex_lock(priv);
/* Write the desired MMD Devad */ /* Write the desired MMD Devad */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_CTRL, devad); MII_MMD_CTRL, MDIO_MMD_VEND2);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Write the desired MMD register address */ /* Write the desired MMD register address */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_DATA, prtad); MII_MMD_DATA, reg);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Select the Function : DATA with no post increment */ /* Select the Function : DATA with no post increment */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_CTRL, devad | MII_MMD_CTRL_NOINCR); MII_MMD_CTRL, MDIO_MMD_VEND2 | MII_MMD_CTRL_NOINCR);
if (ret < 0) if (ret < 0)
goto err; goto err;
/* Read the content of the MMD's selected register */
val = bus->read(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_DATA);
val &= ~mask;
val |= set;
/* Write the data into MMD's selected register */ /* Write the data into MMD's selected register */
ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr), ret = bus->write(bus, MT753X_CTRL_PHY_ADDR(priv->mdiodev->addr),
MII_MMD_DATA, data); MII_MMD_DATA, val);
err: err:
if (ret < 0) if (ret < 0)
dev_err(&bus->dev, dev_err(&bus->dev, "failed to write mmd register\n");
"failed to write mmd register\n");
return ret;
}
static void
mt7530_mutex_lock(struct mt7530_priv *priv)
{
if (priv->bus)
mutex_lock_nested(&priv->bus->mdio_lock, MDIO_MUTEX_NESTED);
}
static void
mt7530_mutex_unlock(struct mt7530_priv *priv)
{
if (priv->bus)
mutex_unlock(&priv->bus->mdio_lock);
}
static void
core_write(struct mt7530_priv *priv, u32 reg, u32 val)
{
mt7530_mutex_lock(priv);
core_write_mmd_indirect(priv, reg, MDIO_MMD_VEND2, val);
mt7530_mutex_unlock(priv);
}
static void
core_rmw(struct mt7530_priv *priv, u32 reg, u32 mask, u32 set)
{
u32 val;
mt7530_mutex_lock(priv);
val = core_read_mmd_indirect(priv, reg, MDIO_MMD_VEND2);
val &= ~mask;
val |= set;
core_write_mmd_indirect(priv, reg, MDIO_MMD_VEND2, val);
mt7530_mutex_unlock(priv); mt7530_mutex_unlock(priv);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment