diff options
author | Somnath Kotur <somnath.kotur@emulex.com> | 2013-05-26 17:08:36 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-05-28 01:27:02 -0400 |
commit | eeb65cedd78ebd375608d71d703e6b0b9296efbd (patch) | |
tree | 2248f522ec63fea57be206ce8ce24bf2593b1b98 /drivers/net/ethernet/emulex | |
parent | 3fb43eb20aec3f5ceed5813a035f200dafb51257 (diff) |
be2net: cleanup be_get_drvinfo()
Removing the be_cmd_get_fw_ver() query from be_get_drvinfo() and invoking
the same from be_setup() and/or post firmware download.
Signed-off-by: Kalesh AP <kalesh.purayil@emulex.com>
Signed-off-by: Somnath Kotur <somnath.kotur@emulex.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/emulex')
-rw-r--r-- | drivers/net/ethernet/emulex/benet/be.h | 1 | ||||
-rw-r--r-- | drivers/net/ethernet/emulex/benet/be_ethtool.c | 8 | ||||
-rw-r--r-- | drivers/net/ethernet/emulex/benet/be_main.c | 6 |
3 files changed, 8 insertions, 7 deletions
diff --git a/drivers/net/ethernet/emulex/benet/be.h b/drivers/net/ethernet/emulex/benet/be.h index f544b297c9ab..edce38bf83c9 100644 --- a/drivers/net/ethernet/emulex/benet/be.h +++ b/drivers/net/ethernet/emulex/benet/be.h | |||
@@ -397,6 +397,7 @@ struct be_adapter { | |||
397 | u32 cmd_privileges; | 397 | u32 cmd_privileges; |
398 | /* Ethtool knobs and info */ | 398 | /* Ethtool knobs and info */ |
399 | char fw_ver[FW_VER_LEN]; | 399 | char fw_ver[FW_VER_LEN]; |
400 | char fw_on_flash[FW_VER_LEN]; | ||
400 | int if_handle; /* Used to configure filtering */ | 401 | int if_handle; /* Used to configure filtering */ |
401 | u32 *pmac_id; /* MAC addr handle used by BE card */ | 402 | u32 *pmac_id; /* MAC addr handle used by BE card */ |
402 | u32 beacon_state; /* for set_phys_id */ | 403 | u32 beacon_state; /* for set_phys_id */ |
diff --git a/drivers/net/ethernet/emulex/benet/be_ethtool.c b/drivers/net/ethernet/emulex/benet/be_ethtool.c index 3d4461adb3b4..f3ee07758198 100644 --- a/drivers/net/ethernet/emulex/benet/be_ethtool.c +++ b/drivers/net/ethernet/emulex/benet/be_ethtool.c | |||
@@ -177,19 +177,15 @@ static void be_get_drvinfo(struct net_device *netdev, | |||
177 | struct ethtool_drvinfo *drvinfo) | 177 | struct ethtool_drvinfo *drvinfo) |
178 | { | 178 | { |
179 | struct be_adapter *adapter = netdev_priv(netdev); | 179 | struct be_adapter *adapter = netdev_priv(netdev); |
180 | char fw_on_flash[FW_VER_LEN]; | ||
181 | |||
182 | memset(fw_on_flash, 0 , sizeof(fw_on_flash)); | ||
183 | be_cmd_get_fw_ver(adapter, adapter->fw_ver, fw_on_flash); | ||
184 | 180 | ||
185 | strlcpy(drvinfo->driver, DRV_NAME, sizeof(drvinfo->driver)); | 181 | strlcpy(drvinfo->driver, DRV_NAME, sizeof(drvinfo->driver)); |
186 | strlcpy(drvinfo->version, DRV_VER, sizeof(drvinfo->version)); | 182 | strlcpy(drvinfo->version, DRV_VER, sizeof(drvinfo->version)); |
187 | if (!memcmp(adapter->fw_ver, fw_on_flash, FW_VER_LEN)) | 183 | if (!memcmp(adapter->fw_ver, adapter->fw_on_flash, FW_VER_LEN)) |
188 | strlcpy(drvinfo->fw_version, adapter->fw_ver, | 184 | strlcpy(drvinfo->fw_version, adapter->fw_ver, |
189 | sizeof(drvinfo->fw_version)); | 185 | sizeof(drvinfo->fw_version)); |
190 | else | 186 | else |
191 | snprintf(drvinfo->fw_version, sizeof(drvinfo->fw_version), | 187 | snprintf(drvinfo->fw_version, sizeof(drvinfo->fw_version), |
192 | "%s [%s]", adapter->fw_ver, fw_on_flash); | 188 | "%s [%s]", adapter->fw_ver, adapter->fw_on_flash); |
193 | 189 | ||
194 | strlcpy(drvinfo->bus_info, pci_name(adapter->pdev), | 190 | strlcpy(drvinfo->bus_info, pci_name(adapter->pdev), |
195 | sizeof(drvinfo->bus_info)); | 191 | sizeof(drvinfo->bus_info)); |
diff --git a/drivers/net/ethernet/emulex/benet/be_main.c b/drivers/net/ethernet/emulex/benet/be_main.c index 3d5e1a8929ae..d1580823c286 100644 --- a/drivers/net/ethernet/emulex/benet/be_main.c +++ b/drivers/net/ethernet/emulex/benet/be_main.c | |||
@@ -3193,7 +3193,7 @@ static int be_setup(struct be_adapter *adapter) | |||
3193 | if (status) | 3193 | if (status) |
3194 | goto err; | 3194 | goto err; |
3195 | 3195 | ||
3196 | be_cmd_get_fw_ver(adapter, adapter->fw_ver, NULL); | 3196 | be_cmd_get_fw_ver(adapter, adapter->fw_ver, adapter->fw_on_flash); |
3197 | 3197 | ||
3198 | if (adapter->vlans_added) | 3198 | if (adapter->vlans_added) |
3199 | be_vid_config(adapter); | 3199 | be_vid_config(adapter); |
@@ -3785,6 +3785,10 @@ int be_load_fw(struct be_adapter *adapter, u8 *fw_file) | |||
3785 | else | 3785 | else |
3786 | status = be_fw_download(adapter, fw); | 3786 | status = be_fw_download(adapter, fw); |
3787 | 3787 | ||
3788 | if (!status) | ||
3789 | be_cmd_get_fw_ver(adapter, adapter->fw_ver, | ||
3790 | adapter->fw_on_flash); | ||
3791 | |||
3788 | fw_exit: | 3792 | fw_exit: |
3789 | release_firmware(fw); | 3793 | release_firmware(fw); |
3790 | return status; | 3794 | return status; |