Commit b7a49f73 authored by Manish Chopra's avatar Manish Chopra Committed by David S. Miller

bnx2x: Utilize firmware 7.13.21.0

This new firmware addresses few important issues and enhancements
as mentioned below -

- Support direct invalidation of FP HSI Ver per function ID, required for
  invalidating FP HSI Ver prior to each VF start, as there is no VF start
- BRB hardware block parity error detection support for the driver
- Fix the FCOE underrun flow
- Fix PSOD during FCoE BFS over the NIC ports after preboot driver
- Maintains backward compatibility

This patch incorporates this new firmware 7.13.21.0 in bnx2x driver.
Signed-off-by: default avatarManish Chopra <manishc@marvell.com>
Signed-off-by: default avatarPrabhakar Kushwaha <pkushwaha@marvell.com>
Signed-off-by: default avatarAlok Prasad <palok@marvell.com>
Signed-off-by: default avatarAriel Elior <aelior@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 434ed213
...@@ -1850,6 +1850,14 @@ struct bnx2x { ...@@ -1850,6 +1850,14 @@ struct bnx2x {
/* Vxlan/Geneve related information */ /* Vxlan/Geneve related information */
u16 udp_tunnel_ports[BNX2X_UDP_PORT_MAX]; u16 udp_tunnel_ports[BNX2X_UDP_PORT_MAX];
#define FW_CAP_INVALIDATE_VF_FP_HSI BIT(0)
u32 fw_cap;
u32 fw_major;
u32 fw_minor;
u32 fw_rev;
u32 fw_eng;
}; };
/* Tx queues may be less or equal to Rx queues */ /* Tx queues may be less or equal to Rx queues */
...@@ -2525,5 +2533,6 @@ void bnx2x_register_phc(struct bnx2x *bp); ...@@ -2525,5 +2533,6 @@ void bnx2x_register_phc(struct bnx2x *bp);
* Meant for implicit re-load flows. * Meant for implicit re-load flows.
*/ */
int bnx2x_vlan_reconfigure_vid(struct bnx2x *bp); int bnx2x_vlan_reconfigure_vid(struct bnx2x *bp);
int bnx2x_init_firmware(struct bnx2x *bp);
void bnx2x_release_firmware(struct bnx2x *bp);
#endif /* bnx2x.h */ #endif /* bnx2x.h */
...@@ -2365,10 +2365,8 @@ int bnx2x_compare_fw_ver(struct bnx2x *bp, u32 load_code, bool print_err) ...@@ -2365,10 +2365,8 @@ int bnx2x_compare_fw_ver(struct bnx2x *bp, u32 load_code, bool print_err)
if (load_code != FW_MSG_CODE_DRV_LOAD_COMMON_CHIP && if (load_code != FW_MSG_CODE_DRV_LOAD_COMMON_CHIP &&
load_code != FW_MSG_CODE_DRV_LOAD_COMMON) { load_code != FW_MSG_CODE_DRV_LOAD_COMMON) {
/* build my FW version dword */ /* build my FW version dword */
u32 my_fw = (BCM_5710_FW_MAJOR_VERSION) + u32 my_fw = (bp->fw_major) + (bp->fw_minor << 8) +
(BCM_5710_FW_MINOR_VERSION << 8) + (bp->fw_rev << 16) + (bp->fw_eng << 24);
(BCM_5710_FW_REVISION_VERSION << 16) +
(BCM_5710_FW_ENGINEERING_VERSION << 24);
/* read loaded FW from chip */ /* read loaded FW from chip */
u32 loaded_fw = REG_RD(bp, XSEM_REG_PRAM); u32 loaded_fw = REG_RD(bp, XSEM_REG_PRAM);
......
...@@ -241,6 +241,8 @@ ...@@ -241,6 +241,8 @@
IRO[221].m2)) IRO[221].m2))
#define XSTORM_VF_TO_PF_OFFSET(funcId) \ #define XSTORM_VF_TO_PF_OFFSET(funcId) \
(IRO[48].base + ((funcId) * IRO[48].m1)) (IRO[48].base + ((funcId) * IRO[48].m1))
#define XSTORM_ETH_FUNCTION_INFO_FP_HSI_VALID_E2_OFFSET(fid) \
(IRO[386].base + ((fid) * IRO[386].m1))
#define COMMON_ASM_INVALID_ASSERT_OPCODE 0x0 #define COMMON_ASM_INVALID_ASSERT_OPCODE 0x0
/* eth hsi version */ /* eth hsi version */
......
...@@ -3024,7 +3024,8 @@ struct afex_stats { ...@@ -3024,7 +3024,8 @@ struct afex_stats {
#define BCM_5710_FW_MAJOR_VERSION 7 #define BCM_5710_FW_MAJOR_VERSION 7
#define BCM_5710_FW_MINOR_VERSION 13 #define BCM_5710_FW_MINOR_VERSION 13
#define BCM_5710_FW_REVISION_VERSION 15 #define BCM_5710_FW_REVISION_VERSION 21
#define BCM_5710_FW_REVISION_VERSION_V15 15
#define BCM_5710_FW_ENGINEERING_VERSION 0 #define BCM_5710_FW_ENGINEERING_VERSION 0
#define BCM_5710_FW_COMPILE_FLAGS 1 #define BCM_5710_FW_COMPILE_FLAGS 1
......
...@@ -74,9 +74,19 @@ ...@@ -74,9 +74,19 @@
__stringify(BCM_5710_FW_MINOR_VERSION) "." \ __stringify(BCM_5710_FW_MINOR_VERSION) "." \
__stringify(BCM_5710_FW_REVISION_VERSION) "." \ __stringify(BCM_5710_FW_REVISION_VERSION) "." \
__stringify(BCM_5710_FW_ENGINEERING_VERSION) __stringify(BCM_5710_FW_ENGINEERING_VERSION)
#define FW_FILE_VERSION_V15 \
__stringify(BCM_5710_FW_MAJOR_VERSION) "." \
__stringify(BCM_5710_FW_MINOR_VERSION) "." \
__stringify(BCM_5710_FW_REVISION_VERSION_V15) "." \
__stringify(BCM_5710_FW_ENGINEERING_VERSION)
#define FW_FILE_NAME_E1 "bnx2x/bnx2x-e1-" FW_FILE_VERSION ".fw" #define FW_FILE_NAME_E1 "bnx2x/bnx2x-e1-" FW_FILE_VERSION ".fw"
#define FW_FILE_NAME_E1H "bnx2x/bnx2x-e1h-" FW_FILE_VERSION ".fw" #define FW_FILE_NAME_E1H "bnx2x/bnx2x-e1h-" FW_FILE_VERSION ".fw"
#define FW_FILE_NAME_E2 "bnx2x/bnx2x-e2-" FW_FILE_VERSION ".fw" #define FW_FILE_NAME_E2 "bnx2x/bnx2x-e2-" FW_FILE_VERSION ".fw"
#define FW_FILE_NAME_E1_V15 "bnx2x/bnx2x-e1-" FW_FILE_VERSION_V15 ".fw"
#define FW_FILE_NAME_E1H_V15 "bnx2x/bnx2x-e1h-" FW_FILE_VERSION_V15 ".fw"
#define FW_FILE_NAME_E2_V15 "bnx2x/bnx2x-e2-" FW_FILE_VERSION_V15 ".fw"
/* Time in jiffies before concluding the transmitter is hung */ /* Time in jiffies before concluding the transmitter is hung */
#define TX_TIMEOUT (5*HZ) #define TX_TIMEOUT (5*HZ)
...@@ -747,9 +757,7 @@ static int bnx2x_mc_assert(struct bnx2x *bp) ...@@ -747,9 +757,7 @@ static int bnx2x_mc_assert(struct bnx2x *bp)
CHIP_IS_E1(bp) ? "everest1" : CHIP_IS_E1(bp) ? "everest1" :
CHIP_IS_E1H(bp) ? "everest1h" : CHIP_IS_E1H(bp) ? "everest1h" :
CHIP_IS_E2(bp) ? "everest2" : "everest3", CHIP_IS_E2(bp) ? "everest2" : "everest3",
BCM_5710_FW_MAJOR_VERSION, bp->fw_major, bp->fw_minor, bp->fw_rev);
BCM_5710_FW_MINOR_VERSION,
BCM_5710_FW_REVISION_VERSION);
return rc; return rc;
} }
...@@ -12308,6 +12316,15 @@ static int bnx2x_init_bp(struct bnx2x *bp) ...@@ -12308,6 +12316,15 @@ static int bnx2x_init_bp(struct bnx2x *bp)
bnx2x_read_fwinfo(bp); bnx2x_read_fwinfo(bp);
if (IS_PF(bp)) {
rc = bnx2x_init_firmware(bp);
if (rc) {
bnx2x_free_mem_bp(bp);
return rc;
}
}
func = BP_FUNC(bp); func = BP_FUNC(bp);
/* need to reset chip if undi was active */ /* need to reset chip if undi was active */
...@@ -12320,6 +12337,7 @@ static int bnx2x_init_bp(struct bnx2x *bp) ...@@ -12320,6 +12337,7 @@ static int bnx2x_init_bp(struct bnx2x *bp)
rc = bnx2x_prev_unload(bp); rc = bnx2x_prev_unload(bp);
if (rc) { if (rc) {
bnx2x_release_firmware(bp);
bnx2x_free_mem_bp(bp); bnx2x_free_mem_bp(bp);
return rc; return rc;
} }
...@@ -13317,16 +13335,11 @@ static int bnx2x_check_firmware(struct bnx2x *bp) ...@@ -13317,16 +13335,11 @@ static int bnx2x_check_firmware(struct bnx2x *bp)
/* Check FW version */ /* Check FW version */
offset = be32_to_cpu(fw_hdr->fw_version.offset); offset = be32_to_cpu(fw_hdr->fw_version.offset);
fw_ver = firmware->data + offset; fw_ver = firmware->data + offset;
if ((fw_ver[0] != BCM_5710_FW_MAJOR_VERSION) || if (fw_ver[0] != bp->fw_major || fw_ver[1] != bp->fw_minor ||
(fw_ver[1] != BCM_5710_FW_MINOR_VERSION) || fw_ver[2] != bp->fw_rev || fw_ver[3] != bp->fw_eng) {
(fw_ver[2] != BCM_5710_FW_REVISION_VERSION) ||
(fw_ver[3] != BCM_5710_FW_ENGINEERING_VERSION)) {
BNX2X_ERR("Bad FW version:%d.%d.%d.%d. Should be %d.%d.%d.%d\n", BNX2X_ERR("Bad FW version:%d.%d.%d.%d. Should be %d.%d.%d.%d\n",
fw_ver[0], fw_ver[1], fw_ver[2], fw_ver[3], fw_ver[0], fw_ver[1], fw_ver[2], fw_ver[3],
BCM_5710_FW_MAJOR_VERSION, bp->fw_major, bp->fw_minor, bp->fw_rev, bp->fw_eng);
BCM_5710_FW_MINOR_VERSION,
BCM_5710_FW_REVISION_VERSION,
BCM_5710_FW_ENGINEERING_VERSION);
return -EINVAL; return -EINVAL;
} }
...@@ -13404,34 +13417,51 @@ do { \ ...@@ -13404,34 +13417,51 @@ do { \
(u8 *)bp->arr, len); \ (u8 *)bp->arr, len); \
} while (0) } while (0)
static int bnx2x_init_firmware(struct bnx2x *bp) int bnx2x_init_firmware(struct bnx2x *bp)
{ {
const char *fw_file_name; const char *fw_file_name, *fw_file_name_v15;
struct bnx2x_fw_file_hdr *fw_hdr; struct bnx2x_fw_file_hdr *fw_hdr;
int rc; int rc;
if (bp->firmware) if (bp->firmware)
return 0; return 0;
if (CHIP_IS_E1(bp)) if (CHIP_IS_E1(bp)) {
fw_file_name = FW_FILE_NAME_E1; fw_file_name = FW_FILE_NAME_E1;
else if (CHIP_IS_E1H(bp)) fw_file_name_v15 = FW_FILE_NAME_E1_V15;
} else if (CHIP_IS_E1H(bp)) {
fw_file_name = FW_FILE_NAME_E1H; fw_file_name = FW_FILE_NAME_E1H;
else if (!CHIP_IS_E1x(bp)) fw_file_name_v15 = FW_FILE_NAME_E1H_V15;
} else if (!CHIP_IS_E1x(bp)) {
fw_file_name = FW_FILE_NAME_E2; fw_file_name = FW_FILE_NAME_E2;
else { fw_file_name_v15 = FW_FILE_NAME_E2_V15;
} else {
BNX2X_ERR("Unsupported chip revision\n"); BNX2X_ERR("Unsupported chip revision\n");
return -EINVAL; return -EINVAL;
} }
BNX2X_DEV_INFO("Loading %s\n", fw_file_name); BNX2X_DEV_INFO("Loading %s\n", fw_file_name);
rc = request_firmware(&bp->firmware, fw_file_name, &bp->pdev->dev); rc = request_firmware(&bp->firmware, fw_file_name, &bp->pdev->dev);
if (rc) { if (rc) {
BNX2X_ERR("Can't load firmware file %s\n", BNX2X_DEV_INFO("Trying to load older fw %s\n", fw_file_name_v15);
fw_file_name);
goto request_firmware_exit; /* try to load prev version */
rc = request_firmware(&bp->firmware, fw_file_name_v15, &bp->pdev->dev);
if (rc)
goto request_firmware_exit;
bp->fw_rev = BCM_5710_FW_REVISION_VERSION_V15;
} else {
bp->fw_cap |= FW_CAP_INVALIDATE_VF_FP_HSI;
bp->fw_rev = BCM_5710_FW_REVISION_VERSION;
} }
bp->fw_major = BCM_5710_FW_MAJOR_VERSION;
bp->fw_minor = BCM_5710_FW_MINOR_VERSION;
bp->fw_eng = BCM_5710_FW_ENGINEERING_VERSION;
rc = bnx2x_check_firmware(bp); rc = bnx2x_check_firmware(bp);
if (rc) { if (rc) {
BNX2X_ERR("Corrupt firmware file %s\n", fw_file_name); BNX2X_ERR("Corrupt firmware file %s\n", fw_file_name);
...@@ -13487,7 +13517,7 @@ static int bnx2x_init_firmware(struct bnx2x *bp) ...@@ -13487,7 +13517,7 @@ static int bnx2x_init_firmware(struct bnx2x *bp)
return rc; return rc;
} }
static void bnx2x_release_firmware(struct bnx2x *bp) void bnx2x_release_firmware(struct bnx2x *bp)
{ {
kfree(bp->init_ops_offsets); kfree(bp->init_ops_offsets);
kfree(bp->init_ops); kfree(bp->init_ops);
...@@ -14004,6 +14034,7 @@ static int bnx2x_init_one(struct pci_dev *pdev, ...@@ -14004,6 +14034,7 @@ static int bnx2x_init_one(struct pci_dev *pdev,
return 0; return 0;
init_one_freemem: init_one_freemem:
bnx2x_release_firmware(bp);
bnx2x_free_mem_bp(bp); bnx2x_free_mem_bp(bp);
init_one_exit: init_one_exit:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment