diff options
Diffstat (limited to 'net/dsa/dsa_priv.h')
| -rw-r--r-- | net/dsa/dsa_priv.h | 44 | 
1 files changed, 18 insertions, 26 deletions
| diff --git a/net/dsa/dsa_priv.h b/net/dsa/dsa_priv.h index 55982cc39b24..9c3eeb72462d 100644 --- a/net/dsa/dsa_priv.h +++ b/net/dsa/dsa_priv.h @@ -43,10 +43,10 @@ struct dsa_notifier_bridge_info {  /* DSA_NOTIFIER_FDB_* */  struct dsa_notifier_fdb_info { -	const struct switchdev_obj_port_fdb *fdb; -	struct switchdev_trans *trans;  	int sw_index;  	int port; +	const unsigned char *addr; +	u16 vid;  };  /* DSA_NOTIFIER_MDB_* */ @@ -65,18 +65,13 @@ struct dsa_notifier_vlan_info {  	int port;  }; -struct dsa_device_ops { -	struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev); -	struct sk_buff *(*rcv)(struct sk_buff *skb, struct net_device *dev, -			       struct packet_type *pt, -			       struct net_device *orig_dev); -}; -  struct dsa_slave_priv {  	/* Copy of dp->ds->dst->tag_ops->xmit for faster access in hot path */  	struct sk_buff *	(*xmit)(struct sk_buff *skb,  					struct net_device *dev); +	struct pcpu_sw_netstats	*stats64; +  	/* DSA port data, such as switch, port index, etc. */  	struct dsa_port		*dp; @@ -99,16 +94,23 @@ struct dsa_slave_priv {  };  /* dsa.c */ -int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev, -		      struct dsa_port *dport, int port); +int dsa_cpu_dsa_setup(struct dsa_port *port);  void dsa_cpu_dsa_destroy(struct dsa_port *dport);  const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);  int dsa_cpu_port_ethtool_setup(struct dsa_port *cpu_dp);  void dsa_cpu_port_ethtool_restore(struct dsa_port *cpu_dp); +bool dsa_schedule_work(struct work_struct *work);  /* legacy.c */  int dsa_legacy_register(void);  void dsa_legacy_unregister(void); +int dsa_legacy_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], +		       struct net_device *dev, +		       const unsigned char *addr, u16 vid, +		       u16 flags); +int dsa_legacy_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], +		       struct net_device *dev, +		       const unsigned char *addr, u16 vid);  /* port.c */  int dsa_port_set_state(struct dsa_port *dp, u8 state, @@ -120,35 +122,25 @@ int dsa_port_vlan_filtering(struct dsa_port *dp, bool vlan_filtering,  			    struct switchdev_trans *trans);  int dsa_port_ageing_time(struct dsa_port *dp, clock_t ageing_clock,  			 struct switchdev_trans *trans); -int dsa_port_fdb_add(struct dsa_port *dp, -		     const struct switchdev_obj_port_fdb *fdb, -		     struct switchdev_trans *trans); -int dsa_port_fdb_del(struct dsa_port *dp, -		     const struct switchdev_obj_port_fdb *fdb); -int dsa_port_fdb_dump(struct dsa_port *dp, struct switchdev_obj_port_fdb *fdb, -		      switchdev_obj_dump_cb_t *cb); +int dsa_port_fdb_add(struct dsa_port *dp, const unsigned char *addr, +		     u16 vid); +int dsa_port_fdb_del(struct dsa_port *dp, const unsigned char *addr, +		     u16 vid);  int dsa_port_mdb_add(struct dsa_port *dp,  		     const struct switchdev_obj_port_mdb *mdb,  		     struct switchdev_trans *trans);  int dsa_port_mdb_del(struct dsa_port *dp,  		     const struct switchdev_obj_port_mdb *mdb); -int dsa_port_mdb_dump(struct dsa_port *dp, struct switchdev_obj_port_mdb *mdb, -		      switchdev_obj_dump_cb_t *cb);  int dsa_port_vlan_add(struct dsa_port *dp,  		      const struct switchdev_obj_port_vlan *vlan,  		      struct switchdev_trans *trans);  int dsa_port_vlan_del(struct dsa_port *dp,  		      const struct switchdev_obj_port_vlan *vlan); -int dsa_port_vlan_dump(struct dsa_port *dp, -		       struct switchdev_obj_port_vlan *vlan, -		       switchdev_obj_dump_cb_t *cb); -  /* slave.c */  extern const struct dsa_device_ops notag_netdev_ops;  void dsa_slave_mii_bus_init(struct dsa_switch *ds);  void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops); -int dsa_slave_create(struct dsa_switch *ds, struct device *parent, -		     int port, const char *name); +int dsa_slave_create(struct dsa_port *port, const char *name);  void dsa_slave_destroy(struct net_device *slave_dev);  int dsa_slave_suspend(struct net_device *slave_dev);  int dsa_slave_resume(struct net_device *slave_dev); |