diff options
Diffstat (limited to 'include/linux/dsa/8021q.h')
-rw-r--r-- | include/linux/dsa/8021q.h | 82 |
1 files changed, 34 insertions, 48 deletions
diff --git a/include/linux/dsa/8021q.h b/include/linux/dsa/8021q.h index 0aa803c451a3..3ed117e299ec 100644 --- a/include/linux/dsa/8021q.h +++ b/include/linux/dsa/8021q.h @@ -5,70 +5,56 @@ #ifndef _NET_DSA_8021Q_H #define _NET_DSA_8021Q_H +#include <linux/refcount.h> #include <linux/types.h> +#include <net/dsa.h> struct dsa_switch; +struct dsa_port; struct sk_buff; struct net_device; -struct packet_type; -#if IS_ENABLED(CONFIG_NET_DSA_TAG_8021Q) +struct dsa_tag_8021q_vlan { + struct list_head list; + int port; + u16 vid; + refcount_t refcount; +}; -int dsa_port_setup_8021q_tagging(struct dsa_switch *ds, int index, - bool enabled); +struct dsa_8021q_context { + struct dsa_switch *ds; + struct list_head vlans; + /* EtherType of RX VID, used for filtering on master interface */ + __be16 proto; +}; + +int dsa_tag_8021q_register(struct dsa_switch *ds, __be16 proto); + +void dsa_tag_8021q_unregister(struct dsa_switch *ds); + +int dsa_tag_8021q_bridge_join(struct dsa_switch *ds, int port, + struct dsa_bridge bridge); + +void dsa_tag_8021q_bridge_leave(struct dsa_switch *ds, int port, + struct dsa_bridge bridge); struct sk_buff *dsa_8021q_xmit(struct sk_buff *skb, struct net_device *netdev, u16 tpid, u16 tci); -u16 dsa_8021q_tx_vid(struct dsa_switch *ds, int port); - -u16 dsa_8021q_rx_vid(struct dsa_switch *ds, int port); +void dsa_8021q_rcv(struct sk_buff *skb, int *source_port, int *switch_id, + int *vbid); -int dsa_8021q_rx_switch_id(u16 vid); +struct net_device *dsa_tag_8021q_find_port_by_vbid(struct net_device *master, + int vbid); -int dsa_8021q_rx_source_port(u16 vid); +u16 dsa_tag_8021q_bridge_vid(unsigned int bridge_num); -struct sk_buff *dsa_8021q_remove_header(struct sk_buff *skb); +u16 dsa_tag_8021q_standalone_vid(const struct dsa_port *dp); -#else +int dsa_8021q_rx_switch_id(u16 vid); -int dsa_port_setup_8021q_tagging(struct dsa_switch *ds, int index, - bool enabled) -{ - return 0; -} +int dsa_8021q_rx_source_port(u16 vid); -struct sk_buff *dsa_8021q_xmit(struct sk_buff *skb, struct net_device *netdev, - u16 tpid, u16 tci) -{ - return NULL; -} - -u16 dsa_8021q_tx_vid(struct dsa_switch *ds, int port) -{ - return 0; -} - -u16 dsa_8021q_rx_vid(struct dsa_switch *ds, int port) -{ - return 0; -} - -int dsa_8021q_rx_switch_id(u16 vid) -{ - return 0; -} - -int dsa_8021q_rx_source_port(u16 vid) -{ - return 0; -} - -struct sk_buff *dsa_8021q_remove_header(struct sk_buff *skb) -{ - return NULL; -} - -#endif /* IS_ENABLED(CONFIG_NET_DSA_TAG_8021Q) */ +bool vid_is_dsa_8021q(u16 vid); #endif /* _NET_DSA_8021Q_H */ |