diff options
author | Vivien Didelot <vivien.didelot@savoirfairelinux.com> | 2017-09-22 19:01:56 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-09-25 20:22:46 -0700 |
commit | fb8a6a2b8b7cfee8a0cf2cd431e1d0f45dd1c9e0 (patch) | |
tree | 0668bc999f2cc8a159fe82d285377601ec66374a /net/dsa/port.c | |
parent | 6457edfe7344ac1da334b9f24a42aacea084a451 (diff) | |
download | op-kernel-dev-fb8a6a2b8b7cfee8a0cf2cd431e1d0f45dd1c9e0.zip op-kernel-dev-fb8a6a2b8b7cfee8a0cf2cd431e1d0f45dd1c9e0.tar.gz |
net: dsa: add port enable and disable helpers
Provide dsa_port_enable and dsa_port_disable helpers to respectively
enable and disable a switch port. This makes the dsa_port_set_state_now
helper static.
Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/dsa/port.c')
-rw-r--r-- | net/dsa/port.c | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/net/dsa/port.c b/net/dsa/port.c index 76d43a8..72c8dbd3 100644 --- a/net/dsa/port.c +++ b/net/dsa/port.c @@ -56,7 +56,7 @@ int dsa_port_set_state(struct dsa_port *dp, u8 state, return 0; } -void dsa_port_set_state_now(struct dsa_port *dp, u8 state) +static void dsa_port_set_state_now(struct dsa_port *dp, u8 state) { int err; @@ -65,6 +65,35 @@ void dsa_port_set_state_now(struct dsa_port *dp, u8 state) pr_err("DSA: failed to set STP state %u (%d)\n", state, err); } +int dsa_port_enable(struct dsa_port *dp, struct phy_device *phy) +{ + u8 stp_state = dp->bridge_dev ? BR_STATE_BLOCKING : BR_STATE_FORWARDING; + struct dsa_switch *ds = dp->ds; + int port = dp->index; + int err; + + if (ds->ops->port_enable) { + err = ds->ops->port_enable(ds, port, phy); + if (err) + return err; + } + + dsa_port_set_state_now(dp, stp_state); + + return 0; +} + +void dsa_port_disable(struct dsa_port *dp, struct phy_device *phy) +{ + struct dsa_switch *ds = dp->ds; + int port = dp->index; + + dsa_port_set_state_now(dp, BR_STATE_DISABLED); + + if (ds->ops->port_disable) + ds->ops->port_disable(ds, port, phy); +} + int dsa_port_bridge_join(struct dsa_port *dp, struct net_device *br) { struct dsa_notifier_bridge_info info = { |