aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorMatt Carlson <mcarlson@broadcom.com>2010-02-26 09:04:41 -0500
committerDavid S. Miller <davem@davemloft.net>2010-02-28 03:43:32 -0500
commitb55ac1b22690d2e5b02a61cf6d69c2d66969c79d (patch)
treed336b38719dba482e2734f2091f5a60dfcb134b4 /drivers/net
parent7ad506fa1adc2da3d394c562f09b8e1b3026c402 (diff)
pci: Add helper to find a VPD resource data type
This patch adds the pci_vpd_find_tag() helper function to find VPD resource data types in a buffer. Signed-off-by: Matt Carlson <mcarlson@broadcom.com> Signed-off-by: Michael Chan <mchan@broadcom.com> Acked-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/bnx2.c24
-rw-r--r--drivers/net/tg3.c26
2 files changed, 9 insertions, 41 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c
index 084ef102b8c4..fd43feb5a350 100644
--- a/drivers/net/bnx2.c
+++ b/drivers/net/bnx2.c
@@ -7769,28 +7769,12 @@ bnx2_read_vpd_fw_ver(struct bnx2 *bp)
7769 } 7769 }
7770 7770
7771 for (i = 0; i <= BNX2_VPD_LEN - 3; ) { 7771 for (i = 0; i <= BNX2_VPD_LEN - 3; ) {
7772 unsigned char val = data[i];
7773 unsigned int block_end; 7772 unsigned int block_end;
7774 7773
7775 if (val & PCI_VPD_LRDT) { 7774 i = pci_vpd_find_tag(data, i, BNX2_VPD_LEN,
7776 if (i + PCI_VPD_LRDT_TAG_SIZE > BNX2_VPD_LEN) 7775 PCI_VPD_LRDT_RO_DATA);
7777 break; 7776 if (i < 0)
7778 7777 break;
7779 if (val != PCI_VPD_LRDT_RO_DATA) {
7780 i += PCI_VPD_LRDT_TAG_SIZE +
7781 pci_vpd_lrdt_size(&data[i]);
7782
7783 continue;
7784 }
7785 } else {
7786 if ((val & PCI_VPD_SRDT_TIN_MASK) == PCI_VPD_STIN_END)
7787 break;
7788
7789 i += PCI_VPD_SRDT_TAG_SIZE +
7790 pci_vpd_srdt_size(&data[i]);
7791
7792 continue;
7793 }
7794 7778
7795 block_end = (i + PCI_VPD_LRDT_TAG_SIZE + 7779 block_end = (i + PCI_VPD_LRDT_TAG_SIZE +
7796 pci_vpd_lrdt_size(&data[i])); 7780 pci_vpd_lrdt_size(&data[i]));
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index ed57a62b3ac8..76ad141ab448 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -12547,7 +12547,7 @@ skip_phy_reset:
12547static void __devinit tg3_read_partno(struct tg3 *tp) 12547static void __devinit tg3_read_partno(struct tg3 *tp)
12548{ 12548{
12549 unsigned char vpd_data[TG3_NVM_VPD_LEN]; /* in little-endian format */ 12549 unsigned char vpd_data[TG3_NVM_VPD_LEN]; /* in little-endian format */
12550 unsigned int i; 12550 int i;
12551 u32 magic; 12551 u32 magic;
12552 12552
12553 if ((tp->tg3_flags3 & TG3_FLG3_NO_NVRAM) || 12553 if ((tp->tg3_flags3 & TG3_FLG3_NO_NVRAM) ||
@@ -12586,28 +12586,12 @@ static void __devinit tg3_read_partno(struct tg3 *tp)
12586 12586
12587 /* Now parse and find the part number. */ 12587 /* Now parse and find the part number. */
12588 for (i = 0; i < TG3_NVM_VPD_LEN - 2; ) { 12588 for (i = 0; i < TG3_NVM_VPD_LEN - 2; ) {
12589 unsigned char val = vpd_data[i];
12590 unsigned int block_end; 12589 unsigned int block_end;
12591 12590
12592 if (val & PCI_VPD_LRDT) { 12591 i = pci_vpd_find_tag(vpd_data, i, TG3_NVM_VPD_LEN,
12593 if (i + PCI_VPD_LRDT_TAG_SIZE > TG3_NVM_VPD_LEN) 12592 PCI_VPD_LRDT_RO_DATA);
12594 break; 12593 if (i < 0)
12595 12594 break;
12596 if (val != PCI_VPD_LRDT_RO_DATA) {
12597 i += PCI_VPD_LRDT_TAG_SIZE +
12598 pci_vpd_lrdt_size(&vpd_data[i]);
12599
12600 continue;
12601 }
12602 } else {
12603 if ((val & PCI_VPD_SRDT_TIN_MASK) == PCI_VPD_STIN_END)
12604 break;
12605
12606 i += PCI_VPD_SRDT_TAG_SIZE +
12607 pci_vpd_srdt_size(&vpd_data[i]);
12608
12609 continue;
12610 }
12611 12595
12612 block_end = i + PCI_VPD_LRDT_TAG_SIZE + 12596 block_end = i + PCI_VPD_LRDT_TAG_SIZE +
12613 pci_vpd_lrdt_size(&vpd_data[i]); 12597 pci_vpd_lrdt_size(&vpd_data[i]);