diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/bnx2.c | 23 | ||||
-rw-r--r-- | drivers/net/tg3.c | 23 |
2 files changed, 34 insertions, 12 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index bb403887b549..084ef102b8c4 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
@@ -7772,15 +7772,26 @@ bnx2_read_vpd_fw_ver(struct bnx2 *bp) | |||
7772 | unsigned char val = data[i]; | 7772 | unsigned char val = data[i]; |
7773 | unsigned int block_end; | 7773 | unsigned int block_end; |
7774 | 7774 | ||
7775 | if (val == 0x82 || val == 0x91) { | 7775 | if (val & PCI_VPD_LRDT) { |
7776 | i += PCI_VPD_LRDT_TAG_SIZE + | 7776 | if (i + PCI_VPD_LRDT_TAG_SIZE > BNX2_VPD_LEN) |
7777 | pci_vpd_lrdt_size(&data[i]); | 7777 | break; |
7778 | |||
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 | |||
7778 | continue; | 7792 | continue; |
7779 | } | 7793 | } |
7780 | 7794 | ||
7781 | if (val != 0x90) | ||
7782 | goto vpd_done; | ||
7783 | |||
7784 | block_end = (i + PCI_VPD_LRDT_TAG_SIZE + | 7795 | block_end = (i + PCI_VPD_LRDT_TAG_SIZE + |
7785 | pci_vpd_lrdt_size(&data[i])); | 7796 | pci_vpd_lrdt_size(&data[i])); |
7786 | i += PCI_VPD_LRDT_TAG_SIZE; | 7797 | i += PCI_VPD_LRDT_TAG_SIZE; |
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index 5fccbe459949..ed57a62b3ac8 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -12589,15 +12589,26 @@ static void __devinit tg3_read_partno(struct tg3 *tp) | |||
12589 | unsigned char val = vpd_data[i]; | 12589 | unsigned char val = vpd_data[i]; |
12590 | unsigned int block_end; | 12590 | unsigned int block_end; |
12591 | 12591 | ||
12592 | if (val == 0x82 || val == 0x91) { | 12592 | if (val & PCI_VPD_LRDT) { |
12593 | i += PCI_VPD_LRDT_TAG_SIZE + | 12593 | if (i + PCI_VPD_LRDT_TAG_SIZE > TG3_NVM_VPD_LEN) |
12594 | pci_vpd_lrdt_size(&vpd_data[i]); | 12594 | break; |
12595 | |||
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 | |||
12595 | continue; | 12609 | continue; |
12596 | } | 12610 | } |
12597 | 12611 | ||
12598 | if (val != 0x90) | ||
12599 | goto out_not_found; | ||
12600 | |||
12601 | block_end = i + PCI_VPD_LRDT_TAG_SIZE + | 12612 | block_end = i + PCI_VPD_LRDT_TAG_SIZE + |
12602 | pci_vpd_lrdt_size(&vpd_data[i]); | 12613 | pci_vpd_lrdt_size(&vpd_data[i]); |
12603 | 12614 | ||