aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFlorian Fainelli <f.fainelli@gmail.com>2015-03-05 15:35:07 -0500
committerDavid S. Miller <davem@davemloft.net>2015-03-06 00:18:20 -0500
commit59299031038f3ea92cf484bc4a68d16ad4bb3050 (patch)
tree340dcd16f53510323a1fae6945e329b4cf615d57
parentdf197195a5248164df0709fbadc61133897281f5 (diff)
net: dsa: let switches specify their tagging protocol
In order to support the new DSA device driver model, a dsa_switch should be able to advertise the type of tagging protocol supported by the underlying switch device. This also removes constraints on how tagging can be stacked to each other. Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/net/dsa.h5
-rw-r--r--net/dsa/dsa.c5
2 files changed, 8 insertions, 2 deletions
diff --git a/include/net/dsa.h b/include/net/dsa.h
index c542c131d551..b525ac516559 100644
--- a/include/net/dsa.h
+++ b/include/net/dsa.h
@@ -128,6 +128,11 @@ struct dsa_switch {
128 int index; 128 int index;
129 129
130 /* 130 /*
131 * Tagging protocol understood by this switch
132 */
133 enum dsa_tag_protocol tag_protocol;
134
135 /*
131 * Configuration data for this switch. 136 * Configuration data for this switch.
132 */ 137 */
133 struct dsa_chip_data *pd; 138 struct dsa_chip_data *pd;
diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c
index 6f02ccc57593..4cc995664fdf 100644
--- a/net/dsa/dsa.c
+++ b/net/dsa/dsa.c
@@ -227,7 +227,7 @@ static int dsa_switch_setup_one(struct dsa_switch *ds, struct device *parent)
227 * switch. 227 * switch.
228 */ 228 */
229 if (dst->cpu_switch == index) { 229 if (dst->cpu_switch == index) {
230 switch (drv->tag_protocol) { 230 switch (ds->tag_protocol) {
231#ifdef CONFIG_NET_DSA_TAG_DSA 231#ifdef CONFIG_NET_DSA_TAG_DSA
232 case DSA_TAG_PROTO_DSA: 232 case DSA_TAG_PROTO_DSA:
233 dst->rcv = dsa_netdev_ops.rcv; 233 dst->rcv = dsa_netdev_ops.rcv;
@@ -255,7 +255,7 @@ static int dsa_switch_setup_one(struct dsa_switch *ds, struct device *parent)
255 goto out; 255 goto out;
256 } 256 }
257 257
258 dst->tag_protocol = drv->tag_protocol; 258 dst->tag_protocol = ds->tag_protocol;
259 } 259 }
260 260
261 /* 261 /*
@@ -364,6 +364,7 @@ dsa_switch_setup(struct dsa_switch_tree *dst, int index,
364 ds->index = index; 364 ds->index = index;
365 ds->pd = pd; 365 ds->pd = pd;
366 ds->drv = drv; 366 ds->drv = drv;
367 ds->tag_protocol = drv->tag_protocol;
367 ds->master_dev = host_dev; 368 ds->master_dev = host_dev;
368 369
369 ret = dsa_switch_setup_one(ds, parent); 370 ret = dsa_switch_setup_one(ds, parent);