diff options
author | Matt Carlson <mcarlson@broadcom.com> | 2010-02-26 09:04:41 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-28 03:43:32 -0500 |
commit | b55ac1b22690d2e5b02a61cf6d69c2d66969c79d (patch) | |
tree | d336b38719dba482e2734f2091f5a60dfcb134b4 /drivers/net | |
parent | 7ad506fa1adc2da3d394c562f09b8e1b3026c402 (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.c | 24 | ||||
-rw-r--r-- | drivers/net/tg3.c | 26 |
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: | |||
12547 | static void __devinit tg3_read_partno(struct tg3 *tp) | 12547 | static 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]); |