net: rework setup_tc ndo op to consume general tc operand
This patch updates setup_tc so we can pass additional parameters into the ndo op in a generic way. To do this we provide structured union and type flag. This lets each classifier and qdisc provide its own set of attributes without having to add new ndo ops or grow the signature of the callback. Signed-off-by: John Fastabend <john.r.fastabend@intel.com> Acked-by: Jiri Pirko <jiri@mellanox.com> Acked-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
e4c6734eaa
commit
16e5cc6471
@@ -1204,12 +1204,13 @@ err_queueing_scheme:
|
||||
return err;
|
||||
}
|
||||
|
||||
static int __fm10k_setup_tc(struct net_device *dev, u32 handle, u8 tc)
|
||||
static int __fm10k_setup_tc(struct net_device *dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc)
|
||||
{
|
||||
if (handle != TC_H_ROOT)
|
||||
if (handle != TC_H_ROOT || tc->type != TC_SETUP_MQPRIO)
|
||||
return -EINVAL;
|
||||
|
||||
return fm10k_setup_tc(dev, tc);
|
||||
return fm10k_setup_tc(dev, tc->tc);
|
||||
}
|
||||
|
||||
static int fm10k_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
|
||||
|
@@ -788,7 +788,8 @@ struct i40e_mac_filter *i40e_find_mac(struct i40e_vsi *vsi, u8 *macaddr,
|
||||
bool is_vf, bool is_netdev);
|
||||
#ifdef I40E_FCOE
|
||||
int i40e_close(struct net_device *netdev);
|
||||
int __i40e_setup_tc(struct net_device *netdev, u32 handle, u8 tc);
|
||||
int __i40e_setup_tc(struct net_device *netdev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc);
|
||||
void i40e_netpoll(struct net_device *netdev);
|
||||
int i40e_fcoe_enable(struct net_device *netdev);
|
||||
int i40e_fcoe_disable(struct net_device *netdev);
|
||||
|
@@ -5307,14 +5307,16 @@ exit:
|
||||
}
|
||||
|
||||
#ifdef I40E_FCOE
|
||||
int __i40e_setup_tc(struct net_device *netdev, u32 handle, u8 tc)
|
||||
int __i40e_setup_tc(struct net_device *netdev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc)
|
||||
#else
|
||||
static int __i40e_setup_tc(struct net_device *netdev, u32 handle, u8 tc)
|
||||
static int __i40e_setup_tc(struct net_device *netdev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc)
|
||||
#endif
|
||||
{
|
||||
if (handle != TC_H_ROOT)
|
||||
if (handle != TC_H_ROOT || tc->type != TC_SETUP_MQPRIO)
|
||||
return -EINVAL;
|
||||
return i40e_setup_tc(netdev, tc);
|
||||
return i40e_setup_tc(netdev, tc->tc);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -8200,13 +8200,14 @@ int ixgbe_setup_tc(struct net_device *dev, u8 tc)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int __ixgbe_setup_tc(struct net_device *dev, u32 handle, u8 tc)
|
||||
int __ixgbe_setup_tc(struct net_device *dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc)
|
||||
{
|
||||
/* Only support egress tc setup for now */
|
||||
if (handle != TC_H_ROOT)
|
||||
if (handle != TC_H_ROOT || tc->type != TC_SETUP_MQPRIO)
|
||||
return -EINVAL;
|
||||
|
||||
return ixgbe_setup_tc(dev, tc);
|
||||
return ixgbe_setup_tc(dev, tc->tc);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_PCI_IOV
|
||||
|
Reference in New Issue
Block a user