net/mlx5i: Enable Rx steering for IPoIB via ethtool
Enable steering IPoIB packets via ethtool, the same way it is done today for Ethernet packets. Signed-off-by: Moosa Baransi <moosab@nvidia.com> Reviewed-by: Tariq Toukan <tariqt@nvidia.com> Signed-off-by: Saeed Mahameed <saeedm@nvidia.com>
This commit is contained in:
parent
17ac528d88
commit
9fbe1c25ec
@ -125,15 +125,15 @@ struct mlx5e_ethtool_steering {
|
|||||||
|
|
||||||
void mlx5e_ethtool_init_steering(struct mlx5e_priv *priv);
|
void mlx5e_ethtool_init_steering(struct mlx5e_priv *priv);
|
||||||
void mlx5e_ethtool_cleanup_steering(struct mlx5e_priv *priv);
|
void mlx5e_ethtool_cleanup_steering(struct mlx5e_priv *priv);
|
||||||
int mlx5e_ethtool_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd);
|
int mlx5e_ethtool_set_rxnfc(struct mlx5e_priv *priv, struct ethtool_rxnfc *cmd);
|
||||||
int mlx5e_ethtool_get_rxnfc(struct net_device *dev,
|
int mlx5e_ethtool_get_rxnfc(struct mlx5e_priv *priv,
|
||||||
struct ethtool_rxnfc *info, u32 *rule_locs);
|
struct ethtool_rxnfc *info, u32 *rule_locs);
|
||||||
#else
|
#else
|
||||||
static inline void mlx5e_ethtool_init_steering(struct mlx5e_priv *priv) { }
|
static inline void mlx5e_ethtool_init_steering(struct mlx5e_priv *priv) { }
|
||||||
static inline void mlx5e_ethtool_cleanup_steering(struct mlx5e_priv *priv) { }
|
static inline void mlx5e_ethtool_cleanup_steering(struct mlx5e_priv *priv) { }
|
||||||
static inline int mlx5e_ethtool_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
static inline int mlx5e_ethtool_set_rxnfc(struct mlx5e_priv *priv, struct ethtool_rxnfc *cmd)
|
||||||
{ return -EOPNOTSUPP; }
|
{ return -EOPNOTSUPP; }
|
||||||
static inline int mlx5e_ethtool_get_rxnfc(struct net_device *dev,
|
static inline int mlx5e_ethtool_get_rxnfc(struct mlx5e_priv *priv,
|
||||||
struct ethtool_rxnfc *info, u32 *rule_locs)
|
struct ethtool_rxnfc *info, u32 *rule_locs)
|
||||||
{ return -EOPNOTSUPP; }
|
{ return -EOPNOTSUPP; }
|
||||||
#endif /* CONFIG_MLX5_EN_RXNFC */
|
#endif /* CONFIG_MLX5_EN_RXNFC */
|
||||||
|
@ -2137,12 +2137,14 @@ int mlx5e_get_rxnfc(struct net_device *dev, struct ethtool_rxnfc *info,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return mlx5e_ethtool_get_rxnfc(dev, info, rule_locs);
|
return mlx5e_ethtool_get_rxnfc(priv, info, rule_locs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5e_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
int mlx5e_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
||||||
{
|
{
|
||||||
return mlx5e_ethtool_set_rxnfc(dev, cmd);
|
struct mlx5e_priv *priv = netdev_priv(dev);
|
||||||
|
|
||||||
|
return mlx5e_ethtool_set_rxnfc(priv, cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int query_port_status_opcode(struct mlx5_core_dev *mdev, u32 *status_opcode)
|
static int query_port_status_opcode(struct mlx5_core_dev *mdev, u32 *status_opcode)
|
||||||
|
@ -937,9 +937,8 @@ static int mlx5e_get_rss_hash_opt(struct mlx5e_priv *priv,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5e_ethtool_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
int mlx5e_ethtool_set_rxnfc(struct mlx5e_priv *priv, struct ethtool_rxnfc *cmd)
|
||||||
{
|
{
|
||||||
struct mlx5e_priv *priv = netdev_priv(dev);
|
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
switch (cmd->cmd) {
|
switch (cmd->cmd) {
|
||||||
@ -960,10 +959,9 @@ int mlx5e_ethtool_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5e_ethtool_get_rxnfc(struct net_device *dev,
|
int mlx5e_ethtool_get_rxnfc(struct mlx5e_priv *priv,
|
||||||
struct ethtool_rxnfc *info, u32 *rule_locs)
|
struct ethtool_rxnfc *info, u32 *rule_locs)
|
||||||
{
|
{
|
||||||
struct mlx5e_priv *priv = netdev_priv(dev);
|
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
switch (info->cmd) {
|
switch (info->cmd) {
|
||||||
|
@ -33,6 +33,11 @@
|
|||||||
#include "en.h"
|
#include "en.h"
|
||||||
#include "ipoib.h"
|
#include "ipoib.h"
|
||||||
|
|
||||||
|
static u32 mlx5i_flow_type_mask(u32 flow_type)
|
||||||
|
{
|
||||||
|
return flow_type & ~(FLOW_EXT | FLOW_MAC_EXT | FLOW_RSS);
|
||||||
|
}
|
||||||
|
|
||||||
static void mlx5i_get_drvinfo(struct net_device *dev,
|
static void mlx5i_get_drvinfo(struct net_device *dev,
|
||||||
struct ethtool_drvinfo *drvinfo)
|
struct ethtool_drvinfo *drvinfo)
|
||||||
{
|
{
|
||||||
@ -217,6 +222,27 @@ static int mlx5i_get_link_ksettings(struct net_device *netdev,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_MLX5_EN_RXNFC
|
||||||
|
static int mlx5i_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd)
|
||||||
|
{
|
||||||
|
struct mlx5e_priv *priv = mlx5i_epriv(dev);
|
||||||
|
struct ethtool_rx_flow_spec *fs = &cmd->fs;
|
||||||
|
|
||||||
|
if (mlx5i_flow_type_mask(fs->flow_type) == ETHER_FLOW)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
return mlx5e_ethtool_set_rxnfc(priv, cmd);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int mlx5i_get_rxnfc(struct net_device *dev, struct ethtool_rxnfc *info,
|
||||||
|
u32 *rule_locs)
|
||||||
|
{
|
||||||
|
struct mlx5e_priv *priv = mlx5i_epriv(dev);
|
||||||
|
|
||||||
|
return mlx5e_ethtool_get_rxnfc(priv, info, rule_locs);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
const struct ethtool_ops mlx5i_ethtool_ops = {
|
const struct ethtool_ops mlx5i_ethtool_ops = {
|
||||||
.supported_coalesce_params = ETHTOOL_COALESCE_USECS |
|
.supported_coalesce_params = ETHTOOL_COALESCE_USECS |
|
||||||
ETHTOOL_COALESCE_MAX_FRAMES |
|
ETHTOOL_COALESCE_MAX_FRAMES |
|
||||||
@ -233,6 +259,10 @@ const struct ethtool_ops mlx5i_ethtool_ops = {
|
|||||||
.get_coalesce = mlx5i_get_coalesce,
|
.get_coalesce = mlx5i_get_coalesce,
|
||||||
.set_coalesce = mlx5i_set_coalesce,
|
.set_coalesce = mlx5i_set_coalesce,
|
||||||
.get_ts_info = mlx5i_get_ts_info,
|
.get_ts_info = mlx5i_get_ts_info,
|
||||||
|
#ifdef CONFIG_MLX5_EN_RXNFC
|
||||||
|
.get_rxnfc = mlx5i_get_rxnfc,
|
||||||
|
.set_rxnfc = mlx5i_set_rxnfc,
|
||||||
|
#endif
|
||||||
.get_link_ksettings = mlx5i_get_link_ksettings,
|
.get_link_ksettings = mlx5i_get_link_ksettings,
|
||||||
.get_link = ethtool_op_get_link,
|
.get_link = ethtool_op_get_link,
|
||||||
};
|
};
|
||||||
|
@ -336,6 +336,8 @@ static int mlx5i_create_flow_steering(struct mlx5e_priv *priv)
|
|||||||
goto err_destroy_arfs_tables;
|
goto err_destroy_arfs_tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mlx5e_ethtool_init_steering(priv);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_destroy_arfs_tables:
|
err_destroy_arfs_tables:
|
||||||
@ -348,6 +350,7 @@ static void mlx5i_destroy_flow_steering(struct mlx5e_priv *priv)
|
|||||||
{
|
{
|
||||||
mlx5e_destroy_ttc_table(priv);
|
mlx5e_destroy_ttc_table(priv);
|
||||||
mlx5e_arfs_destroy_tables(priv);
|
mlx5e_arfs_destroy_tables(priv);
|
||||||
|
mlx5e_ethtool_cleanup_steering(priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int mlx5i_init_rx(struct mlx5e_priv *priv)
|
static int mlx5i_init_rx(struct mlx5e_priv *priv)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user