aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorVladislav Zolotarov <vladz@broadcom.com>2010-04-18 21:13:23 -0400
committerDavid S. Miller <davem@davemloft.net>2010-04-19 16:17:06 -0400
commit34f24c7fc095a2d884e634ff430ab0da6f2a0669 (patch)
tree59982427f62ce52d7b5dd6d0393a59f85ff293b8 /drivers
parent72fd0718332e6514fb9db325e89ffc694bb31f6e (diff)
bnx2x: Use VPD-R V0 entry to display firmware revision
Author: Dmitry Kravkov <dmitry@broadcom.com> Signed-off-by: Dmitry Kravkov <dmitry@broadcom.com> Signed-off-by: Vladislav Zolotarov <vladz@broadcom.com> Signed-off-by: Eilon Greenstein <eilong@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/bnx2x.h4
-rw-r--r--drivers/net/bnx2x_main.c71
2 files changed, 73 insertions, 2 deletions
diff --git a/drivers/net/bnx2x.h b/drivers/net/bnx2x.h
index ccef13b41dfa..694c8cd59e09 100644
--- a/drivers/net/bnx2x.h
+++ b/drivers/net/bnx2x.h
@@ -1089,6 +1089,7 @@ struct bnx2x {
1089#define INIT_CSEM_INT_TABLE_DATA(bp) (bp->csem_int_table_data) 1089#define INIT_CSEM_INT_TABLE_DATA(bp) (bp->csem_int_table_data)
1090#define INIT_CSEM_PRAM_DATA(bp) (bp->csem_pram_data) 1090#define INIT_CSEM_PRAM_DATA(bp) (bp->csem_pram_data)
1091 1091
1092 char fw_ver[32];
1092 const struct firmware *firmware; 1093 const struct firmware *firmware;
1093}; 1094};
1094 1095
@@ -1352,6 +1353,9 @@ static inline u32 reg_poll(struct bnx2x *bp, u32 reg, u32 expected, int ms,
1352#define PXP2_REG_PXP2_INT_STS PXP2_REG_PXP2_INT_STS_0 1353#define PXP2_REG_PXP2_INT_STS PXP2_REG_PXP2_INT_STS_0
1353#endif 1354#endif
1354 1355
1356#define BNX2X_VPD_LEN 128
1357#define VENDOR_ID_LEN 4
1358
1355/* MISC_REG_RESET_REG - this is here for the hsi to work don't touch */ 1359/* MISC_REG_RESET_REG - this is here for the hsi to work don't touch */
1356 1360
1357#endif /* bnx2x.h */ 1361#endif /* bnx2x.h */
diff --git a/drivers/net/bnx2x_main.c b/drivers/net/bnx2x_main.c
index 2b6717748eb8..d0884862b96c 100644
--- a/drivers/net/bnx2x_main.c
+++ b/drivers/net/bnx2x_main.c
@@ -9759,6 +9759,70 @@ static int __devinit bnx2x_get_hwinfo(struct bnx2x *bp)
9759 return rc; 9759 return rc;
9760} 9760}
9761 9761
9762static void __devinit bnx2x_read_fwinfo(struct bnx2x *bp)
9763{
9764 int cnt, i, block_end, rodi;
9765 char vpd_data[BNX2X_VPD_LEN+1];
9766 char str_id_reg[VENDOR_ID_LEN+1];
9767 char str_id_cap[VENDOR_ID_LEN+1];
9768 u8 len;
9769
9770 cnt = pci_read_vpd(bp->pdev, 0, BNX2X_VPD_LEN, vpd_data);
9771 memset(bp->fw_ver, 0, sizeof(bp->fw_ver));
9772
9773 if (cnt < BNX2X_VPD_LEN)
9774 goto out_not_found;
9775
9776 i = pci_vpd_find_tag(vpd_data, 0, BNX2X_VPD_LEN,
9777 PCI_VPD_LRDT_RO_DATA);
9778 if (i < 0)
9779 goto out_not_found;
9780
9781
9782 block_end = i + PCI_VPD_LRDT_TAG_SIZE +
9783 pci_vpd_lrdt_size(&vpd_data[i]);
9784
9785 i += PCI_VPD_LRDT_TAG_SIZE;
9786
9787 if (block_end > BNX2X_VPD_LEN)
9788 goto out_not_found;
9789
9790 rodi = pci_vpd_find_info_keyword(vpd_data, i, block_end,
9791 PCI_VPD_RO_KEYWORD_MFR_ID);
9792 if (rodi < 0)
9793 goto out_not_found;
9794
9795 len = pci_vpd_info_field_size(&vpd_data[rodi]);
9796
9797 if (len != VENDOR_ID_LEN)
9798 goto out_not_found;
9799
9800 rodi += PCI_VPD_INFO_FLD_HDR_SIZE;
9801
9802 /* vendor specific info */
9803 snprintf(str_id_reg, VENDOR_ID_LEN + 1, "%04x", PCI_VENDOR_ID_DELL);
9804 snprintf(str_id_cap, VENDOR_ID_LEN + 1, "%04X", PCI_VENDOR_ID_DELL);
9805 if (!strncmp(str_id_reg, &vpd_data[rodi], VENDOR_ID_LEN) ||
9806 !strncmp(str_id_cap, &vpd_data[rodi], VENDOR_ID_LEN)) {
9807
9808 rodi = pci_vpd_find_info_keyword(vpd_data, i, block_end,
9809 PCI_VPD_RO_KEYWORD_VENDOR0);
9810 if (rodi >= 0) {
9811 len = pci_vpd_info_field_size(&vpd_data[rodi]);
9812
9813 rodi += PCI_VPD_INFO_FLD_HDR_SIZE;
9814
9815 if (len < 32 && (len + rodi) <= BNX2X_VPD_LEN) {
9816 memcpy(bp->fw_ver, &vpd_data[rodi], len);
9817 bp->fw_ver[len] = ' ';
9818 }
9819 }
9820 return;
9821 }
9822out_not_found:
9823 return;
9824}
9825
9762static int __devinit bnx2x_init_bp(struct bnx2x *bp) 9826static int __devinit bnx2x_init_bp(struct bnx2x *bp)
9763{ 9827{
9764 int func = BP_FUNC(bp); 9828 int func = BP_FUNC(bp);
@@ -9780,6 +9844,7 @@ static int __devinit bnx2x_init_bp(struct bnx2x *bp)
9780 9844
9781 rc = bnx2x_get_hwinfo(bp); 9845 rc = bnx2x_get_hwinfo(bp);
9782 9846
9847 bnx2x_read_fwinfo(bp);
9783 /* need to reset chip if undi was active */ 9848 /* need to reset chip if undi was active */
9784 if (!BP_NOMCP(bp)) 9849 if (!BP_NOMCP(bp))
9785 bnx2x_undi_unload(bp); 9850 bnx2x_undi_unload(bp);
@@ -10170,11 +10235,13 @@ static void bnx2x_get_drvinfo(struct net_device *dev,
10170 bnx2x_release_phy_lock(bp); 10235 bnx2x_release_phy_lock(bp);
10171 } 10236 }
10172 10237
10173 snprintf(info->fw_version, 32, "BC:%d.%d.%d%s%s", 10238 strncpy(info->fw_version, bp->fw_ver, 32);
10239 snprintf(info->fw_version + strlen(bp->fw_ver), 32 - strlen(bp->fw_ver),
10240 "bc %d.%d.%d%s%s",
10174 (bp->common.bc_ver & 0xff0000) >> 16, 10241 (bp->common.bc_ver & 0xff0000) >> 16,
10175 (bp->common.bc_ver & 0xff00) >> 8, 10242 (bp->common.bc_ver & 0xff00) >> 8,
10176 (bp->common.bc_ver & 0xff), 10243 (bp->common.bc_ver & 0xff),
10177 ((phy_fw_ver[0] != '\0') ? " PHY:" : ""), phy_fw_ver); 10244 ((phy_fw_ver[0] != '\0') ? " phy " : ""), phy_fw_ver);
10178 strcpy(info->bus_info, pci_name(bp->pdev)); 10245 strcpy(info->bus_info, pci_name(bp->pdev));
10179 info->n_stats = BNX2X_NUM_STATS; 10246 info->n_stats = BNX2X_NUM_STATS;
10180 info->testinfo_len = BNX2X_NUM_TESTS; 10247 info->testinfo_len = BNX2X_NUM_TESTS;