aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorMatt Carlson <mcarlson@broadcom.com>2010-10-14 06:37:44 -0400
committerDavid S. Miller <davem@davemloft.net>2010-10-17 16:57:45 -0400
commit64c2218266996b562a8e940a95a887fc432daced (patch)
tree0546b538923bdac20ff3accbf3996b4e1e2e2e9e /drivers/net
parent4803572815feea2dca9485a343a8556c9037e36e (diff)
tg3: Report invalid link from tg3_get_settings()
Currently the tg3 driver leaves the speed and duplex fields uninitialized in tg3_get_settings() if the device is not up. This can lead to some strange deductions in certain versions of ethtool. When the device is up and the link is down, the driver reports SPEED_INVALID and DUPLEX_INVALID for these fields. This patch makes the presentation consistent by returning SPEED_INVALID and DUPLEX_INVALID when the device has not been brought up as well. Signed-off-by: Matt Carlson <mcarlson@broadcom.com> Reviewed-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/tg3.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index 17ca0a37c9e7..5d30e67ffe69 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -9807,6 +9807,9 @@ static int tg3_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
9807 if (netif_running(dev)) { 9807 if (netif_running(dev)) {
9808 cmd->speed = tp->link_config.active_speed; 9808 cmd->speed = tp->link_config.active_speed;
9809 cmd->duplex = tp->link_config.active_duplex; 9809 cmd->duplex = tp->link_config.active_duplex;
9810 } else {
9811 cmd->speed = SPEED_INVALID;
9812 cmd->duplex = DUPLEX_INVALID;
9810 } 9813 }
9811 cmd->phy_address = tp->phy_addr; 9814 cmd->phy_address = tp->phy_addr;
9812 cmd->transceiver = XCVR_INTERNAL; 9815 cmd->transceiver = XCVR_INTERNAL;