Commit 466a79f4 authored by Heiner Kallweit's avatar Heiner Kallweit Committed by Bjorn Helgaas

tg3: Search VPD with pci_vpd_find_ro_info_keyword()

Use pci_vpd_find_ro_info_keyword() to search for keywords in VPD to
simplify the code.

Link: https://lore.kernel.org/r/0ae9d4c0-590d-682a-a0af-2272e5f71630@gmail.comSigned-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
parent 8d6ab5c5
...@@ -15592,63 +15592,36 @@ static int tg3_phy_probe(struct tg3 *tp) ...@@ -15592,63 +15592,36 @@ static int tg3_phy_probe(struct tg3 *tp)
static void tg3_read_vpd(struct tg3 *tp) static void tg3_read_vpd(struct tg3 *tp)
{ {
u8 *vpd_data; u8 *vpd_data;
unsigned int block_end, rosize, len, vpdlen; unsigned int len, vpdlen;
int j, i = 0; int i;
vpd_data = (u8 *)tg3_vpd_readblock(tp, &vpdlen); vpd_data = (u8 *)tg3_vpd_readblock(tp, &vpdlen);
if (!vpd_data) if (!vpd_data)
goto out_no_vpd; goto out_no_vpd;
i = pci_vpd_find_tag(vpd_data, vpdlen, PCI_VPD_LRDT_RO_DATA); i = pci_vpd_find_ro_info_keyword(vpd_data, vpdlen,
PCI_VPD_RO_KEYWORD_MFR_ID, &len);
if (i < 0) if (i < 0)
goto out_not_found; goto partno;
rosize = pci_vpd_lrdt_size(&vpd_data[i]);
block_end = i + PCI_VPD_LRDT_TAG_SIZE + rosize;
i += PCI_VPD_LRDT_TAG_SIZE;
if (block_end > vpdlen)
goto out_not_found;
j = pci_vpd_find_info_keyword(vpd_data, i, rosize,
PCI_VPD_RO_KEYWORD_MFR_ID);
if (j > 0) {
len = pci_vpd_info_field_size(&vpd_data[j]);
j += PCI_VPD_INFO_FLD_HDR_SIZE; if (len != 4 || memcmp(vpd_data + i, "1028", 4))
if (j + len > block_end || len != 4 || goto partno;
memcmp(&vpd_data[j], "1028", 4))
goto partno;
j = pci_vpd_find_info_keyword(vpd_data, i, rosize, i = pci_vpd_find_ro_info_keyword(vpd_data, vpdlen,
PCI_VPD_RO_KEYWORD_VENDOR0); PCI_VPD_RO_KEYWORD_VENDOR0, &len);
if (j < 0) if (i < 0)
goto partno; goto partno;
len = pci_vpd_info_field_size(&vpd_data[j]);
j += PCI_VPD_INFO_FLD_HDR_SIZE; memset(tp->fw_ver, 0, sizeof(tp->fw_ver));
if (j + len > block_end) snprintf(tp->fw_ver, sizeof(tp->fw_ver), "%.*s bc ", len, vpd_data + i);
goto partno;
if (len >= sizeof(tp->fw_ver))
len = sizeof(tp->fw_ver) - 1;
memset(tp->fw_ver, 0, sizeof(tp->fw_ver));
snprintf(tp->fw_ver, sizeof(tp->fw_ver), "%.*s bc ", len,
&vpd_data[j]);
}
partno: partno:
i = pci_vpd_find_info_keyword(vpd_data, i, rosize, i = pci_vpd_find_ro_info_keyword(vpd_data, vpdlen,
PCI_VPD_RO_KEYWORD_PARTNO); PCI_VPD_RO_KEYWORD_PARTNO, &len);
if (i < 0) if (i < 0)
goto out_not_found; goto out_not_found;
len = pci_vpd_info_field_size(&vpd_data[i]); if (len > TG3_BPN_SIZE)
i += PCI_VPD_INFO_FLD_HDR_SIZE;
if (len > TG3_BPN_SIZE ||
(len + i) > vpdlen)
goto out_not_found; goto out_not_found;
memcpy(tp->board_part_number, &vpd_data[i], len); memcpy(tp->board_part_number, &vpd_data[i], len);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment