aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/dsa
diff options
context:
space:
mode:
authorAndrew Lunn <andrew@lunn.ch>2019-04-27 13:32:59 -0400
committerDavid S. Miller <davem@davemloft.net>2019-04-27 20:23:04 -0400
commit1ba22bf547a3c92d3e6c5c8d3e3ebe48a7bc26b3 (patch)
treea107bd7eb2f574134373ea062d8924bd49a8f9f8 /drivers/net/dsa
parentc4362c37431b999c84dd047f0125592987c09142 (diff)
net: dsa: mv88e6060: Replace REG_READ macro
The REG_READ macro contains a return statement, making it not very safe. Remove it by inlining the code. Signed-off-by: Andrew Lunn <andrew@lunn.ch> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/dsa')
-rw-r--r--drivers/net/dsa/mv88e6060.c20
1 files changed, 7 insertions, 13 deletions
diff --git a/drivers/net/dsa/mv88e6060.c b/drivers/net/dsa/mv88e6060.c
index 68d33c42ce5f..4ca06b3b9d4f 100644
--- a/drivers/net/dsa/mv88e6060.c
+++ b/drivers/net/dsa/mv88e6060.c
@@ -19,17 +19,6 @@ static int reg_read(struct mv88e6060_priv *priv, int addr, int reg)
19 return mdiobus_read_nested(priv->bus, priv->sw_addr + addr, reg); 19 return mdiobus_read_nested(priv->bus, priv->sw_addr + addr, reg);
20} 20}
21 21
22#define REG_READ(addr, reg) \
23 ({ \
24 int __ret; \
25 \
26 __ret = reg_read(priv, addr, reg); \
27 if (__ret < 0) \
28 return __ret; \
29 __ret; \
30 })
31
32
33static int reg_write(struct mv88e6060_priv *priv, int addr, int reg, u16 val) 22static int reg_write(struct mv88e6060_priv *priv, int addr, int reg, u16 val)
34{ 23{
35 return mdiobus_write_nested(priv->bus, priv->sw_addr + addr, reg, val); 24 return mdiobus_write_nested(priv->bus, priv->sw_addr + addr, reg, val);
@@ -88,7 +77,9 @@ static int mv88e6060_switch_reset(struct mv88e6060_priv *priv)
88 77
89 /* Set all ports to the disabled state. */ 78 /* Set all ports to the disabled state. */
90 for (i = 0; i < MV88E6060_PORTS; i++) { 79 for (i = 0; i < MV88E6060_PORTS; i++) {
91 ret = REG_READ(REG_PORT(i), PORT_CONTROL); 80 ret = reg_read(priv, REG_PORT(i), PORT_CONTROL);
81 if (ret < 0)
82 return ret;
92 ret = reg_write(priv, REG_PORT(i), PORT_CONTROL, 83 ret = reg_write(priv, REG_PORT(i), PORT_CONTROL,
93 ret & ~PORT_CONTROL_STATE_MASK); 84 ret & ~PORT_CONTROL_STATE_MASK);
94 if (ret) 85 if (ret)
@@ -108,7 +99,10 @@ static int mv88e6060_switch_reset(struct mv88e6060_priv *priv)
108 /* Wait up to one second for reset to complete. */ 99 /* Wait up to one second for reset to complete. */
109 timeout = jiffies + 1 * HZ; 100 timeout = jiffies + 1 * HZ;
110 while (time_before(jiffies, timeout)) { 101 while (time_before(jiffies, timeout)) {
111 ret = REG_READ(REG_GLOBAL, GLOBAL_STATUS); 102 ret = reg_read(priv, REG_GLOBAL, GLOBAL_STATUS);
103 if (ret < 0)
104 return ret;
105
112 if (ret & GLOBAL_STATUS_INIT_READY) 106 if (ret & GLOBAL_STATUS_INIT_READY)
113 break; 107 break;
114 108