net: propagate tc filter chain index down the ndo_setup_tc call
We need to push the chain index down to the drivers, so they have the information to which chain the rule belongs. For now, no driver supports multichain offload, so only chain 0 is supported. This is needed to prevent chain squashes during offload for now. Later this will be used to implement multichain offload. Signed-off-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
50dffe7fad
commit
a5fcf8a6c9
@ -32,8 +32,8 @@ netdev_tx_t efx_hard_start_xmit(struct sk_buff *skb,
|
||||
struct net_device *net_dev);
|
||||
netdev_tx_t efx_enqueue_skb(struct efx_tx_queue *tx_queue, struct sk_buff *skb);
|
||||
void efx_xmit_done(struct efx_tx_queue *tx_queue, unsigned int index);
|
||||
int efx_setup_tc(struct net_device *net_dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc);
|
||||
int efx_setup_tc(struct net_device *net_dev, u32 handle, u32 chain_index,
|
||||
__be16 proto, struct tc_to_netdev *tc);
|
||||
unsigned int efx_tx_max_skb_descs(struct efx_nic *efx);
|
||||
extern unsigned int efx_piobuf_size;
|
||||
extern bool efx_separate_tx_channels;
|
||||
|
@ -32,8 +32,8 @@ netdev_tx_t ef4_hard_start_xmit(struct sk_buff *skb,
|
||||
struct net_device *net_dev);
|
||||
netdev_tx_t ef4_enqueue_skb(struct ef4_tx_queue *tx_queue, struct sk_buff *skb);
|
||||
void ef4_xmit_done(struct ef4_tx_queue *tx_queue, unsigned int index);
|
||||
int ef4_setup_tc(struct net_device *net_dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *tc);
|
||||
int ef4_setup_tc(struct net_device *net_dev, u32 handle, u32 chain_index,
|
||||
__be16 proto, struct tc_to_netdev *tc);
|
||||
unsigned int ef4_tx_max_skb_descs(struct ef4_nic *efx);
|
||||
extern bool ef4_separate_tx_channels;
|
||||
|
||||
|
@ -425,8 +425,8 @@ void ef4_init_tx_queue_core_txq(struct ef4_tx_queue *tx_queue)
|
||||
efx->n_tx_channels : 0));
|
||||
}
|
||||
|
||||
int ef4_setup_tc(struct net_device *net_dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *ntc)
|
||||
int ef4_setup_tc(struct net_device *net_dev, u32 handle, u32 chain_index,
|
||||
__be16 proto, struct tc_to_netdev *ntc)
|
||||
{
|
||||
struct ef4_nic *efx = netdev_priv(net_dev);
|
||||
struct ef4_channel *channel;
|
||||
|
@ -653,8 +653,8 @@ void efx_init_tx_queue_core_txq(struct efx_tx_queue *tx_queue)
|
||||
efx->n_tx_channels : 0));
|
||||
}
|
||||
|
||||
int efx_setup_tc(struct net_device *net_dev, u32 handle, __be16 proto,
|
||||
struct tc_to_netdev *ntc)
|
||||
int efx_setup_tc(struct net_device *net_dev, u32 handle, u32 chain_index,
|
||||
__be16 proto, struct tc_to_netdev *ntc)
|
||||
{
|
||||
struct efx_nic *efx = netdev_priv(net_dev);
|
||||
struct efx_channel *channel;
|
||||
|
Reference in New Issue
Block a user