aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatt Carlson <mcarlson@broadcom.com>2010-02-26 09:04:39 -0500
committerDavid S. Miller <davem@davemloft.net>2010-02-28 03:43:30 -0500
commita2ce766238f72ff7337606c0bc96803c30c9e05c (patch)
tree5968e585402263556481075a49599dc697aeab49
parent2ea186ae533c7b4f4c56811b69d3e40a6209a9c0 (diff)
pci: Add PCI LRDT tag size and section size
This patch adds a preprocessor constant to describe the PCI VPD large resource data type tag size and an inline function to extract the large resource section size from the large resource data type tag. 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>
-rw-r--r--drivers/net/bnx2.c8
-rw-r--r--drivers/net/tg3.c13
-rw-r--r--include/linux/pci.h14
3 files changed, 25 insertions, 10 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c
index d3f739a295df..bb403887b549 100644
--- a/drivers/net/bnx2.c
+++ b/drivers/net/bnx2.c
@@ -7773,15 +7773,17 @@ bnx2_read_vpd_fw_ver(struct bnx2 *bp)
7773 unsigned int block_end; 7773 unsigned int block_end;
7774 7774
7775 if (val == 0x82 || val == 0x91) { 7775 if (val == 0x82 || val == 0x91) {
7776 i = (i + 3 + (data[i + 1] + (data[i + 2] << 8))); 7776 i += PCI_VPD_LRDT_TAG_SIZE +
7777 pci_vpd_lrdt_size(&data[i]);
7777 continue; 7778 continue;
7778 } 7779 }
7779 7780
7780 if (val != 0x90) 7781 if (val != 0x90)
7781 goto vpd_done; 7782 goto vpd_done;
7782 7783
7783 block_end = (i + 3 + (data[i + 1] + (data[i + 2] << 8))); 7784 block_end = (i + PCI_VPD_LRDT_TAG_SIZE +
7784 i += 3; 7785 pci_vpd_lrdt_size(&data[i]));
7786 i += PCI_VPD_LRDT_TAG_SIZE;
7785 7787
7786 if (block_end > BNX2_VPD_LEN) 7788 if (block_end > BNX2_VPD_LEN)
7787 goto vpd_done; 7789 goto vpd_done;
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index 0d06e4007f44..5fccbe459949 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -12590,19 +12590,18 @@ static void __devinit tg3_read_partno(struct tg3 *tp)
12590 unsigned int block_end; 12590 unsigned int block_end;
12591 12591
12592 if (val == 0x82 || val == 0x91) { 12592 if (val == 0x82 || val == 0x91) {
12593 i = (i + 3 + 12593 i += PCI_VPD_LRDT_TAG_SIZE +
12594 (vpd_data[i + 1] + 12594 pci_vpd_lrdt_size(&vpd_data[i]);
12595 (vpd_data[i + 2] << 8)));
12596 continue; 12595 continue;
12597 } 12596 }
12598 12597
12599 if (val != 0x90) 12598 if (val != 0x90)
12600 goto out_not_found; 12599 goto out_not_found;
12601 12600
12602 block_end = (i + 3 + 12601 block_end = i + PCI_VPD_LRDT_TAG_SIZE +
12603 (vpd_data[i + 1] + 12602 pci_vpd_lrdt_size(&vpd_data[i]);
12604 (vpd_data[i + 2] << 8))); 12603
12605 i += 3; 12604 i += PCI_VPD_LRDT_TAG_SIZE;
12606 12605
12607 if (block_end > TG3_NVM_VPD_LEN) 12606 if (block_end > TG3_NVM_VPD_LEN)
12608 goto out_not_found; 12607 goto out_not_found;
diff --git a/include/linux/pci.h b/include/linux/pci.h
index e2575f86133a..6f62a499023f 100644
--- a/include/linux/pci.h
+++ b/include/linux/pci.h
@@ -1349,5 +1349,19 @@ static inline bool pci_is_pcie(struct pci_dev *dev)
1349 1349
1350void pci_request_acs(void); 1350void pci_request_acs(void);
1351 1351
1352
1353#define PCI_VPD_LRDT_TAG_SIZE 3
1354
1355/**
1356 * pci_vpd_lrdt_size - Extracts the Large Resource Data Type length
1357 * @lrdt: Pointer to the beginning of the Large Resource Data Type tag
1358 *
1359 * Returns the extracted Large Resource Data Type length.
1360 */
1361static inline u16 pci_vpd_lrdt_size(const u8 *lrdt)
1362{
1363 return (u16)lrdt[1] + ((u16)lrdt[2] << 8);
1364}
1365
1352#endif /* __KERNEL__ */ 1366#endif /* __KERNEL__ */
1353#endif /* LINUX_PCI_H */ 1367#endif /* LINUX_PCI_H */