Commit c8a2a011 authored by Vladimir Oltean's avatar Vladimir Oltean Committed by David S. Miller

net: dsa: sja1105: fix broken connection with the sja1110 tagger

The driver was incorrectly converted assuming that "sja1105" is the only
tagger supported by this driver. This results in SJA1110 switches
failing to probe:

sja1105 spi1.0: Unable to connect to tag protocol "sja1110": -EPROTONOSUPPORT
sja1105: probe of spi1.2 failed with error -93

Add DSA_TAG_PROTO_SJA1110 to the list of supported taggers by the
sja1105 driver. The sja1105_tagger_data structure format is common for
the two tagging protocols.

Fixes: c79e8486 ("net: dsa: tag_sja1105: convert to tagger-owned data")
Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent e2f01bfe
...@@ -2708,17 +2708,17 @@ static void sja1105_port_deferred_xmit(struct kthread_work *work) ...@@ -2708,17 +2708,17 @@ static void sja1105_port_deferred_xmit(struct kthread_work *work)
static int sja1105_connect_tag_protocol(struct dsa_switch *ds, static int sja1105_connect_tag_protocol(struct dsa_switch *ds,
enum dsa_tag_protocol proto) enum dsa_tag_protocol proto)
{ {
struct sja1105_private *priv = ds->priv;
struct sja1105_tagger_data *tagger_data; struct sja1105_tagger_data *tagger_data;
switch (proto) { if (proto != priv->info->tag_proto)
case DSA_TAG_PROTO_SJA1105:
tagger_data = sja1105_tagger_data(ds);
tagger_data->xmit_work_fn = sja1105_port_deferred_xmit;
tagger_data->meta_tstamp_handler = sja1110_process_meta_tstamp;
return 0;
default:
return -EPROTONOSUPPORT; return -EPROTONOSUPPORT;
}
tagger_data = sja1105_tagger_data(ds);
tagger_data->xmit_work_fn = sja1105_port_deferred_xmit;
tagger_data->meta_tstamp_handler = sja1110_process_meta_tstamp;
return 0;
} }
/* The MAXAGE setting belongs to the L2 Forwarding Parameters table, /* The MAXAGE setting belongs to the L2 Forwarding Parameters table,
......
...@@ -70,7 +70,8 @@ struct sja1105_skb_cb { ...@@ -70,7 +70,8 @@ struct sja1105_skb_cb {
static inline struct sja1105_tagger_data * static inline struct sja1105_tagger_data *
sja1105_tagger_data(struct dsa_switch *ds) sja1105_tagger_data(struct dsa_switch *ds)
{ {
BUG_ON(ds->dst->tag_ops->proto != DSA_TAG_PROTO_SJA1105); BUG_ON(ds->dst->tag_ops->proto != DSA_TAG_PROTO_SJA1105 &&
ds->dst->tag_ops->proto != DSA_TAG_PROTO_SJA1110);
return ds->tagger_data; return ds->tagger_data;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment