diff options
| author | Andrew Lunn <andrew@lunn.ch> | 2019-04-27 13:32:59 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2019-04-27 20:23:04 -0400 |
| commit | 1ba22bf547a3c92d3e6c5c8d3e3ebe48a7bc26b3 (patch) | |
| tree | a107bd7eb2f574134373ea062d8924bd49a8f9f8 /drivers/net/dsa | |
| parent | c4362c37431b999c84dd047f0125592987c09142 (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.c | 20 |
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 | |||
| 33 | static int reg_write(struct mv88e6060_priv *priv, int addr, int reg, u16 val) | 22 | static 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 | ||
