aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/forcedeth.c
diff options
context:
space:
mode:
authorDavid Decotigny <decot@google.com>2011-04-27 14:32:40 -0400
committerDavid S. Miller <davem@davemloft.net>2011-04-29 17:03:01 -0400
commit707394972093e2056e1e8cc39be19cf9bcb3e7b3 (patch)
treef6dc95219bca6895adf304b79241e9d60561f8f5 /drivers/net/forcedeth.c
parent25db0338813a8915457636b1f6abe6a28fa73f8d (diff)
ethtool: cosmetic: Use ethtool ethtool_cmd_speed API
This updates the network drivers so that they don't access the ethtool_cmd::speed field directly, but use ethtool_cmd_speed() instead. For most of the drivers, these changes are purely cosmetic and don't fix any problem, such as for those 1GbE/10GbE drivers that indirectly call their own ethtool get_settings()/mii_ethtool_gset(). The changes are meant to enforce code consistency and provide robustness with future larger throughputs, at the expense of a few CPU cycles for each ethtool operation. All drivers compiled with make allyesconfig ion x86_64 have been updated. Tested: make allyesconfig on x86_64 + e1000e/bnx2x work Signed-off-by: David Decotigny <decot@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/forcedeth.c')
-rw-r--r--drivers/net/forcedeth.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/drivers/net/forcedeth.c b/drivers/net/forcedeth.c
index d24b3f3e646b..d09e8b0add01 100644
--- a/drivers/net/forcedeth.c
+++ b/drivers/net/forcedeth.c
@@ -3955,6 +3955,7 @@ static int nv_set_wol(struct net_device *dev, struct ethtool_wolinfo *wolinfo)
3955static int nv_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd) 3955static int nv_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
3956{ 3956{
3957 struct fe_priv *np = netdev_priv(dev); 3957 struct fe_priv *np = netdev_priv(dev);
3958 u32 speed;
3958 int adv; 3959 int adv;
3959 3960
3960 spin_lock_irq(&np->lock); 3961 spin_lock_irq(&np->lock);
@@ -3974,23 +3975,26 @@ static int nv_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
3974 if (netif_carrier_ok(dev)) { 3975 if (netif_carrier_ok(dev)) {
3975 switch (np->linkspeed & (NVREG_LINKSPEED_MASK)) { 3976 switch (np->linkspeed & (NVREG_LINKSPEED_MASK)) {
3976 case NVREG_LINKSPEED_10: 3977 case NVREG_LINKSPEED_10:
3977 ecmd->speed = SPEED_10; 3978 speed = SPEED_10;
3978 break; 3979 break;
3979 case NVREG_LINKSPEED_100: 3980 case NVREG_LINKSPEED_100:
3980 ecmd->speed = SPEED_100; 3981 speed = SPEED_100;
3981 break; 3982 break;
3982 case NVREG_LINKSPEED_1000: 3983 case NVREG_LINKSPEED_1000:
3983 ecmd->speed = SPEED_1000; 3984 speed = SPEED_1000;
3985 break;
3986 default:
3987 speed = -1;
3984 break; 3988 break;
3985 } 3989 }
3986 ecmd->duplex = DUPLEX_HALF; 3990 ecmd->duplex = DUPLEX_HALF;
3987 if (np->duplex) 3991 if (np->duplex)
3988 ecmd->duplex = DUPLEX_FULL; 3992 ecmd->duplex = DUPLEX_FULL;
3989 } else { 3993 } else {
3990 ecmd->speed = -1; 3994 speed = -1;
3991 ecmd->duplex = -1; 3995 ecmd->duplex = -1;
3992 } 3996 }
3993 3997 ethtool_cmd_speed_set(ecmd, speed);
3994 ecmd->autoneg = np->autoneg; 3998 ecmd->autoneg = np->autoneg;
3995 3999
3996 ecmd->advertising = ADVERTISED_MII; 4000 ecmd->advertising = ADVERTISED_MII;