diff options
author | Matt Carlson <mcarlson@broadcom.com> | 2010-02-26 09:04:42 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-28 03:43:32 -0500 |
commit | e1d5bdabb94da89bdb3c3f2ee105cf61fca88ec8 (patch) | |
tree | bc5b86b19bc49ace2df10ed9e7ba7d1ca2b74d33 /drivers/net/bnx2.c | |
parent | b55ac1b22690d2e5b02a61cf6d69c2d66969c79d (diff) |
pci: Add VPD information field helper functions
This patch adds a preprocessor constant to describe the PCI VPD
information field header size and an inline function to extract the
size of the information field itself.
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/bnx2.c')
-rw-r--r-- | drivers/net/bnx2.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index fd43feb5a35..b808707f83f 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
@@ -7784,14 +7784,15 @@ bnx2_read_vpd_fw_ver(struct bnx2 *bp) | |||
7784 | goto vpd_done; | 7784 | goto vpd_done; |
7785 | 7785 | ||
7786 | while (i < (block_end - 2)) { | 7786 | while (i < (block_end - 2)) { |
7787 | int len = data[i + 2]; | 7787 | int len = pci_vpd_info_field_size(&data[i]); |
7788 | 7788 | ||
7789 | if (i + 3 + len > block_end) | 7789 | if (i + PCI_VPD_INFO_FLD_HDR_SIZE + len > block_end) |
7790 | goto vpd_done; | 7790 | goto vpd_done; |
7791 | 7791 | ||
7792 | if (data[i] == 'M' && data[i + 1] == 'N') { | 7792 | if (data[i] == 'M' && data[i + 1] == 'N') { |
7793 | if (len != 4 || | 7793 | if (len != 4 || |
7794 | memcmp(&data[i + 3], "1028", 4)) | 7794 | memcmp(&data[i + PCI_VPD_INFO_FLD_HDR_SIZE], |
7795 | "1028", 4)) | ||
7795 | goto vpd_done; | 7796 | goto vpd_done; |
7796 | mn_match = true; | 7797 | mn_match = true; |
7797 | 7798 | ||
@@ -7800,9 +7801,9 @@ bnx2_read_vpd_fw_ver(struct bnx2 *bp) | |||
7800 | goto vpd_done; | 7801 | goto vpd_done; |
7801 | 7802 | ||
7802 | v0_len = len; | 7803 | v0_len = len; |
7803 | v0_str = &data[i + 3]; | 7804 | v0_str = &data[i + PCI_VPD_INFO_FLD_HDR_SIZE]; |
7804 | } | 7805 | } |
7805 | i += 3 + len; | 7806 | i += PCI_VPD_INFO_FLD_HDR_SIZE + len; |
7806 | 7807 | ||
7807 | if (mn_match && v0_str) { | 7808 | if (mn_match && v0_str) { |
7808 | memcpy(bp->fw_version, v0_str, v0_len); | 7809 | memcpy(bp->fw_version, v0_str, v0_len); |