|
@@ -231,18 +231,14 @@ static int bnx2x_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|
|
cmd->advertising &= ~(ADVERTISED_10000baseT_Full);
|
|
|
}
|
|
|
|
|
|
- if ((bp->state == BNX2X_STATE_OPEN) && (bp->link_vars.link_up)) {
|
|
|
- if (!(bp->flags & MF_FUNC_DIS)) {
|
|
|
- ethtool_cmd_speed_set(cmd, bp->link_vars.line_speed);
|
|
|
+ if ((bp->state == BNX2X_STATE_OPEN) && bp->link_vars.link_up &&
|
|
|
+ !(bp->flags & MF_FUNC_DIS)) {
|
|
|
cmd->duplex = bp->link_vars.duplex;
|
|
|
- } else {
|
|
|
- ethtool_cmd_speed_set(
|
|
|
- cmd, bp->link_params.req_line_speed[cfg_idx]);
|
|
|
- cmd->duplex = bp->link_params.req_duplex[cfg_idx];
|
|
|
- }
|
|
|
|
|
|
if (IS_MF(bp) && !BP_NOMCP(bp))
|
|
|
ethtool_cmd_speed_set(cmd, bnx2x_get_mf_speed(bp));
|
|
|
+ else
|
|
|
+ ethtool_cmd_speed_set(cmd, bp->link_vars.line_speed);
|
|
|
} else {
|
|
|
cmd->duplex = DUPLEX_UNKNOWN;
|
|
|
ethtool_cmd_speed_set(cmd, SPEED_UNKNOWN);
|