forked from Minki/linux
mlxsw: spectrum: Prevent force of 56G
Force of 56G is not supported by hardware in Ethernet devices. This
configuration fails with a bad parameter error from firmware.
Add check of this case. Instead of trying to set 56G with autoneg off,
return a meaningful error.
Fixes: 56ade8fe3f
("mlxsw: spectrum: Add initial support for Spectrum ASIC")
Signed-off-by: Amit Cohen <amitc@mellanox.com>
Acked-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
ef74422020
commit
275e928f19
@ -3128,6 +3128,10 @@ mlxsw_sp_port_set_link_ksettings(struct net_device *dev,
|
|||||||
ops->reg_ptys_eth_unpack(mlxsw_sp, ptys_pl, ð_proto_cap, NULL, NULL);
|
ops->reg_ptys_eth_unpack(mlxsw_sp, ptys_pl, ð_proto_cap, NULL, NULL);
|
||||||
|
|
||||||
autoneg = cmd->base.autoneg == AUTONEG_ENABLE;
|
autoneg = cmd->base.autoneg == AUTONEG_ENABLE;
|
||||||
|
if (!autoneg && cmd->base.speed == SPEED_56000) {
|
||||||
|
netdev_err(dev, "56G not supported with autoneg off\n");
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
eth_proto_new = autoneg ?
|
eth_proto_new = autoneg ?
|
||||||
ops->to_ptys_advert_link(mlxsw_sp, cmd) :
|
ops->to_ptys_advert_link(mlxsw_sp, cmd) :
|
||||||
ops->to_ptys_speed(mlxsw_sp, cmd->base.speed);
|
ops->to_ptys_speed(mlxsw_sp, cmd->base.speed);
|
||||||
|
Loading…
Reference in New Issue
Block a user