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/scsi/bnx2fc | |
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/scsi/bnx2fc')
-rw-r--r-- | drivers/scsi/bnx2fc/bnx2fc_fcoe.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/scsi/bnx2fc/bnx2fc_fcoe.c b/drivers/scsi/bnx2fc/bnx2fc_fcoe.c index e2e647509a73..cd050196a163 100644 --- a/drivers/scsi/bnx2fc/bnx2fc_fcoe.c +++ b/drivers/scsi/bnx2fc/bnx2fc_fcoe.c | |||
@@ -664,7 +664,7 @@ static void bnx2fc_link_speed_update(struct fc_lport *lport) | |||
664 | struct fcoe_port *port = lport_priv(lport); | 664 | struct fcoe_port *port = lport_priv(lport); |
665 | struct bnx2fc_hba *hba = port->priv; | 665 | struct bnx2fc_hba *hba = port->priv; |
666 | struct net_device *netdev = hba->netdev; | 666 | struct net_device *netdev = hba->netdev; |
667 | struct ethtool_cmd ecmd = { ETHTOOL_GSET }; | 667 | struct ethtool_cmd ecmd; |
668 | 668 | ||
669 | if (!dev_ethtool_get_settings(netdev, &ecmd)) { | 669 | if (!dev_ethtool_get_settings(netdev, &ecmd)) { |
670 | lport->link_supported_speeds &= | 670 | lport->link_supported_speeds &= |
@@ -675,12 +675,15 @@ static void bnx2fc_link_speed_update(struct fc_lport *lport) | |||
675 | if (ecmd.supported & SUPPORTED_10000baseT_Full) | 675 | if (ecmd.supported & SUPPORTED_10000baseT_Full) |
676 | lport->link_supported_speeds |= FC_PORTSPEED_10GBIT; | 676 | lport->link_supported_speeds |= FC_PORTSPEED_10GBIT; |
677 | 677 | ||
678 | if (ecmd.speed == SPEED_1000) | 678 | switch (ethtool_cmd_speed(&ecmd)) { |
679 | case SPEED_1000: | ||
679 | lport->link_speed = FC_PORTSPEED_1GBIT; | 680 | lport->link_speed = FC_PORTSPEED_1GBIT; |
680 | if (ecmd.speed == SPEED_10000) | 681 | break; |
682 | case SPEED_10000: | ||
681 | lport->link_speed = FC_PORTSPEED_10GBIT; | 683 | lport->link_speed = FC_PORTSPEED_10GBIT; |
684 | break; | ||
685 | } | ||
682 | } | 686 | } |
683 | return; | ||
684 | } | 687 | } |
685 | static int bnx2fc_link_ok(struct fc_lport *lport) | 688 | static int bnx2fc_link_ok(struct fc_lport *lport) |
686 | { | 689 | { |