net/mlx5e: NIC netdev init flow cleanup
Remove redundant call to unregister vport representor in mlx5e_add error
flow.
Hide the representor priv and eswitch internal structures from en_main.c
as preparation step for downstream patches which would allow building
the driver without support for representors and eswitch.
Fixes: 6f08a22c5f
("net/mlx5e: Register/unregister vport representors on interface attach/detach")
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
Reviewed-by: Or Gerlitz <ogerlitz@mellanox.com>
This commit is contained in:
parent
706b358348
commit
07c9f1e578
@ -4428,32 +4428,27 @@ static void mlx5e_detach(struct mlx5_core_dev *mdev, void *vpriv)
|
||||
|
||||
static void *mlx5e_add(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
struct mlx5_eswitch *esw = mdev->priv.eswitch;
|
||||
int total_vfs = MLX5_TOTAL_VPORTS(mdev);
|
||||
struct mlx5e_rep_priv *rpriv = NULL;
|
||||
void *priv;
|
||||
int vport;
|
||||
int err;
|
||||
struct net_device *netdev;
|
||||
void *rpriv = NULL;
|
||||
void *priv;
|
||||
int err;
|
||||
|
||||
err = mlx5e_check_required_hca_cap(mdev);
|
||||
if (err)
|
||||
return NULL;
|
||||
|
||||
if (MLX5_CAP_GEN(mdev, vport_group_manager)) {
|
||||
rpriv = kzalloc(sizeof(*rpriv), GFP_KERNEL);
|
||||
rpriv = mlx5e_alloc_nic_rep_priv(mdev);
|
||||
if (!rpriv) {
|
||||
mlx5_core_warn(mdev,
|
||||
"Not creating net device, Failed to alloc rep priv data\n");
|
||||
mlx5_core_warn(mdev, "Failed to alloc NIC rep priv data\n");
|
||||
return NULL;
|
||||
}
|
||||
rpriv->rep = &esw->offloads.vport_reps[0];
|
||||
}
|
||||
|
||||
netdev = mlx5e_create_netdev(mdev, &mlx5e_nic_profile, rpriv);
|
||||
if (!netdev) {
|
||||
mlx5_core_err(mdev, "mlx5e_create_netdev failed\n");
|
||||
goto err_unregister_reps;
|
||||
goto err_free_rpriv;
|
||||
}
|
||||
|
||||
priv = netdev_priv(netdev);
|
||||
@ -4474,14 +4469,9 @@ static void *mlx5e_add(struct mlx5_core_dev *mdev)
|
||||
|
||||
err_detach:
|
||||
mlx5e_detach(mdev, priv);
|
||||
|
||||
err_destroy_netdev:
|
||||
mlx5e_destroy_netdev(priv);
|
||||
|
||||
err_unregister_reps:
|
||||
for (vport = 1; vport < total_vfs; vport++)
|
||||
mlx5_eswitch_unregister_vport_rep(esw, vport);
|
||||
|
||||
err_free_rpriv:
|
||||
kfree(rpriv);
|
||||
return NULL;
|
||||
}
|
||||
|
@ -1099,3 +1099,16 @@ void mlx5e_unregister_vport_reps(struct mlx5e_priv *priv)
|
||||
mlx5e_rep_unregister_vf_vports(priv); /* VFs vports */
|
||||
mlx5_eswitch_unregister_vport_rep(esw, 0); /* UPLINK PF*/
|
||||
}
|
||||
|
||||
void *mlx5e_alloc_nic_rep_priv(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
struct mlx5_eswitch *esw = mdev->priv.eswitch;
|
||||
struct mlx5e_rep_priv *rpriv;
|
||||
|
||||
rpriv = kzalloc(sizeof(*rpriv), GFP_KERNEL);
|
||||
if (!rpriv)
|
||||
return NULL;
|
||||
|
||||
rpriv->rep = &esw->offloads.vport_reps[0];
|
||||
return rpriv;
|
||||
}
|
||||
|
@ -123,6 +123,7 @@ struct mlx5e_encap_entry {
|
||||
int encap_size;
|
||||
};
|
||||
|
||||
void *mlx5e_alloc_nic_rep_priv(struct mlx5_core_dev *mdev);
|
||||
void mlx5e_register_vport_reps(struct mlx5e_priv *priv);
|
||||
void mlx5e_unregister_vport_reps(struct mlx5e_priv *priv);
|
||||
bool mlx5e_is_uplink_rep(struct mlx5e_priv *priv);
|
||||
|
Loading…
Reference in New Issue
Block a user