diff options
author | Amir Vadai <amirv@mellanox.com> | 2012-07-18 18:33:52 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-07-19 11:34:37 -0400 |
commit | 1eb8c695bda92ccaec30e9a3351e37a1896da54f (patch) | |
tree | a5c73ef50598f37bc3bdead53425dcedb7ae9bca /drivers/net/ethernet/mellanox/mlx4/en_rx.c | |
parent | d9236c3f10490cd0b3fd4516af12ba62dcbae0b0 (diff) |
net/mlx4_en: Add accelerated RFS support
Use RFS infrastructure and flow steering in HW to keep CPU
affinity of rx interrupts and application per TCP stream.
A flow steering filter is added to the HW whenever the RFS
ndo callback is invoked by core networking code.
Because the invocation takes place in interrupt context, the
actual setup of HW is done using workqueue. Whenever new filter
is added, the driver checks for expiry of existing filters.
Since there's window in time between the point where the core
RFS code invoked the ndo callback, to the point where the HW
is configured from the workqueue context, the 2nd, 3rd etc
packets from that stream will cause the net core to invoke
the callback again and again.
To prevent inefficient/double configuration of the HW, the filters
are kept in a database which is indexed using hash function to enable
fast access.
Signed-off-by: Amir Vadai <amirv@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/mellanox/mlx4/en_rx.c')
-rw-r--r-- | drivers/net/ethernet/mellanox/mlx4/en_rx.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/ethernet/mellanox/mlx4/en_rx.c b/drivers/net/ethernet/mellanox/mlx4/en_rx.c index a04cbf767eb5..796cd58e6229 100644 --- a/drivers/net/ethernet/mellanox/mlx4/en_rx.c +++ b/drivers/net/ethernet/mellanox/mlx4/en_rx.c | |||
@@ -389,6 +389,9 @@ void mlx4_en_destroy_rx_ring(struct mlx4_en_priv *priv, | |||
389 | mlx4_free_hwq_res(mdev->dev, &ring->wqres, size * stride + TXBB_SIZE); | 389 | mlx4_free_hwq_res(mdev->dev, &ring->wqres, size * stride + TXBB_SIZE); |
390 | vfree(ring->rx_info); | 390 | vfree(ring->rx_info); |
391 | ring->rx_info = NULL; | 391 | ring->rx_info = NULL; |
392 | #ifdef CONFIG_RFS_ACCEL | ||
393 | mlx4_en_cleanup_filters(priv, ring); | ||
394 | #endif | ||
392 | } | 395 | } |
393 | 396 | ||
394 | void mlx4_en_deactivate_rx_ring(struct mlx4_en_priv *priv, | 397 | void mlx4_en_deactivate_rx_ring(struct mlx4_en_priv *priv, |