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 /include | |
| 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 'include')
| -rw-r--r-- | include/linux/ethtool.h | 4 | ||||
| -rw-r--r-- | include/linux/netdevice.h | 9 | ||||
| -rw-r--r-- | include/rdma/ib_addr.h | 13 |
3 files changed, 12 insertions, 14 deletions
diff --git a/include/linux/ethtool.h b/include/linux/ethtool.h index 7e6e0a89ca26..4194a2067a14 100644 --- a/include/linux/ethtool.h +++ b/include/linux/ethtool.h | |||
| @@ -744,7 +744,9 @@ bool ethtool_invalid_flags(struct net_device *dev, u32 data, u32 supported); | |||
| 744 | /** | 744 | /** |
| 745 | * struct ethtool_ops - optional netdev operations | 745 | * struct ethtool_ops - optional netdev operations |
| 746 | * @get_settings: Get various device settings including Ethernet link | 746 | * @get_settings: Get various device settings including Ethernet link |
| 747 | * settings. Returns a negative error code or zero. | 747 | * settings. The @cmd parameter is expected to have been cleared |
| 748 | * before get_settings is called. Returns a negative error code or | ||
| 749 | * zero. | ||
| 748 | * @set_settings: Set various device settings including Ethernet link | 750 | * @set_settings: Set various device settings including Ethernet link |
| 749 | * settings. Returns a negative error code or zero. | 751 | * settings. Returns a negative error code or zero. |
| 750 | * @get_drvinfo: Report driver/device information. Should only set the | 752 | * @get_drvinfo: Report driver/device information. Should only set the |
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index e03af35843bc..d5de66af46f9 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h | |||
| @@ -2597,13 +2597,8 @@ static inline int netif_is_bond_slave(struct net_device *dev) | |||
| 2597 | 2597 | ||
| 2598 | extern struct pernet_operations __net_initdata loopback_net_ops; | 2598 | extern struct pernet_operations __net_initdata loopback_net_ops; |
| 2599 | 2599 | ||
| 2600 | static inline int dev_ethtool_get_settings(struct net_device *dev, | 2600 | int dev_ethtool_get_settings(struct net_device *dev, |
| 2601 | struct ethtool_cmd *cmd) | 2601 | struct ethtool_cmd *cmd); |
| 2602 | { | ||
| 2603 | if (!dev->ethtool_ops || !dev->ethtool_ops->get_settings) | ||
| 2604 | return -EOPNOTSUPP; | ||
| 2605 | return dev->ethtool_ops->get_settings(dev, cmd); | ||
| 2606 | } | ||
| 2607 | 2602 | ||
| 2608 | static inline u32 dev_ethtool_get_rx_csum(struct net_device *dev) | 2603 | static inline u32 dev_ethtool_get_rx_csum(struct net_device *dev) |
| 2609 | { | 2604 | { |
diff --git a/include/rdma/ib_addr.h b/include/rdma/ib_addr.h index b5fc9f39122b..ae8c68f30f1b 100644 --- a/include/rdma/ib_addr.h +++ b/include/rdma/ib_addr.h | |||
| @@ -217,18 +217,19 @@ static inline enum ib_mtu iboe_get_mtu(int mtu) | |||
| 217 | static inline int iboe_get_rate(struct net_device *dev) | 217 | static inline int iboe_get_rate(struct net_device *dev) |
| 218 | { | 218 | { |
| 219 | struct ethtool_cmd cmd; | 219 | struct ethtool_cmd cmd; |
| 220 | u32 speed; | ||
| 220 | 221 | ||
| 221 | if (!dev->ethtool_ops || !dev->ethtool_ops->get_settings || | 222 | if (dev_ethtool_get_settings(dev, &cmd)) |
| 222 | dev->ethtool_ops->get_settings(dev, &cmd)) | ||
| 223 | return IB_RATE_PORT_CURRENT; | 223 | return IB_RATE_PORT_CURRENT; |
| 224 | 224 | ||
| 225 | if (cmd.speed >= 40000) | 225 | speed = ethtool_cmd_speed(&cmd); |
| 226 | if (speed >= 40000) | ||
| 226 | return IB_RATE_40_GBPS; | 227 | return IB_RATE_40_GBPS; |
| 227 | else if (cmd.speed >= 30000) | 228 | else if (speed >= 30000) |
| 228 | return IB_RATE_30_GBPS; | 229 | return IB_RATE_30_GBPS; |
| 229 | else if (cmd.speed >= 20000) | 230 | else if (speed >= 20000) |
| 230 | return IB_RATE_20_GBPS; | 231 | return IB_RATE_20_GBPS; |
| 231 | else if (cmd.speed >= 10000) | 232 | else if (speed >= 10000) |
| 232 | return IB_RATE_10_GBPS; | 233 | return IB_RATE_10_GBPS; |
| 233 | else | 234 | else |
| 234 | return IB_RATE_PORT_CURRENT; | 235 | return IB_RATE_PORT_CURRENT; |
