net: dsa: support cross-chip ageing time
authorVivien Didelot <vivien.didelot@savoirfairelinux.com>
Tue, 23 May 2017 19:20:59 +0000 (15:20 -0400)
committerDavid S. Miller <davem@davemloft.net>
Wed, 24 May 2017 20:27:47 +0000 (16:27 -0400)
Now that the switchdev bridge ageing time attribute is propagated to all
switch chips of the fabric, each switch can check if the requested value
is valid and program itself, so that the whole fabric shares a common
ageing time setting.

This is especially needed for switch chips in between others, containing
no bridge port members but evidently used in the data path.

To achieve that, remove the condition which skips the other switches. We
also don't need to identify the target switch anymore, thus remove the
sw_index member of the dsa_notifier_ageing_time_info notifier structure.

On ZII Dev Rev B (with two 88E6352 and one 88E6185) and ZII Dev Rev C
(with two 88E6390X), we have the following hardware configuration:

    # ip link add name br0 type bridge
    # ip link set master br0 dev lan6
    br0: port 1(lan6) entered blocking state
    br0: port 1(lan6) entered disabled state
    # echo 2000 > /sys/class/net/br0/bridge/ageing_time

Before this patch:

    zii-rev-b# cat /sys/kernel/debug/mv88e6xxx/sw*/age_time
    300000
    300000
    15000

    zii-rev-c# cat /sys/kernel/debug/mv88e6xxx/sw*/age_time
    300000
    18750

After this patch:

    zii-rev-b# cat /sys/kernel/debug/mv88e6xxx/sw*/age_time
    15000
    15000
    15000

    zii-rev-c# cat /sys/kernel/debug/mv88e6xxx/sw*/age_time
    18750
    18750

Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/dsa/dsa_priv.h
net/dsa/port.c
net/dsa/switch.c

index 1d52f9051d0e217d73c8c3bd9c7ec6cea041a036..c1d4180651af84b4717f4f9c3da0ea035e17198b 100644 (file)
@@ -32,7 +32,6 @@ enum {
 struct dsa_notifier_ageing_time_info {
        struct switchdev_trans *trans;
        unsigned int ageing_time;
-       int sw_index;
 };
 
 /* DSA_NOTIFIER_BRIDGE_* */
index c88c0cec8454cf6af7ff20976410cd19e11812aa..efc3bce3a89d7068af05b213e344bc64a0a46675 100644 (file)
@@ -135,7 +135,6 @@ int dsa_port_ageing_time(struct dsa_port *dp, clock_t ageing_clock,
        unsigned int ageing_time = jiffies_to_msecs(ageing_jiffies);
        struct dsa_notifier_ageing_time_info info = {
                .ageing_time = ageing_time,
-               .sw_index = dp->ds->index,
                .trans = trans,
        };
 
index c1e4b2d5a3ae5cf0c014df8c25871b942568ef5e..d8e5c311ee7cda455c961f09b542e301decadc94 100644 (file)
@@ -37,10 +37,6 @@ static int dsa_switch_ageing_time(struct dsa_switch *ds,
        unsigned int ageing_time = info->ageing_time;
        struct switchdev_trans *trans = info->trans;
 
-       /* Do not care yet about other switch chips of the fabric */
-       if (ds->index != info->sw_index)
-               return 0;
-
        if (switchdev_trans_ph_prepare(trans)) {
                if (ds->ageing_time_min && ageing_time < ds->ageing_time_min)
                        return -ERANGE;