mlxsw: spectrum: Set port type before setting its address
During port init, we currently set the port's type to Ethernet after
setting its MAC address. However, the hardware documentation states this
should be the other way around.
Align the driver with the hardware documentation and set the port's MAC
address after setting its type.
Fixes: 56ade8fe3f
("mlxsw: spectrum: Add initial support for Spectrum ASIC")
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
40d2590455
commit
3247ff2b31
|
@ -2106,6 +2106,13 @@ static int mlxsw_sp_port_create(struct mlxsw_sp *mlxsw_sp, u8 local_port,
|
|||
dev->netdev_ops = &mlxsw_sp_port_netdev_ops;
|
||||
dev->ethtool_ops = &mlxsw_sp_port_ethtool_ops;
|
||||
|
||||
err = mlxsw_sp_port_swid_set(mlxsw_sp_port, 0);
|
||||
if (err) {
|
||||
dev_err(mlxsw_sp->bus_info->dev, "Port %d: Failed to set SWID\n",
|
||||
mlxsw_sp_port->local_port);
|
||||
goto err_port_swid_set;
|
||||
}
|
||||
|
||||
err = mlxsw_sp_port_dev_addr_init(mlxsw_sp_port);
|
||||
if (err) {
|
||||
dev_err(mlxsw_sp->bus_info->dev, "Port %d: Unable to init port mac address\n",
|
||||
|
@ -2131,13 +2138,6 @@ static int mlxsw_sp_port_create(struct mlxsw_sp *mlxsw_sp, u8 local_port,
|
|||
goto err_port_system_port_mapping_set;
|
||||
}
|
||||
|
||||
err = mlxsw_sp_port_swid_set(mlxsw_sp_port, 0);
|
||||
if (err) {
|
||||
dev_err(mlxsw_sp->bus_info->dev, "Port %d: Failed to set SWID\n",
|
||||
mlxsw_sp_port->local_port);
|
||||
goto err_port_swid_set;
|
||||
}
|
||||
|
||||
err = mlxsw_sp_port_speed_by_width_set(mlxsw_sp_port, width);
|
||||
if (err) {
|
||||
dev_err(mlxsw_sp->bus_info->dev, "Port %d: Failed to enable speeds\n",
|
||||
|
@ -2219,10 +2219,10 @@ err_port_buffers_init:
|
|||
err_port_admin_status_set:
|
||||
err_port_mtu_set:
|
||||
err_port_speed_by_width_set:
|
||||
mlxsw_sp_port_swid_set(mlxsw_sp_port, MLXSW_PORT_SWID_DISABLED_PORT);
|
||||
err_port_swid_set:
|
||||
err_port_system_port_mapping_set:
|
||||
err_dev_addr_init:
|
||||
mlxsw_sp_port_swid_set(mlxsw_sp_port, MLXSW_PORT_SWID_DISABLED_PORT);
|
||||
err_port_swid_set:
|
||||
free_percpu(mlxsw_sp_port->pcpu_stats);
|
||||
err_alloc_stats:
|
||||
kfree(mlxsw_sp_port->untagged_vlans);
|
||||
|
|
Loading…
Reference in New Issue