mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	net: Add extack argument to ndo_fdb_add()
Drivers may not be able to support certain FDB entries, and an error code is insufficient to give clear hints as to the reasons of rejection. In order to make it possible to communicate the rejection reason, extend ndo_fdb_add() with an extack argument. Adapt the existing implementations of ndo_fdb_add() to take the parameter (and ignore it). Pass the extack parameter when invoking ndo_fdb_add() from rtnl_fdb_add(). Signed-off-by: Petr Machata <petrm@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									1cdc98c271
								
							
						
					
					
						commit
						87b0984ebf
					
				| @ -11644,7 +11644,8 @@ static int i40e_get_phys_port_id(struct net_device *netdev, | |||||||
| static int i40e_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int i40e_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			    struct net_device *dev, | 			    struct net_device *dev, | ||||||
| 			    const unsigned char *addr, u16 vid, | 			    const unsigned char *addr, u16 vid, | ||||||
| 			    u16 flags) | 			    u16 flags, | ||||||
|  | 			    struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct i40e_netdev_priv *np = netdev_priv(dev); | 	struct i40e_netdev_priv *np = netdev_priv(dev); | ||||||
| 	struct i40e_pf *pf = np->vsi->back; | 	struct i40e_pf *pf = np->vsi->back; | ||||||
|  | |||||||
| @ -2438,7 +2438,8 @@ static void ice_set_rx_mode(struct net_device *netdev) | |||||||
|  */ |  */ | ||||||
| static int ice_fdb_add(struct ndmsg *ndm, struct nlattr __always_unused *tb[], | static int ice_fdb_add(struct ndmsg *ndm, struct nlattr __always_unused *tb[], | ||||||
| 		       struct net_device *dev, const unsigned char *addr, | 		       struct net_device *dev, const unsigned char *addr, | ||||||
| 		       u16 vid, u16 flags) | 		       u16 vid, u16 flags, | ||||||
|  | 		       struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	int err; | 	int err; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2486,7 +2486,8 @@ static int igb_set_features(struct net_device *netdev, | |||||||
| static int igb_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int igb_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			   struct net_device *dev, | 			   struct net_device *dev, | ||||||
| 			   const unsigned char *addr, u16 vid, | 			   const unsigned char *addr, u16 vid, | ||||||
| 			   u16 flags) | 			   u16 flags, | ||||||
|  | 			   struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	/* guarantee we can provide a unique filter for the unicast address */ | 	/* guarantee we can provide a unique filter for the unicast address */ | ||||||
| 	if (is_unicast_ether_addr(addr) || is_link_local_ether_addr(addr)) { | 	if (is_unicast_ether_addr(addr) || is_link_local_ether_addr(addr)) { | ||||||
|  | |||||||
| @ -9910,7 +9910,8 @@ static void ixgbe_del_udp_tunnel_port(struct net_device *dev, | |||||||
| static int ixgbe_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int ixgbe_ndo_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			     struct net_device *dev, | 			     struct net_device *dev, | ||||||
| 			     const unsigned char *addr, u16 vid, | 			     const unsigned char *addr, u16 vid, | ||||||
| 			     u16 flags) | 			     u16 flags, | ||||||
|  | 			     struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	/* guarantee we can provide a unique filter for the unicast address */ | 	/* guarantee we can provide a unique filter for the unicast address */ | ||||||
| 	if (is_unicast_ether_addr(addr) || is_link_local_ether_addr(addr)) { | 	if (is_unicast_ether_addr(addr) || is_link_local_ether_addr(addr)) { | ||||||
|  | |||||||
| @ -721,7 +721,8 @@ static void ocelot_get_stats64(struct net_device *dev, | |||||||
| 
 | 
 | ||||||
| static int ocelot_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int ocelot_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			  struct net_device *dev, const unsigned char *addr, | 			  struct net_device *dev, const unsigned char *addr, | ||||||
| 			  u16 vid, u16 flags) | 			  u16 vid, u16 flags, | ||||||
|  | 			  struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct ocelot_port *port = netdev_priv(dev); | 	struct ocelot_port *port = netdev_priv(dev); | ||||||
| 	struct ocelot *ocelot = port->ocelot; | 	struct ocelot *ocelot = port->ocelot; | ||||||
|  | |||||||
| @ -396,7 +396,8 @@ static int qlcnic_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], | |||||||
| 
 | 
 | ||||||
| static int qlcnic_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int qlcnic_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			struct net_device *netdev, | 			struct net_device *netdev, | ||||||
| 			const unsigned char *addr, u16 vid, u16 flags) | 			const unsigned char *addr, u16 vid, u16 flags, | ||||||
|  | 			struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct qlcnic_adapter *adapter = netdev_priv(netdev); | 	struct qlcnic_adapter *adapter = netdev_priv(netdev); | ||||||
| 	int err = 0; | 	int err = 0; | ||||||
|  | |||||||
| @ -963,7 +963,8 @@ static int macvlan_vlan_rx_kill_vid(struct net_device *dev, | |||||||
| static int macvlan_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int macvlan_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			   struct net_device *dev, | 			   struct net_device *dev, | ||||||
| 			   const unsigned char *addr, u16 vid, | 			   const unsigned char *addr, u16 vid, | ||||||
| 			   u16 flags) | 			   u16 flags, | ||||||
|  | 			   struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct macvlan_dev *vlan = netdev_priv(dev); | 	struct macvlan_dev *vlan = netdev_priv(dev); | ||||||
| 	int err = -EINVAL; | 	int err = -EINVAL; | ||||||
|  | |||||||
| @ -1087,7 +1087,8 @@ static int vxlan_fdb_parse(struct nlattr *tb[], struct vxlan_dev *vxlan, | |||||||
| /* Add static entry (via netlink) */ | /* Add static entry (via netlink) */ | ||||||
| static int vxlan_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | static int vxlan_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 			 struct net_device *dev, | 			 struct net_device *dev, | ||||||
| 			 const unsigned char *addr, u16 vid, u16 flags) | 			 const unsigned char *addr, u16 vid, u16 flags, | ||||||
|  | 			 struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct vxlan_dev *vxlan = netdev_priv(dev); | 	struct vxlan_dev *vxlan = netdev_priv(dev); | ||||||
| 	/* struct net *net = dev_net(vxlan->dev); */ | 	/* struct net *net = dev_net(vxlan->dev); */ | ||||||
|  | |||||||
| @ -1152,7 +1152,8 @@ struct dev_ifalias { | |||||||
|  * |  * | ||||||
|  * int (*ndo_fdb_add)(struct ndmsg *ndm, struct nlattr *tb[], |  * int (*ndo_fdb_add)(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
|  *		      struct net_device *dev, |  *		      struct net_device *dev, | ||||||
|  *		      const unsigned char *addr, u16 vid, u16 flags) |  *		      const unsigned char *addr, u16 vid, u16 flags, | ||||||
|  |  *		      struct netlink_ext_ack *extack); | ||||||
|  *	Adds an FDB entry to dev for addr. |  *	Adds an FDB entry to dev for addr. | ||||||
|  * int (*ndo_fdb_del)(struct ndmsg *ndm, struct nlattr *tb[], |  * int (*ndo_fdb_del)(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
|  *		      struct net_device *dev, |  *		      struct net_device *dev, | ||||||
| @ -1376,7 +1377,8 @@ struct net_device_ops { | |||||||
| 					       struct net_device *dev, | 					       struct net_device *dev, | ||||||
| 					       const unsigned char *addr, | 					       const unsigned char *addr, | ||||||
| 					       u16 vid, | 					       u16 vid, | ||||||
| 					       u16 flags); | 					       u16 flags, | ||||||
|  | 					       struct netlink_ext_ack *extack); | ||||||
| 	int			(*ndo_fdb_del)(struct ndmsg *ndm, | 	int			(*ndo_fdb_del)(struct ndmsg *ndm, | ||||||
| 					       struct nlattr *tb[], | 					       struct nlattr *tb[], | ||||||
| 					       struct net_device *dev, | 					       struct net_device *dev, | ||||||
|  | |||||||
| @ -915,7 +915,8 @@ static int __br_fdb_add(struct ndmsg *ndm, struct net_bridge *br, | |||||||
| /* Add new permanent fdb entry with RTM_NEWNEIGH */ | /* Add new permanent fdb entry with RTM_NEWNEIGH */ | ||||||
| int br_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | int br_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 	       struct net_device *dev, | 	       struct net_device *dev, | ||||||
| 	       const unsigned char *addr, u16 vid, u16 nlh_flags) | 	       const unsigned char *addr, u16 vid, u16 nlh_flags, | ||||||
|  | 	       struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct net_bridge_vlan_group *vg; | 	struct net_bridge_vlan_group *vg; | ||||||
| 	struct net_bridge_port *p = NULL; | 	struct net_bridge_port *p = NULL; | ||||||
|  | |||||||
| @ -573,7 +573,8 @@ void br_fdb_update(struct net_bridge *br, struct net_bridge_port *source, | |||||||
| int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], | int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 		  struct net_device *dev, const unsigned char *addr, u16 vid); | 		  struct net_device *dev, const unsigned char *addr, u16 vid); | ||||||
| int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, | int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, | ||||||
| 	       const unsigned char *addr, u16 vid, u16 nlh_flags); | 	       const unsigned char *addr, u16 vid, u16 nlh_flags, | ||||||
|  | 	       struct netlink_ext_ack *extack); | ||||||
| int br_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb, | int br_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb, | ||||||
| 		struct net_device *dev, struct net_device *fdev, int *idx); | 		struct net_device *dev, struct net_device *fdev, int *idx); | ||||||
| int br_fdb_get(struct sk_buff *skb, struct nlattr *tb[], struct net_device *dev, | int br_fdb_get(struct sk_buff *skb, struct nlattr *tb[], struct net_device *dev, | ||||||
|  | |||||||
| @ -3639,7 +3639,7 @@ static int rtnl_fdb_add(struct sk_buff *skb, struct nlmsghdr *nlh, | |||||||
| 		const struct net_device_ops *ops = br_dev->netdev_ops; | 		const struct net_device_ops *ops = br_dev->netdev_ops; | ||||||
| 
 | 
 | ||||||
| 		err = ops->ndo_fdb_add(ndm, tb, dev, addr, vid, | 		err = ops->ndo_fdb_add(ndm, tb, dev, addr, vid, | ||||||
| 				       nlh->nlmsg_flags); | 				       nlh->nlmsg_flags, extack); | ||||||
| 		if (err) | 		if (err) | ||||||
| 			goto out; | 			goto out; | ||||||
| 		else | 		else | ||||||
| @ -3651,7 +3651,8 @@ static int rtnl_fdb_add(struct sk_buff *skb, struct nlmsghdr *nlh, | |||||||
| 		if (dev->netdev_ops->ndo_fdb_add) | 		if (dev->netdev_ops->ndo_fdb_add) | ||||||
| 			err = dev->netdev_ops->ndo_fdb_add(ndm, tb, dev, addr, | 			err = dev->netdev_ops->ndo_fdb_add(ndm, tb, dev, addr, | ||||||
| 							   vid, | 							   vid, | ||||||
| 							   nlh->nlmsg_flags); | 							   nlh->nlmsg_flags, | ||||||
|  | 							   extack); | ||||||
| 		else | 		else | ||||||
| 			err = ndo_dflt_fdb_add(ndm, tb, dev, addr, vid, | 			err = ndo_dflt_fdb_add(ndm, tb, dev, addr, vid, | ||||||
| 					       nlh->nlmsg_flags); | 					       nlh->nlmsg_flags); | ||||||
|  | |||||||
| @ -103,7 +103,8 @@ static inline void dsa_legacy_unregister(void) { } | |||||||
| int dsa_legacy_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | int dsa_legacy_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 		       struct net_device *dev, | 		       struct net_device *dev, | ||||||
| 		       const unsigned char *addr, u16 vid, | 		       const unsigned char *addr, u16 vid, | ||||||
| 		       u16 flags); | 		       u16 flags, | ||||||
|  | 		       struct netlink_ext_ack *extack); | ||||||
| int dsa_legacy_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], | int dsa_legacy_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 		       struct net_device *dev, | 		       struct net_device *dev, | ||||||
| 		       const unsigned char *addr, u16 vid); | 		       const unsigned char *addr, u16 vid); | ||||||
|  | |||||||
| @ -1009,7 +1009,8 @@ static const struct ethtool_ops dsa_slave_ethtool_ops = { | |||||||
| int dsa_legacy_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | int dsa_legacy_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], | ||||||
| 		       struct net_device *dev, | 		       struct net_device *dev, | ||||||
| 		       const unsigned char *addr, u16 vid, | 		       const unsigned char *addr, u16 vid, | ||||||
| 		       u16 flags) | 		       u16 flags, | ||||||
|  | 		       struct netlink_ext_ack *extack) | ||||||
| { | { | ||||||
| 	struct dsa_port *dp = dsa_slave_to_port(dev); | 	struct dsa_port *dp = dsa_slave_to_port(dev); | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Petr Machata
						Petr Machata