|
@@ -238,7 +238,7 @@ static int bnx2x_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|
speed |= (cmd->speed_hi << 16);
|
|
speed |= (cmd->speed_hi << 16);
|
|
|
|
|
|
if (IS_MF_SI(bp)) {
|
|
if (IS_MF_SI(bp)) {
|
|
- u32 param = 0;
|
|
|
|
|
|
+ u32 param = 0, part;
|
|
u32 line_speed = bp->link_vars.line_speed;
|
|
u32 line_speed = bp->link_vars.line_speed;
|
|
|
|
|
|
/* use 10G if no link detected */
|
|
/* use 10G if no link detected */
|
|
@@ -251,9 +251,11 @@ static int bnx2x_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|
REQ_BC_VER_4_SET_MF_BW);
|
|
REQ_BC_VER_4_SET_MF_BW);
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|
|
- if (line_speed < speed) {
|
|
|
|
- BNX2X_DEV_INFO("New speed should be less or equal "
|
|
|
|
- "to actual line speed\n");
|
|
|
|
|
|
+ part = (speed * 100) / line_speed;
|
|
|
|
+ if (line_speed < speed || !part) {
|
|
|
|
+ BNX2X_DEV_INFO("Speed setting should be in a range "
|
|
|
|
+ "from 1%% to 100%% "
|
|
|
|
+ "of actual line speed\n");
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|
|
/* load old values */
|
|
/* load old values */
|
|
@@ -263,8 +265,7 @@ static int bnx2x_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|
param &= FUNC_MF_CFG_MIN_BW_MASK;
|
|
param &= FUNC_MF_CFG_MIN_BW_MASK;
|
|
|
|
|
|
/* set new MAX value */
|
|
/* set new MAX value */
|
|
- param |= (((speed * 100) / line_speed)
|
|
|
|
- << FUNC_MF_CFG_MAX_BW_SHIFT)
|
|
|
|
|
|
+ param |= (part << FUNC_MF_CFG_MAX_BW_SHIFT)
|
|
& FUNC_MF_CFG_MAX_BW_MASK;
|
|
& FUNC_MF_CFG_MAX_BW_MASK;
|
|
|
|
|
|
bnx2x_fw_command(bp, DRV_MSG_CODE_SET_MF_BW, param);
|
|
bnx2x_fw_command(bp, DRV_MSG_CODE_SET_MF_BW, param);
|