diff options
author | Yaniv Rosner <yanivr@broadcom.com> | 2011-01-17 23:33:36 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-01-18 19:10:38 -0500 |
commit | 5c99274b0177cd614455c277b1a4d4410d9cb702 (patch) | |
tree | ab857db34f7375c19e6e7d97af13534fe0b6d224 /drivers/net/bnx2x/bnx2x_link.c | |
parent | 1f48353a3ce7297f5150b47e21df5ec212876e5d (diff) |
bnx2x: Fix BCM8073/BCM8727 microcode loading
Improve microcode loading verification before proceeding to next stage
Signed-off-by: Yaniv Rosner <yanivr@broadcom.com>
Signed-off-by: Eilon Greenstein <eilong@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/bnx2x/bnx2x_link.c')
-rw-r--r-- | drivers/net/bnx2x/bnx2x_link.c | 73 |
1 files changed, 43 insertions, 30 deletions
diff --git a/drivers/net/bnx2x/bnx2x_link.c b/drivers/net/bnx2x/bnx2x_link.c index 36a88448b245..500258d38cf1 100644 --- a/drivers/net/bnx2x/bnx2x_link.c +++ b/drivers/net/bnx2x/bnx2x_link.c | |||
@@ -3870,11 +3870,14 @@ static void bnx2x_8073_resolve_fc(struct bnx2x_phy *phy, | |||
3870 | pause_result); | 3870 | pause_result); |
3871 | } | 3871 | } |
3872 | } | 3872 | } |
3873 | 3873 | static u8 bnx2x_8073_8727_external_rom_boot(struct bnx2x *bp, | |
3874 | static void bnx2x_8073_8727_external_rom_boot(struct bnx2x *bp, | ||
3875 | struct bnx2x_phy *phy, | 3874 | struct bnx2x_phy *phy, |
3876 | u8 port) | 3875 | u8 port) |
3877 | { | 3876 | { |
3877 | u32 count = 0; | ||
3878 | u16 fw_ver1, fw_msgout; | ||
3879 | u8 rc = 0; | ||
3880 | |||
3878 | /* Boot port from external ROM */ | 3881 | /* Boot port from external ROM */ |
3879 | /* EDC grst */ | 3882 | /* EDC grst */ |
3880 | bnx2x_cl45_write(bp, phy, | 3883 | bnx2x_cl45_write(bp, phy, |
@@ -3904,14 +3907,45 @@ static void bnx2x_8073_8727_external_rom_boot(struct bnx2x *bp, | |||
3904 | MDIO_PMA_REG_GEN_CTRL, | 3907 | MDIO_PMA_REG_GEN_CTRL, |
3905 | MDIO_PMA_REG_GEN_CTRL_ROM_RESET_INTERNAL_MP); | 3908 | MDIO_PMA_REG_GEN_CTRL_ROM_RESET_INTERNAL_MP); |
3906 | 3909 | ||
3907 | /* wait for 120ms for code download via SPI port */ | 3910 | /* Delay 100ms per the PHY specifications */ |
3908 | msleep(120); | 3911 | msleep(100); |
3912 | |||
3913 | /* 8073 sometimes taking longer to download */ | ||
3914 | do { | ||
3915 | count++; | ||
3916 | if (count > 300) { | ||
3917 | DP(NETIF_MSG_LINK, | ||
3918 | "bnx2x_8073_8727_external_rom_boot port %x:" | ||
3919 | "Download failed. fw version = 0x%x\n", | ||
3920 | port, fw_ver1); | ||
3921 | rc = -EINVAL; | ||
3922 | break; | ||
3923 | } | ||
3924 | |||
3925 | bnx2x_cl45_read(bp, phy, | ||
3926 | MDIO_PMA_DEVAD, | ||
3927 | MDIO_PMA_REG_ROM_VER1, &fw_ver1); | ||
3928 | bnx2x_cl45_read(bp, phy, | ||
3929 | MDIO_PMA_DEVAD, | ||
3930 | MDIO_PMA_REG_M8051_MSGOUT_REG, &fw_msgout); | ||
3931 | |||
3932 | msleep(1); | ||
3933 | } while (fw_ver1 == 0 || fw_ver1 == 0x4321 || | ||
3934 | ((fw_msgout & 0xff) != 0x03 && (phy->type == | ||
3935 | PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8073))); | ||
3909 | 3936 | ||
3910 | /* Clear ser_boot_ctl bit */ | 3937 | /* Clear ser_boot_ctl bit */ |
3911 | bnx2x_cl45_write(bp, phy, | 3938 | bnx2x_cl45_write(bp, phy, |
3912 | MDIO_PMA_DEVAD, | 3939 | MDIO_PMA_DEVAD, |
3913 | MDIO_PMA_REG_MISC_CTRL1, 0x0000); | 3940 | MDIO_PMA_REG_MISC_CTRL1, 0x0000); |
3914 | bnx2x_save_bcm_spirom_ver(bp, phy, port); | 3941 | bnx2x_save_bcm_spirom_ver(bp, phy, port); |
3942 | |||
3943 | DP(NETIF_MSG_LINK, | ||
3944 | "bnx2x_8073_8727_external_rom_boot port %x:" | ||
3945 | "Download complete. fw version = 0x%x\n", | ||
3946 | port, fw_ver1); | ||
3947 | |||
3948 | return rc; | ||
3915 | } | 3949 | } |
3916 | 3950 | ||
3917 | static void bnx2x_8073_set_xaui_low_power_mode(struct bnx2x *bp, | 3951 | static void bnx2x_8073_set_xaui_low_power_mode(struct bnx2x *bp, |
@@ -7721,7 +7755,6 @@ static u8 bnx2x_8073_common_init_phy(struct bnx2x *bp, | |||
7721 | 7755 | ||
7722 | /* PART2 - Download firmware to both phys */ | 7756 | /* PART2 - Download firmware to both phys */ |
7723 | for (port = PORT_MAX - 1; port >= PORT_0; port--) { | 7757 | for (port = PORT_MAX - 1; port >= PORT_0; port--) { |
7724 | u16 fw_ver1; | ||
7725 | if (CHIP_IS_E2(bp)) | 7758 | if (CHIP_IS_E2(bp)) |
7726 | port_of_path = 0; | 7759 | port_of_path = 0; |
7727 | else | 7760 | else |
@@ -7729,19 +7762,9 @@ static u8 bnx2x_8073_common_init_phy(struct bnx2x *bp, | |||
7729 | 7762 | ||
7730 | DP(NETIF_MSG_LINK, "Loading spirom for phy address 0x%x\n", | 7763 | DP(NETIF_MSG_LINK, "Loading spirom for phy address 0x%x\n", |
7731 | phy_blk[port]->addr); | 7764 | phy_blk[port]->addr); |
7732 | bnx2x_8073_8727_external_rom_boot(bp, phy_blk[port], | 7765 | if (bnx2x_8073_8727_external_rom_boot(bp, phy_blk[port], |
7733 | port_of_path); | 7766 | port_of_path)) |
7734 | |||
7735 | bnx2x_cl45_read(bp, phy_blk[port], | ||
7736 | MDIO_PMA_DEVAD, | ||
7737 | MDIO_PMA_REG_ROM_VER1, &fw_ver1); | ||
7738 | if (fw_ver1 == 0 || fw_ver1 == 0x4321) { | ||
7739 | DP(NETIF_MSG_LINK, | ||
7740 | "bnx2x_8073_common_init_phy port %x:" | ||
7741 | "Download failed. fw version = 0x%x\n", | ||
7742 | port, fw_ver1); | ||
7743 | return -EINVAL; | 7767 | return -EINVAL; |
7744 | } | ||
7745 | 7768 | ||
7746 | /* Only set bit 10 = 1 (Tx power down) */ | 7769 | /* Only set bit 10 = 1 (Tx power down) */ |
7747 | bnx2x_cl45_read(bp, phy_blk[port], | 7770 | bnx2x_cl45_read(bp, phy_blk[port], |
@@ -7906,27 +7929,17 @@ static u8 bnx2x_8727_common_init_phy(struct bnx2x *bp, | |||
7906 | } | 7929 | } |
7907 | /* PART2 - Download firmware to both phys */ | 7930 | /* PART2 - Download firmware to both phys */ |
7908 | for (port = PORT_MAX - 1; port >= PORT_0; port--) { | 7931 | for (port = PORT_MAX - 1; port >= PORT_0; port--) { |
7909 | u16 fw_ver1; | ||
7910 | if (CHIP_IS_E2(bp)) | 7932 | if (CHIP_IS_E2(bp)) |
7911 | port_of_path = 0; | 7933 | port_of_path = 0; |
7912 | else | 7934 | else |
7913 | port_of_path = port; | 7935 | port_of_path = port; |
7914 | DP(NETIF_MSG_LINK, "Loading spirom for phy address 0x%x\n", | 7936 | DP(NETIF_MSG_LINK, "Loading spirom for phy address 0x%x\n", |
7915 | phy_blk[port]->addr); | 7937 | phy_blk[port]->addr); |
7916 | bnx2x_8073_8727_external_rom_boot(bp, phy_blk[port], | 7938 | if (bnx2x_8073_8727_external_rom_boot(bp, phy_blk[port], |
7917 | port_of_path); | 7939 | port_of_path)) |
7918 | bnx2x_cl45_read(bp, phy_blk[port], | ||
7919 | MDIO_PMA_DEVAD, | ||
7920 | MDIO_PMA_REG_ROM_VER1, &fw_ver1); | ||
7921 | if (fw_ver1 == 0 || fw_ver1 == 0x4321) { | ||
7922 | DP(NETIF_MSG_LINK, | ||
7923 | "bnx2x_8727_common_init_phy port %x:" | ||
7924 | "Download failed. fw version = 0x%x\n", | ||
7925 | port, fw_ver1); | ||
7926 | return -EINVAL; | 7940 | return -EINVAL; |
7927 | } | ||
7928 | } | ||
7929 | 7941 | ||
7942 | } | ||
7930 | return 0; | 7943 | return 0; |
7931 | } | 7944 | } |
7932 | 7945 | ||