提交 f5372251 编写于 作者: E Eilon Greenstein 提交者: David S. Miller

bnx2x: Comments and prints

Signed-off-by: NEilon Greenstein <eilong@broadcom.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 9898f86d
...@@ -194,7 +194,7 @@ ...@@ -194,7 +194,7 @@
#define COMMON_ASM_INVALID_ASSERT_OPCODE 0x0 #define COMMON_ASM_INVALID_ASSERT_OPCODE 0x0
/** /**
* This file defines HSI constatnts for the ETH flow * This file defines HSI constants for the ETH flow
*/ */
#ifdef _EVEREST_MICROCODE #ifdef _EVEREST_MICROCODE
#include "microcode_constants.h" #include "microcode_constants.h"
...@@ -212,7 +212,8 @@ ...@@ -212,7 +212,8 @@
#define IPV6_HASH_TYPE 3 #define IPV6_HASH_TYPE 3
#define TCP_IPV6_HASH_TYPE 4 #define TCP_IPV6_HASH_TYPE 4
/* Ethernet Ring parmaters */
/* Ethernet Ring parameters */
#define X_ETH_LOCAL_RING_SIZE 13 #define X_ETH_LOCAL_RING_SIZE 13
#define FIRST_BD_IN_PKT 0 #define FIRST_BD_IN_PKT 0
#define PARSE_BD_INDEX 1 #define PARSE_BD_INDEX 1
...@@ -279,7 +280,7 @@ ...@@ -279,7 +280,7 @@
/** /**
* This file defines HSI constatnts common to all microcode flows * This file defines HSI constants common to all microcode flows
*/ */
/* Connection types */ /* Connection types */
...@@ -313,7 +314,7 @@ ...@@ -313,7 +314,7 @@
#define HC_USTORM_SB_NUM_INDICES 4 #define HC_USTORM_SB_NUM_INDICES 4
#define HC_CSTORM_SB_NUM_INDICES 4 #define HC_CSTORM_SB_NUM_INDICES 4
/* index values - which counterto update */ /* index values - which counter to update */
#define HC_INDEX_U_TOE_RX_CQ_CONS 0 #define HC_INDEX_U_TOE_RX_CQ_CONS 0
#define HC_INDEX_U_ETH_RX_CQ_CONS 1 #define HC_INDEX_U_ETH_RX_CQ_CONS 1
......
...@@ -1671,7 +1671,7 @@ struct xstorm_eth_ag_context { ...@@ -1671,7 +1671,7 @@ struct xstorm_eth_ag_context {
}; };
/* /*
* The eth aggregative context section of Tstorm * The eth extra aggregative context section of Tstorm
*/ */
struct tstorm_eth_extra_ag_context_section { struct tstorm_eth_extra_ag_context_section {
u32 __agg_val1; u32 __agg_val1;
......
...@@ -429,57 +429,57 @@ struct arb_line { ...@@ -429,57 +429,57 @@ struct arb_line {
/* derived configuration for each read queue for each max request size */ /* derived configuration for each read queue for each max request size */
static const struct arb_line read_arb_data[NUM_RD_Q][MAX_RD_ORD + 1] = { static const struct arb_line read_arb_data[NUM_RD_Q][MAX_RD_ORD + 1] = {
{{8 , 64 , 25}, {16 , 64 , 25}, {32 , 64 , 25}, {64 , 64 , 41} }, /* 1 */ { {8, 64, 25}, {16, 64, 25}, {32, 64, 25}, {64, 64, 41} },
{{4 , 8 , 4}, {4 , 8 , 4}, {4 , 8 , 4}, {4 , 8 , 4} }, { {4, 8, 4}, {4, 8, 4}, {4, 8, 4}, {4, 8, 4} },
{{4 , 3 , 3}, {4 , 3 , 3}, {4 , 3 , 3}, {4 , 3 , 3} }, { {4, 3, 3}, {4, 3, 3}, {4, 3, 3}, {4, 3, 3} },
{{8 , 3 , 6}, {16 , 3 , 11}, {16 , 3 , 11}, {16 , 3 , 11} }, { {8, 3, 6}, {16, 3, 11}, {16, 3, 11}, {16, 3, 11} },
{{8 , 64 , 25}, {16 , 64 , 25}, {32 , 64 , 25}, {64 , 64 , 41} }, { {8, 64, 25}, {16, 64, 25}, {32, 64, 25}, {64, 64, 41} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {64 , 3 , 41} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {64, 3, 41} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {64 , 3 , 41} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {64, 3, 41} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {64 , 3 , 41} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {64, 3, 41} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {64 , 3 , 41} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {64, 3, 41} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, /* 10 */{ {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, /* 20 */{ {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 3 , 6}, {16 , 3 , 11}, {32 , 3 , 21}, {32 , 3 , 21} }, { {8, 3, 6}, {16, 3, 11}, {32, 3, 21}, {32, 3, 21} },
{{8 , 64 , 25}, {16 , 64 , 41}, {32 , 64 , 81}, {64 , 64 , 120} } { {8, 64, 25}, {16, 64, 41}, {32, 64, 81}, {64, 64, 120} }
}; };
/* derived configuration for each write queue for each max request size */ /* derived configuration for each write queue for each max request size */
static const struct arb_line write_arb_data[NUM_WR_Q][MAX_WR_ORD + 1] = { static const struct arb_line write_arb_data[NUM_WR_Q][MAX_WR_ORD + 1] = {
{{4 , 6 , 3}, {4 , 6 , 3}, {4 , 6 , 3} }, /* 1 */ { {4, 6, 3}, {4, 6, 3}, {4, 6, 3} },
{{4 , 2 , 3}, {4 , 2 , 3}, {4 , 2 , 3} }, { {4, 2, 3}, {4, 2, 3}, {4, 2, 3} },
{{8 , 2 , 6}, {16 , 2 , 11}, {16 , 2 , 11} }, { {8, 2, 6}, {16, 2, 11}, {16, 2, 11} },
{{8 , 2 , 6}, {16 , 2 , 11}, {32 , 2 , 21} }, { {8, 2, 6}, {16, 2, 11}, {32, 2, 21} },
{{8 , 2 , 6}, {16 , 2 , 11}, {32 , 2 , 21} }, { {8, 2, 6}, {16, 2, 11}, {32, 2, 21} },
{{8 , 2 , 6}, {16 , 2 , 11}, {32 , 2 , 21} }, { {8, 2, 6}, {16, 2, 11}, {32, 2, 21} },
{{8 , 64 , 25}, {16 , 64 , 25}, {32 , 64 , 25} }, { {8, 64, 25}, {16, 64, 25}, {32, 64, 25} },
{{8 , 2 , 6}, {16 , 2 , 11}, {16 , 2 , 11} }, { {8, 2, 6}, {16, 2, 11}, {16, 2, 11} },
{{8 , 2 , 6}, {16 , 2 , 11}, {16 , 2 , 11} }, { {8, 2, 6}, {16, 2, 11}, {16, 2, 11} },
{{8 , 9 , 6}, {16 , 9 , 11}, {32 , 9 , 21} }, /* 10 */{ {8, 9, 6}, {16, 9, 11}, {32, 9, 21} },
{{8 , 47 , 19}, {16 , 47 , 19}, {32 , 47 , 21} }, { {8, 47, 19}, {16, 47, 19}, {32, 47, 21} },
{{8 , 9 , 6}, {16 , 9 , 11}, {16 , 9 , 11} }, { {8, 9, 6}, {16, 9, 11}, {16, 9, 11} },
{{8 , 64 , 25}, {16 , 64 , 41}, {32 , 64 , 81} } { {8, 64, 25}, {16, 64, 41}, {32, 64, 81} }
}; };
/* register addresses for read queues */ /* register addresses for read queues */
static const struct arb_line read_arb_addr[NUM_RD_Q-1] = { static const struct arb_line read_arb_addr[NUM_RD_Q-1] = {
{PXP2_REG_RQ_BW_RD_L0, PXP2_REG_RQ_BW_RD_ADD0, /* 1 */ {PXP2_REG_RQ_BW_RD_L0, PXP2_REG_RQ_BW_RD_ADD0,
PXP2_REG_RQ_BW_RD_UBOUND0}, PXP2_REG_RQ_BW_RD_UBOUND0},
{PXP2_REG_PSWRQ_BW_L1, PXP2_REG_PSWRQ_BW_ADD1, {PXP2_REG_PSWRQ_BW_L1, PXP2_REG_PSWRQ_BW_ADD1,
PXP2_REG_PSWRQ_BW_UB1}, PXP2_REG_PSWRQ_BW_UB1},
...@@ -497,7 +497,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = { ...@@ -497,7 +497,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = {
PXP2_REG_PSWRQ_BW_UB7}, PXP2_REG_PSWRQ_BW_UB7},
{PXP2_REG_PSWRQ_BW_L8, PXP2_REG_PSWRQ_BW_ADD8, {PXP2_REG_PSWRQ_BW_L8, PXP2_REG_PSWRQ_BW_ADD8,
PXP2_REG_PSWRQ_BW_UB8}, PXP2_REG_PSWRQ_BW_UB8},
{PXP2_REG_PSWRQ_BW_L9, PXP2_REG_PSWRQ_BW_ADD9, /* 10 */{PXP2_REG_PSWRQ_BW_L9, PXP2_REG_PSWRQ_BW_ADD9,
PXP2_REG_PSWRQ_BW_UB9}, PXP2_REG_PSWRQ_BW_UB9},
{PXP2_REG_PSWRQ_BW_L10, PXP2_REG_PSWRQ_BW_ADD10, {PXP2_REG_PSWRQ_BW_L10, PXP2_REG_PSWRQ_BW_ADD10,
PXP2_REG_PSWRQ_BW_UB10}, PXP2_REG_PSWRQ_BW_UB10},
...@@ -517,7 +517,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = { ...@@ -517,7 +517,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = {
PXP2_REG_RQ_BW_RD_UBOUND17}, PXP2_REG_RQ_BW_RD_UBOUND17},
{PXP2_REG_RQ_BW_RD_L18, PXP2_REG_RQ_BW_RD_ADD18, {PXP2_REG_RQ_BW_RD_L18, PXP2_REG_RQ_BW_RD_ADD18,
PXP2_REG_RQ_BW_RD_UBOUND18}, PXP2_REG_RQ_BW_RD_UBOUND18},
{PXP2_REG_RQ_BW_RD_L19, PXP2_REG_RQ_BW_RD_ADD19, /* 20 */{PXP2_REG_RQ_BW_RD_L19, PXP2_REG_RQ_BW_RD_ADD19,
PXP2_REG_RQ_BW_RD_UBOUND19}, PXP2_REG_RQ_BW_RD_UBOUND19},
{PXP2_REG_RQ_BW_RD_L20, PXP2_REG_RQ_BW_RD_ADD20, {PXP2_REG_RQ_BW_RD_L20, PXP2_REG_RQ_BW_RD_ADD20,
PXP2_REG_RQ_BW_RD_UBOUND20}, PXP2_REG_RQ_BW_RD_UBOUND20},
...@@ -539,7 +539,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = { ...@@ -539,7 +539,7 @@ static const struct arb_line read_arb_addr[NUM_RD_Q-1] = {
/* register addresses for write queues */ /* register addresses for write queues */
static const struct arb_line write_arb_addr[NUM_WR_Q-1] = { static const struct arb_line write_arb_addr[NUM_WR_Q-1] = {
{PXP2_REG_PSWRQ_BW_L1, PXP2_REG_PSWRQ_BW_ADD1, /* 1 */ {PXP2_REG_PSWRQ_BW_L1, PXP2_REG_PSWRQ_BW_ADD1,
PXP2_REG_PSWRQ_BW_UB1}, PXP2_REG_PSWRQ_BW_UB1},
{PXP2_REG_PSWRQ_BW_L2, PXP2_REG_PSWRQ_BW_ADD2, {PXP2_REG_PSWRQ_BW_L2, PXP2_REG_PSWRQ_BW_ADD2,
PXP2_REG_PSWRQ_BW_UB2}, PXP2_REG_PSWRQ_BW_UB2},
...@@ -557,7 +557,7 @@ static const struct arb_line write_arb_addr[NUM_WR_Q-1] = { ...@@ -557,7 +557,7 @@ static const struct arb_line write_arb_addr[NUM_WR_Q-1] = {
PXP2_REG_PSWRQ_BW_UB10}, PXP2_REG_PSWRQ_BW_UB10},
{PXP2_REG_PSWRQ_BW_L11, PXP2_REG_PSWRQ_BW_ADD11, {PXP2_REG_PSWRQ_BW_L11, PXP2_REG_PSWRQ_BW_ADD11,
PXP2_REG_PSWRQ_BW_UB11}, PXP2_REG_PSWRQ_BW_UB11},
{PXP2_REG_PSWRQ_BW_L28, PXP2_REG_PSWRQ_BW_ADD28, /* 10 */{PXP2_REG_PSWRQ_BW_L28, PXP2_REG_PSWRQ_BW_ADD28,
PXP2_REG_PSWRQ_BW_UB28}, PXP2_REG_PSWRQ_BW_UB28},
{PXP2_REG_RQ_BW_WR_L29, PXP2_REG_RQ_BW_WR_ADD29, {PXP2_REG_RQ_BW_WR_L29, PXP2_REG_RQ_BW_WR_ADD29,
PXP2_REG_RQ_BW_WR_UBOUND29}, PXP2_REG_RQ_BW_WR_UBOUND29},
......
...@@ -4823,6 +4823,7 @@ u8 bnx2x_phy_init(struct link_params *params, struct link_vars *vars) ...@@ -4823,6 +4823,7 @@ u8 bnx2x_phy_init(struct link_params *params, struct link_vars *vars)
return -EINVAL; return -EINVAL;
break; break;
} }
DP(NETIF_MSG_LINK, "Phy address = 0x%x\n", params->phy_addr);
bnx2x_link_initialize(params, vars); bnx2x_link_initialize(params, vars);
msleep(30); msleep(30);
...@@ -5179,7 +5180,7 @@ static u8 bnx2x_8073_common_init_phy(struct bnx2x *bp, u32 shmem_base) ...@@ -5179,7 +5180,7 @@ static u8 bnx2x_8073_common_init_phy(struct bnx2x *bp, u32 shmem_base)
/* PART3 - complete TX_POWER_DOWN process, and set GPIO2 back to low */ /* PART3 - complete TX_POWER_DOWN process, and set GPIO2 back to low */
for (port = PORT_MAX - 1; port >= PORT_0; port--) { for (port = PORT_MAX - 1; port >= PORT_0; port--) {
/* Phase2 of POWER_DOWN_RESET*/ /* Phase2 of POWER_DOWN_RESET */
/* Release bit 10 (Release Tx power down) */ /* Release bit 10 (Release Tx power down) */
bnx2x_cl45_read(bp, port, bnx2x_cl45_read(bp, port,
PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8073, PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8073,
...@@ -5258,7 +5259,7 @@ u8 bnx2x_common_init_phy(struct bnx2x *bp, u32 shmem_base) ...@@ -5258,7 +5259,7 @@ u8 bnx2x_common_init_phy(struct bnx2x *bp, u32 shmem_base)
u8 rc = 0; u8 rc = 0;
u32 ext_phy_type; u32 ext_phy_type;
DP(NETIF_MSG_LINK, "bnx2x_common_init_phy\n"); DP(NETIF_MSG_LINK, "Begin common phy init\n");
/* Read the ext_phy_type for arbitrary port(0) */ /* Read the ext_phy_type for arbitrary port(0) */
ext_phy_type = XGXS_EXT_PHY_TYPE( ext_phy_type = XGXS_EXT_PHY_TYPE(
......
...@@ -1704,7 +1704,7 @@ static irqreturn_t bnx2x_interrupt(int irq, void *dev_instance) ...@@ -1704,7 +1704,7 @@ static irqreturn_t bnx2x_interrupt(int irq, void *dev_instance)
DP(NETIF_MSG_INTR, "not our interrupt!\n"); DP(NETIF_MSG_INTR, "not our interrupt!\n");
return IRQ_NONE; return IRQ_NONE;
} }
DP(NETIF_MSG_INTR, "got an interrupt status %u\n", status); DP(NETIF_MSG_INTR, "got an interrupt status 0x%x\n", status);
/* Return here if interrupt is disabled */ /* Return here if interrupt is disabled */
if (unlikely(atomic_read(&bp->intr_sem) != 0)) { if (unlikely(atomic_read(&bp->intr_sem) != 0)) {
...@@ -2115,7 +2115,7 @@ static u8 bnx2x_initial_phy_init(struct bnx2x *bp, int load_mode) ...@@ -2115,7 +2115,7 @@ static u8 bnx2x_initial_phy_init(struct bnx2x *bp, int load_mode)
return rc; return rc;
} }
BNX2X_ERR("Bootcode is missing -not initializing link\n"); BNX2X_ERR("Bootcode is missing - can not initialize link\n");
return -EINVAL; return -EINVAL;
} }
...@@ -2128,7 +2128,7 @@ static void bnx2x_link_set(struct bnx2x *bp) ...@@ -2128,7 +2128,7 @@ static void bnx2x_link_set(struct bnx2x *bp)
bnx2x_calc_fc_adv(bp); bnx2x_calc_fc_adv(bp);
} else } else
BNX2X_ERR("Bootcode is missing -not setting link\n"); BNX2X_ERR("Bootcode is missing - can not set link\n");
} }
static void bnx2x__link_reset(struct bnx2x *bp) static void bnx2x__link_reset(struct bnx2x *bp)
...@@ -2138,7 +2138,7 @@ static void bnx2x__link_reset(struct bnx2x *bp) ...@@ -2138,7 +2138,7 @@ static void bnx2x__link_reset(struct bnx2x *bp)
bnx2x_link_reset(&bp->link_params, &bp->link_vars, 1); bnx2x_link_reset(&bp->link_params, &bp->link_vars, 1);
bnx2x_release_phy_lock(bp); bnx2x_release_phy_lock(bp);
} else } else
BNX2X_ERR("Bootcode is missing -not resetting link\n"); BNX2X_ERR("Bootcode is missing - can not reset link\n");
} }
static u8 bnx2x_link_test(struct bnx2x *bp) static u8 bnx2x_link_test(struct bnx2x *bp)
...@@ -5139,8 +5139,8 @@ static void bnx2x_nic_init(struct bnx2x *bp, u32 load_code) ...@@ -5139,8 +5139,8 @@ static void bnx2x_nic_init(struct bnx2x *bp, u32 load_code)
fp->cl_id = BP_L_ID(bp) + i; fp->cl_id = BP_L_ID(bp) + i;
fp->sb_id = fp->cl_id; fp->sb_id = fp->cl_id;
DP(NETIF_MSG_IFUP, DP(NETIF_MSG_IFUP,
"bnx2x_init_sb(%p,%p) index %d cl_id %d sb %d\n", "queue[%d]: bnx2x_init_sb(%p,%p) cl_id %d sb %d\n",
bp, fp->status_blk, i, fp->cl_id, fp->sb_id); i, bp, fp->status_blk, fp->cl_id, fp->sb_id);
bnx2x_init_sb(bp, fp->status_blk, fp->status_blk_mapping, bnx2x_init_sb(bp, fp->status_blk, fp->status_blk_mapping,
fp->sb_id); fp->sb_id);
bnx2x_update_fpsb_idx(fp); bnx2x_update_fpsb_idx(fp);
...@@ -6904,11 +6904,11 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode) ...@@ -6904,11 +6904,11 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode)
} else { } else {
int port = BP_PORT(bp); int port = BP_PORT(bp);
DP(NETIF_MSG_IFUP, "NO MCP load counts before us %d, %d, %d\n", DP(NETIF_MSG_IFUP, "NO MCP - load counts %d, %d, %d\n",
load_count[0], load_count[1], load_count[2]); load_count[0], load_count[1], load_count[2]);
load_count[0]++; load_count[0]++;
load_count[1 + port]++; load_count[1 + port]++;
DP(NETIF_MSG_IFUP, "NO MCP new load counts %d, %d, %d\n", DP(NETIF_MSG_IFUP, "NO MCP - new load counts %d, %d, %d\n",
load_count[0], load_count[1], load_count[2]); load_count[0], load_count[1], load_count[2]);
if (load_count[0] == 1) if (load_count[0] == 1)
load_code = FW_MSG_CODE_DRV_LOAD_COMMON; load_code = FW_MSG_CODE_DRV_LOAD_COMMON;
...@@ -6955,7 +6955,7 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode) ...@@ -6955,7 +6955,7 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode)
if (CHIP_IS_E1H(bp)) if (CHIP_IS_E1H(bp))
if (bp->mf_config & FUNC_MF_CFG_FUNC_DISABLED) { if (bp->mf_config & FUNC_MF_CFG_FUNC_DISABLED) {
BNX2X_ERR("!!! mf_cfg function disabled\n"); DP(NETIF_MSG_IFUP, "mf_cfg function disabled\n");
bp->state = BNX2X_STATE_DISABLED; bp->state = BNX2X_STATE_DISABLED;
} }
...@@ -7028,8 +7028,6 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode) ...@@ -7028,8 +7028,6 @@ static int bnx2x_nic_load(struct bnx2x *bp, int load_mode)
netif_napi_del(&bnx2x_fp(bp, i, napi)); netif_napi_del(&bnx2x_fp(bp, i, napi));
bnx2x_free_mem(bp); bnx2x_free_mem(bp);
/* TBD we really need to reset the chip
if we want to recover from this */
return rc; return rc;
} }
...@@ -7303,11 +7301,11 @@ static int bnx2x_nic_unload(struct bnx2x *bp, int unload_mode) ...@@ -7303,11 +7301,11 @@ static int bnx2x_nic_unload(struct bnx2x *bp, int unload_mode)
if (!BP_NOMCP(bp)) if (!BP_NOMCP(bp))
reset_code = bnx2x_fw_command(bp, reset_code); reset_code = bnx2x_fw_command(bp, reset_code);
else { else {
DP(NETIF_MSG_IFDOWN, "NO MCP load counts %d, %d, %d\n", DP(NETIF_MSG_IFDOWN, "NO MCP - load counts %d, %d, %d\n",
load_count[0], load_count[1], load_count[2]); load_count[0], load_count[1], load_count[2]);
load_count[0]--; load_count[0]--;
load_count[1 + port]--; load_count[1 + port]--;
DP(NETIF_MSG_IFDOWN, "NO MCP new load counts %d, %d, %d\n", DP(NETIF_MSG_IFDOWN, "NO MCP - new load counts %d, %d, %d\n",
load_count[0], load_count[1], load_count[2]); load_count[0], load_count[1], load_count[2]);
if (load_count[0] == 0) if (load_count[0] == 0)
reset_code = FW_MSG_CODE_DRV_UNLOAD_COMMON; reset_code = FW_MSG_CODE_DRV_UNLOAD_COMMON;
...@@ -7615,7 +7613,7 @@ static void __devinit bnx2x_get_common_hwinfo(struct bnx2x *bp) ...@@ -7615,7 +7613,7 @@ static void __devinit bnx2x_get_common_hwinfo(struct bnx2x *bp)
bp->flags |= NO_WOL_FLAG; bp->flags |= NO_WOL_FLAG;
} }
BNX2X_DEV_INFO("%sWoL capable\n", BNX2X_DEV_INFO("%sWoL capable\n",
(bp->flags & NO_WOL_FLAG) ? "Not " : ""); (bp->flags & NO_WOL_FLAG) ? "not " : "");
val = SHMEM_RD(bp, dev_info.shared_hw_config.part_num); val = SHMEM_RD(bp, dev_info.shared_hw_config.part_num);
val2 = SHMEM_RD(bp, dev_info.shared_hw_config.part_num[4]); val2 = SHMEM_RD(bp, dev_info.shared_hw_config.part_num[4]);
...@@ -8111,7 +8109,7 @@ static int __devinit bnx2x_get_hwinfo(struct bnx2x *bp) ...@@ -8111,7 +8109,7 @@ static int __devinit bnx2x_get_hwinfo(struct bnx2x *bp)
"(0x%04x)\n", "(0x%04x)\n",
func, bp->e1hov, bp->e1hov); func, bp->e1hov, bp->e1hov);
} else { } else {
BNX2X_DEV_INFO("Single function mode\n"); BNX2X_DEV_INFO("single function mode\n");
if (BP_E1HVN(bp)) { if (BP_E1HVN(bp)) {
BNX2X_ERR("!!! No valid E1HOV for func %d," BNX2X_ERR("!!! No valid E1HOV for func %d,"
" aborting\n", func); " aborting\n", func);
...@@ -9519,7 +9517,7 @@ static int bnx2x_test_nvram(struct bnx2x *bp) ...@@ -9519,7 +9517,7 @@ static int bnx2x_test_nvram(struct bnx2x *bp)
rc = bnx2x_nvram_read(bp, 0, data, 4); rc = bnx2x_nvram_read(bp, 0, data, 4);
if (rc) { if (rc) {
DP(NETIF_MSG_PROBE, "magic value read (rc -%d)\n", -rc); DP(NETIF_MSG_PROBE, "magic value read (rc %d)\n", rc);
goto test_nvram_exit; goto test_nvram_exit;
} }
...@@ -9536,7 +9534,7 @@ static int bnx2x_test_nvram(struct bnx2x *bp) ...@@ -9536,7 +9534,7 @@ static int bnx2x_test_nvram(struct bnx2x *bp)
nvram_tbl[i].size); nvram_tbl[i].size);
if (rc) { if (rc) {
DP(NETIF_MSG_PROBE, DP(NETIF_MSG_PROBE,
"nvram_tbl[%d] read data (rc -%d)\n", i, -rc); "nvram_tbl[%d] read data (rc %d)\n", i, rc);
goto test_nvram_exit; goto test_nvram_exit;
} }
...@@ -10173,7 +10171,9 @@ static inline u32 bnx2x_xmit_type(struct bnx2x *bp, struct sk_buff *skb) ...@@ -10173,7 +10171,9 @@ static inline u32 bnx2x_xmit_type(struct bnx2x *bp, struct sk_buff *skb)
} }
#if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3) #if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3)
/* check if packet requires linearization (packet is too fragmented) */ /* check if packet requires linearization (packet is too fragmented)
no need to check fragmentation if page size > 8K (there will be no
violation to FW restrictions) */
static int bnx2x_pkt_req_lin(struct bnx2x *bp, struct sk_buff *skb, static int bnx2x_pkt_req_lin(struct bnx2x *bp, struct sk_buff *skb,
u32 xmit_type) u32 xmit_type)
{ {
...@@ -10295,8 +10295,9 @@ static int bnx2x_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -10295,8 +10295,9 @@ static int bnx2x_start_xmit(struct sk_buff *skb, struct net_device *dev)
ip_hdr(skb)->protocol, skb_shinfo(skb)->gso_type, xmit_type); ip_hdr(skb)->protocol, skb_shinfo(skb)->gso_type, xmit_type);
#if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3) #if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3)
/* First, check if we need to linearize the skb /* First, check if we need to linearize the skb (due to FW
(due to FW restrictions) */ restrictions). No need to check fragmentation if page size > 8K
(there will be no violation to FW restrictions) */
if (bnx2x_pkt_req_lin(bp, skb, xmit_type)) { if (bnx2x_pkt_req_lin(bp, skb, xmit_type)) {
/* Statistics of linearization */ /* Statistics of linearization */
bp->lin_cnt++; bp->lin_cnt++;
...@@ -10557,7 +10558,7 @@ static int bnx2x_close(struct net_device *dev) ...@@ -10557,7 +10558,7 @@ static int bnx2x_close(struct net_device *dev)
return 0; return 0;
} }
/* called with netif_tx_lock from set_multicast */ /* called with netif_tx_lock from dev_mcast.c */
static void bnx2x_set_rx_mode(struct net_device *dev) static void bnx2x_set_rx_mode(struct net_device *dev)
{ {
struct bnx2x *bp = netdev_priv(dev); struct bnx2x *bp = netdev_priv(dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册