diff options
author | David Decotigny <decot@google.com> | 2011-04-27 14:32:38 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-04-29 17:01:30 -0400 |
commit | 8ae6daca85c8bbd6a32c382db5e2a2a989f8bed2 (patch) | |
tree | 0c85476c2af6568c3d3a73a960d582d2f91a1256 /drivers/net/stmmac | |
parent | 36504605432996590f889e33d47e2d9c581f7569 (diff) |
ethtool: Call ethtool's get/set_settings callbacks with cleaned data
This makes sure that when a driver calls the ethtool's
get/set_settings() callback of another driver, the data passed to it
is clean. This guarantees that speed_hi will be zeroed correctly if
the called callback doesn't explicitely set it: we are sure we don't
get a corrupted speed from the underlying driver. We also take care of
setting the cmd field appropriately (ETHTOOL_GSET/SSET).
This applies to dev_ethtool_get_settings(), which now makes sure it
sets up that ethtool command parameter correctly before passing it to
drivers. This also means that whoever calls dev_ethtool_get_settings()
does not have to clean the ethtool command parameter. This function
also becomes an exported symbol instead of an inline.
All drivers visible to make allyesconfig under x86_64 have been
updated.
Signed-off-by: David Decotigny <decot@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/stmmac')
-rw-r--r-- | drivers/net/stmmac/stmmac_ethtool.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/drivers/net/stmmac/stmmac_ethtool.c b/drivers/net/stmmac/stmmac_ethtool.c index 0e61ac8707cb..6f5aaeb986ff 100644 --- a/drivers/net/stmmac/stmmac_ethtool.c +++ b/drivers/net/stmmac/stmmac_ethtool.c | |||
@@ -237,13 +237,12 @@ stmmac_set_pauseparam(struct net_device *netdev, | |||
237 | 237 | ||
238 | if (phy->autoneg) { | 238 | if (phy->autoneg) { |
239 | if (netif_running(netdev)) { | 239 | if (netif_running(netdev)) { |
240 | struct ethtool_cmd cmd; | 240 | struct ethtool_cmd cmd = { .cmd = ETHTOOL_SSET }; |
241 | /* auto-negotiation automatically restarted */ | 241 | /* auto-negotiation automatically restarted */ |
242 | cmd.cmd = ETHTOOL_NWAY_RST; | ||
243 | cmd.supported = phy->supported; | 242 | cmd.supported = phy->supported; |
244 | cmd.advertising = phy->advertising; | 243 | cmd.advertising = phy->advertising; |
245 | cmd.autoneg = phy->autoneg; | 244 | cmd.autoneg = phy->autoneg; |
246 | cmd.speed = phy->speed; | 245 | ethtool_cmd_speed_set(&cmd, phy->speed); |
247 | cmd.duplex = phy->duplex; | 246 | cmd.duplex = phy->duplex; |
248 | cmd.phy_address = phy->addr; | 247 | cmd.phy_address = phy->addr; |
249 | ret = phy_ethtool_sset(phy, &cmd); | 248 | ret = phy_ethtool_sset(phy, &cmd); |