mirror of
https://github.com/torvalds/linux.git
synced 2026-05-28 09:04:39 +02:00
Merge branch 'mlx5e-misc-fixes-2025-09-15'
Tariq Toukan says: ==================== mlx5e misc fixes 2025-09-15 This patchset provides misc bug fixes from the team to the mlx5 Eth driver. ==================== Link: https://patch.msgid.link/1757939074-617281-1-git-send-email-tariqt@nvidia.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
commit
8c47485399
|
|
@ -92,6 +92,7 @@ enum {
|
|||
MLX5E_ACCEL_FS_ESP_FT_LEVEL = MLX5E_INNER_TTC_FT_LEVEL + 1,
|
||||
MLX5E_ACCEL_FS_ESP_FT_ERR_LEVEL,
|
||||
MLX5E_ACCEL_FS_POL_FT_LEVEL,
|
||||
MLX5E_ACCEL_FS_POL_MISS_FT_LEVEL,
|
||||
MLX5E_ACCEL_FS_ESP_FT_ROCE_LEVEL,
|
||||
#endif
|
||||
};
|
||||
|
|
|
|||
|
|
@ -185,6 +185,7 @@ struct mlx5e_ipsec_rx_create_attr {
|
|||
u32 family;
|
||||
int prio;
|
||||
int pol_level;
|
||||
int pol_miss_level;
|
||||
int sa_level;
|
||||
int status_level;
|
||||
enum mlx5_flow_namespace_type chains_ns;
|
||||
|
|
|
|||
|
|
@ -747,6 +747,7 @@ static void ipsec_rx_create_attr_set(struct mlx5e_ipsec *ipsec,
|
|||
attr->family = family;
|
||||
attr->prio = MLX5E_NIC_PRIO;
|
||||
attr->pol_level = MLX5E_ACCEL_FS_POL_FT_LEVEL;
|
||||
attr->pol_miss_level = MLX5E_ACCEL_FS_POL_MISS_FT_LEVEL;
|
||||
attr->sa_level = MLX5E_ACCEL_FS_ESP_FT_LEVEL;
|
||||
attr->status_level = MLX5E_ACCEL_FS_ESP_FT_ERR_LEVEL;
|
||||
attr->chains_ns = MLX5_FLOW_NAMESPACE_KERNEL;
|
||||
|
|
@ -833,7 +834,7 @@ static int ipsec_rx_chains_create_miss(struct mlx5e_ipsec *ipsec,
|
|||
|
||||
ft_attr.max_fte = 1;
|
||||
ft_attr.autogroup.max_num_groups = 1;
|
||||
ft_attr.level = attr->pol_level;
|
||||
ft_attr.level = attr->pol_miss_level;
|
||||
ft_attr.prio = attr->prio;
|
||||
|
||||
ft = mlx5_create_auto_grouped_flow_table(attr->ns, &ft_attr);
|
||||
|
|
|
|||
|
|
@ -1506,12 +1506,21 @@ static const struct mlx5e_profile mlx5e_uplink_rep_profile = {
|
|||
static int
|
||||
mlx5e_vport_uplink_rep_load(struct mlx5_core_dev *dev, struct mlx5_eswitch_rep *rep)
|
||||
{
|
||||
struct mlx5e_priv *priv = netdev_priv(mlx5_uplink_netdev_get(dev));
|
||||
struct mlx5e_rep_priv *rpriv = mlx5e_rep_to_rep_priv(rep);
|
||||
struct net_device *netdev;
|
||||
struct mlx5e_priv *priv;
|
||||
int err;
|
||||
|
||||
netdev = mlx5_uplink_netdev_get(dev);
|
||||
if (!netdev)
|
||||
return 0;
|
||||
|
||||
priv = netdev_priv(netdev);
|
||||
rpriv->netdev = priv->netdev;
|
||||
return mlx5e_netdev_change_profile(priv, &mlx5e_uplink_rep_profile,
|
||||
rpriv);
|
||||
err = mlx5e_netdev_change_profile(priv, &mlx5e_uplink_rep_profile,
|
||||
rpriv);
|
||||
mlx5_uplink_netdev_put(dev, netdev);
|
||||
return err;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
@ -1638,8 +1647,16 @@ mlx5e_vport_rep_unload(struct mlx5_eswitch_rep *rep)
|
|||
{
|
||||
struct mlx5e_rep_priv *rpriv = mlx5e_rep_to_rep_priv(rep);
|
||||
struct net_device *netdev = rpriv->netdev;
|
||||
struct mlx5e_priv *priv = netdev_priv(netdev);
|
||||
void *ppriv = priv->ppriv;
|
||||
struct mlx5e_priv *priv;
|
||||
void *ppriv;
|
||||
|
||||
if (!netdev) {
|
||||
ppriv = rpriv;
|
||||
goto free_ppriv;
|
||||
}
|
||||
|
||||
priv = netdev_priv(netdev);
|
||||
ppriv = priv->ppriv;
|
||||
|
||||
if (rep->vport == MLX5_VPORT_UPLINK) {
|
||||
mlx5e_vport_uplink_rep_unload(rpriv);
|
||||
|
|
|
|||
|
|
@ -1515,6 +1515,7 @@ static u32 mlx5_esw_qos_lag_link_speed_get_locked(struct mlx5_core_dev *mdev)
|
|||
speed = lksettings.base.speed;
|
||||
|
||||
out:
|
||||
mlx5_uplink_netdev_put(mdev, slave);
|
||||
return speed;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -114,9 +114,9 @@
|
|||
#define ETHTOOL_NUM_PRIOS 11
|
||||
#define ETHTOOL_MIN_LEVEL (KERNEL_MIN_LEVEL + ETHTOOL_NUM_PRIOS)
|
||||
/* Vlan, mac, ttc, inner ttc, {UDP/ANY/aRFS/accel/{esp, esp_err}}, IPsec policy,
|
||||
* {IPsec RoCE MPV,Alias table},IPsec RoCE policy
|
||||
* IPsec policy miss, {IPsec RoCE MPV,Alias table},IPsec RoCE policy
|
||||
*/
|
||||
#define KERNEL_NIC_PRIO_NUM_LEVELS 10
|
||||
#define KERNEL_NIC_PRIO_NUM_LEVELS 11
|
||||
#define KERNEL_NIC_NUM_PRIOS 1
|
||||
/* One more level for tc, and one more for promisc */
|
||||
#define KERNEL_MIN_LEVEL (KERNEL_NIC_PRIO_NUM_LEVELS + 2)
|
||||
|
|
|
|||
|
|
@ -47,7 +47,20 @@ int mlx5_crdump_collect(struct mlx5_core_dev *dev, u32 *cr_data);
|
|||
|
||||
static inline struct net_device *mlx5_uplink_netdev_get(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
return mdev->mlx5e_res.uplink_netdev;
|
||||
struct mlx5e_resources *mlx5e_res = &mdev->mlx5e_res;
|
||||
struct net_device *netdev;
|
||||
|
||||
mutex_lock(&mlx5e_res->uplink_netdev_lock);
|
||||
netdev = mlx5e_res->uplink_netdev;
|
||||
netdev_hold(netdev, &mlx5e_res->tracker, GFP_KERNEL);
|
||||
mutex_unlock(&mlx5e_res->uplink_netdev_lock);
|
||||
return netdev;
|
||||
}
|
||||
|
||||
static inline void mlx5_uplink_netdev_put(struct mlx5_core_dev *mdev,
|
||||
struct net_device *netdev)
|
||||
{
|
||||
netdev_put(netdev, &mdev->mlx5e_res.tracker);
|
||||
}
|
||||
|
||||
struct mlx5_sd;
|
||||
|
|
|
|||
|
|
@ -663,6 +663,7 @@ struct mlx5e_resources {
|
|||
bool tisn_valid;
|
||||
} hw_objs;
|
||||
struct net_device *uplink_netdev;
|
||||
netdevice_tracker tracker;
|
||||
struct mutex uplink_netdev_lock;
|
||||
struct mlx5_crypto_dek_priv *dek_priv;
|
||||
};
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user