diff options
author | Vivien Didelot <vivien.didelot@savoirfairelinux.com> | 2016-07-18 20:45:40 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-07-19 22:42:02 -0400 |
commit | 2cfcd9641618e71a1b823324aa4737e18662c25e (patch) | |
tree | 25edd602c203442ec3fe5f74cb290b692742149f /drivers/net/dsa | |
parent | acddbd21477efc3da9ab414b2bc72cd580cf6fdb (diff) |
net: dsa: mv88e6xxx: add support for DSA ageing time
Implement the DSA driver function to configure the bridge ageing time.
Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/dsa')
-rw-r--r-- | drivers/net/dsa/mv88e6xxx/chip.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/net/dsa/mv88e6xxx/chip.c b/drivers/net/dsa/mv88e6xxx/chip.c index 8e24c6526894..9ba21738569a 100644 --- a/drivers/net/dsa/mv88e6xxx/chip.c +++ b/drivers/net/dsa/mv88e6xxx/chip.c | |||
@@ -3002,6 +3002,19 @@ static int mv88e6xxx_g1_set_age_time(struct mv88e6xxx_chip *chip, | |||
3002 | return mv88e6xxx_write(chip, REG_GLOBAL, GLOBAL_ATU_CONTROL, val); | 3002 | return mv88e6xxx_write(chip, REG_GLOBAL, GLOBAL_ATU_CONTROL, val); |
3003 | } | 3003 | } |
3004 | 3004 | ||
3005 | static int mv88e6xxx_set_ageing_time(struct dsa_switch *ds, | ||
3006 | unsigned int ageing_time) | ||
3007 | { | ||
3008 | struct mv88e6xxx_chip *chip = ds_to_priv(ds); | ||
3009 | int err; | ||
3010 | |||
3011 | mutex_lock(&chip->reg_lock); | ||
3012 | err = mv88e6xxx_g1_set_age_time(chip, ageing_time); | ||
3013 | mutex_unlock(&chip->reg_lock); | ||
3014 | |||
3015 | return err; | ||
3016 | } | ||
3017 | |||
3005 | static int mv88e6xxx_g1_setup(struct mv88e6xxx_chip *chip) | 3018 | static int mv88e6xxx_g1_setup(struct mv88e6xxx_chip *chip) |
3006 | { | 3019 | { |
3007 | struct dsa_switch *ds = chip->ds; | 3020 | struct dsa_switch *ds = chip->ds; |
@@ -3980,6 +3993,7 @@ static struct dsa_switch_driver mv88e6xxx_switch_driver = { | |||
3980 | .set_eeprom = mv88e6xxx_set_eeprom, | 3993 | .set_eeprom = mv88e6xxx_set_eeprom, |
3981 | .get_regs_len = mv88e6xxx_get_regs_len, | 3994 | .get_regs_len = mv88e6xxx_get_regs_len, |
3982 | .get_regs = mv88e6xxx_get_regs, | 3995 | .get_regs = mv88e6xxx_get_regs, |
3996 | .set_ageing_time = mv88e6xxx_set_ageing_time, | ||
3983 | .port_bridge_join = mv88e6xxx_port_bridge_join, | 3997 | .port_bridge_join = mv88e6xxx_port_bridge_join, |
3984 | .port_bridge_leave = mv88e6xxx_port_bridge_leave, | 3998 | .port_bridge_leave = mv88e6xxx_port_bridge_leave, |
3985 | .port_stp_state_set = mv88e6xxx_port_stp_state_set, | 3999 | .port_stp_state_set = mv88e6xxx_port_stp_state_set, |