net: dsa: mt7530: use unlocked regmap accessors
authorDaniel Golle <daniel@makrotopia.org>
Mon, 3 Apr 2023 01:17:40 +0000 (02:17 +0100)
committerDavid S. Miller <davem@davemloft.net>
Mon, 3 Apr 2023 09:13:00 +0000 (10:13 +0100)
Instead of wrapping the locked register accessor functions, use the
unlocked variants and add locking wrapper functions to let regmap
handle the locking.

This is a preparation towards being able to always use regmap to
access switch registers instead of open-coded accessor functions.

Signed-off-by: Daniel Golle <daniel@makrotopia.org>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/mt7530.c

index 5685c71bc9173bcaf85672e30036b5ff632cc6d9..d8b041d79f2b782d5cf5b633ed89b77be7eaa387 100644 (file)
@@ -2900,7 +2900,7 @@ static int mt7530_regmap_read(void *context, unsigned int reg, unsigned int *val
 {
        struct mt7530_priv *priv = context;
 
-       *val = mt7530_read(priv, reg);
+       *val = mt7530_mii_read(priv, reg);
        return 0;
 };
 
@@ -2908,23 +2908,25 @@ static int mt7530_regmap_write(void *context, unsigned int reg, unsigned int val
 {
        struct mt7530_priv *priv = context;
 
-       mt7530_write(priv, reg, val);
+       mt7530_mii_write(priv, reg, val);
        return 0;
 };
 
-static int mt7530_regmap_update_bits(void *context, unsigned int reg,
-                                    unsigned int mask, unsigned int val)
+static void
+mt7530_mdio_regmap_lock(void *mdio_lock)
 {
-       struct mt7530_priv *priv = context;
+       mutex_lock_nested(mdio_lock, MDIO_MUTEX_NESTED);
+}
 
-       mt7530_rmw(priv, reg, mask, val);
-       return 0;
-};
+static void
+mt7530_mdio_regmap_unlock(void *mdio_lock)
+{
+       mutex_unlock(mdio_lock);
+}
 
 static const struct regmap_bus mt7531_regmap_bus = {
        .reg_write = mt7530_regmap_write,
        .reg_read = mt7530_regmap_read,
-       .reg_update_bits = mt7530_regmap_update_bits,
 };
 
 static int
@@ -2950,6 +2952,9 @@ mt7531_create_sgmii(struct mt7530_priv *priv)
                mt7531_pcs_config[i]->reg_stride = 4;
                mt7531_pcs_config[i]->reg_base = MT7531_SGMII_REG_BASE(5 + i);
                mt7531_pcs_config[i]->max_register = 0x17c;
+               mt7531_pcs_config[i]->lock = mt7530_mdio_regmap_lock;
+               mt7531_pcs_config[i]->unlock = mt7530_mdio_regmap_unlock;
+               mt7531_pcs_config[i]->lock_arg = &priv->bus->mdio_lock;
 
                regmap = devm_regmap_init(priv->dev,
                                          &mt7531_regmap_bus, priv,