OSDN Git Service

net: dsa: qca8k: use dsa_port's bridge pointer
authorVivien Didelot <vivien.didelot@savoirfairelinux.com>
Fri, 27 Jan 2017 20:29:43 +0000 (15:29 -0500)
committerDavid S. Miller <davem@davemloft.net>
Sun, 29 Jan 2017 23:42:46 +0000 (18:42 -0500)
Now that DSA exposes the bridge device pointer to which a port belongs,
use it when programming the port based VLANs and thus remove the cache.

Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/qca8k.c
drivers/net/dsa/qca8k.h

index c85b187..a4fd4cc 100644 (file)
@@ -746,17 +746,14 @@ qca8k_port_stp_state_set(struct dsa_switch *ds, int port, u8 state)
 }
 
 static int
-qca8k_port_bridge_join(struct dsa_switch *ds, int port,
-                      struct net_device *bridge)
+qca8k_port_bridge_join(struct dsa_switch *ds, int port, struct net_device *br)
 {
        struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
        int port_mask = BIT(QCA8K_CPU_PORT);
        int i;
 
-       priv->port_sts[port].bridge_dev = bridge;
-
        for (i = 1; i < QCA8K_NUM_PORTS; i++) {
-               if (priv->port_sts[i].bridge_dev != bridge)
+               if (ds->ports[i].bridge_dev != br)
                        continue;
                /* Add this port to the portvlan mask of the other ports
                 * in the bridge
@@ -781,8 +778,7 @@ qca8k_port_bridge_leave(struct dsa_switch *ds, int port, struct net_device *br)
        int i;
 
        for (i = 1; i < QCA8K_NUM_PORTS; i++) {
-               if (priv->port_sts[i].bridge_dev !=
-                   priv->port_sts[port].bridge_dev)
+               if (ds->ports[i].bridge_dev != br)
                        continue;
                /* Remove this port to the portvlan mask of the other ports
                 * in the bridge
@@ -791,7 +787,7 @@ qca8k_port_bridge_leave(struct dsa_switch *ds, int port, struct net_device *br)
                                QCA8K_PORT_LOOKUP_CTRL(i),
                                BIT(port));
        }
-       priv->port_sts[port].bridge_dev = NULL;
+
        /* Set the cpu port to be the only one in the portvlan mask of
         * this port
         */
index 2014647..1ed4fac 100644 (file)
@@ -157,7 +157,6 @@ enum qca8k_fdb_cmd {
 
 struct ar8xxx_port_status {
        struct ethtool_eee eee;
-       struct net_device *bridge_dev;
        int enabled;
 };