Commit 5aed85ce authored by Florian Fainelli's avatar Florian Fainelli Committed by David S. Miller

net: dsa: allow switches to work without tagging

In case switch port tagging is disabled (voluntarily, or the switch just
does not support it), allow us to continue using the defined set of
dsa_device_ops in net/dsa/slave.c.

We introduce dsa_protocol_is_tagged() to check whether we need to
override skb->protocol and go through the DSA-specifif packet_type
function, or if we just go on and receive the SKB through the normal
path.
Signed-off-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 0d8bcdd3
...@@ -1784,10 +1784,10 @@ void dev_net_set(struct net_device *dev, struct net *net) ...@@ -1784,10 +1784,10 @@ void dev_net_set(struct net_device *dev, struct net *net)
static inline bool netdev_uses_dsa(struct net_device *dev) static inline bool netdev_uses_dsa(struct net_device *dev)
{ {
#ifdef CONFIG_NET_DSA #ifdef CONFIG_NET_DSA
return dev->dsa_ptr != NULL; if (dev->dsa_ptr != NULL)
#else return dsa_uses_tagged_protocol(dev->dsa_ptr);
return false;
#endif #endif
return false;
} }
/** /**
......
...@@ -198,4 +198,9 @@ static inline void *ds_to_priv(struct dsa_switch *ds) ...@@ -198,4 +198,9 @@ static inline void *ds_to_priv(struct dsa_switch *ds)
return (void *)(ds + 1); return (void *)(ds + 1);
} }
static inline bool dsa_uses_tagged_protocol(struct dsa_switch_tree *dst)
{
return dst->tag_protocol != 0;
}
#endif #endif
...@@ -181,6 +181,17 @@ static netdev_tx_t dsa_slave_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -181,6 +181,17 @@ static netdev_tx_t dsa_slave_xmit(struct sk_buff *skb, struct net_device *dev)
return dst->ops->xmit(skb, dev); return dst->ops->xmit(skb, dev);
} }
static netdev_tx_t dsa_slave_notag_xmit(struct sk_buff *skb,
struct net_device *dev)
{
struct dsa_slave_priv *p = netdev_priv(dev);
skb->dev = p->parent->dst->master_netdev;
dev_queue_xmit(skb);
return NETDEV_TX_OK;
}
/* ethtool operations *******************************************************/ /* ethtool operations *******************************************************/
static int static int
...@@ -314,6 +325,11 @@ static const struct net_device_ops dsa_slave_netdev_ops = { ...@@ -314,6 +325,11 @@ static const struct net_device_ops dsa_slave_netdev_ops = {
.ndo_do_ioctl = dsa_slave_ioctl, .ndo_do_ioctl = dsa_slave_ioctl,
}; };
static const struct dsa_device_ops notag_netdev_ops = {
.xmit = dsa_slave_notag_xmit,
.rcv = NULL,
};
static void dsa_slave_adjust_link(struct net_device *dev) static void dsa_slave_adjust_link(struct net_device *dev)
{ {
struct dsa_slave_priv *p = netdev_priv(dev); struct dsa_slave_priv *p = netdev_priv(dev);
...@@ -415,7 +431,8 @@ dsa_slave_create(struct dsa_switch *ds, struct device *parent, ...@@ -415,7 +431,8 @@ dsa_slave_create(struct dsa_switch *ds, struct device *parent,
break; break;
#endif #endif
default: default:
BUG(); ds->dst->ops = &notag_netdev_ops;
break;
} }
SET_NETDEV_DEV(slave_dev, parent); SET_NETDEV_DEV(slave_dev, parent);
......
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