Commit 4293b9f5 authored by Dmitry Kravkov's avatar Dmitry Kravkov Committed by David S. Miller

bnx2x: Don't pretend during register dump

As part of a register dump, the interface pretends to have the identity
of other interfaces of the same physical device in order to perform
HW configuration for them - specifically, it needs to prevent attentions
from generating on those functions as the register dump accesses registers
in common blocks which whose reading might generate an attention.

However, such pretension is unsafe - unlike other flows in which the driver
uses pretend, during register dump there is no guarantee no other HW access
will take place (by other flows). If such access will take place, the HW will
be accessed by the wrong interface, and leave both functions in an incorrect
state.

This patch removes all pretensions from the register dump flow. Instead, it
changes initial configuration of attentions such that no fatal attention will
be generated for other functions as a result of the register dump
(notice however, a debug print claiming an attention from other functions IS
possible during the register dump)
Signed-off-by: default avatarDmitry Kravkov <dmitry@broadcom.com>
Signed-off-by: default avatarYuval Mintz <yuvalmin@broadcom.com>
Signed-off-by: default avatarAriel Elior <ariele@broadcom.com>
Signed-off-by: default avatarEilon Greenstein <eilong@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 32316a46
...@@ -891,17 +891,8 @@ static void bnx2x_get_regs(struct net_device *dev, ...@@ -891,17 +891,8 @@ static void bnx2x_get_regs(struct net_device *dev,
* will re-enable parity attentions right after the dump. * will re-enable parity attentions right after the dump.
*/ */
/* Disable parity on path 0 */
bnx2x_pretend_func(bp, 0);
bnx2x_disable_blocks_parity(bp); bnx2x_disable_blocks_parity(bp);
/* Disable parity on path 1 */
bnx2x_pretend_func(bp, 1);
bnx2x_disable_blocks_parity(bp);
/* Return to current function */
bnx2x_pretend_func(bp, BP_ABS_FUNC(bp));
dump_hdr.header_size = (sizeof(struct dump_header) / 4) - 1; dump_hdr.header_size = (sizeof(struct dump_header) / 4) - 1;
dump_hdr.preset = DUMP_ALL_PRESETS; dump_hdr.preset = DUMP_ALL_PRESETS;
dump_hdr.version = BNX2X_DUMP_VERSION; dump_hdr.version = BNX2X_DUMP_VERSION;
...@@ -928,18 +919,9 @@ static void bnx2x_get_regs(struct net_device *dev, ...@@ -928,18 +919,9 @@ static void bnx2x_get_regs(struct net_device *dev,
/* Actually read the registers */ /* Actually read the registers */
__bnx2x_get_regs(bp, p); __bnx2x_get_regs(bp, p);
/* Re-enable parity attentions on path 0 */ /* Re-enable parity attentions */
bnx2x_pretend_func(bp, 0);
bnx2x_clear_blocks_parity(bp); bnx2x_clear_blocks_parity(bp);
bnx2x_enable_blocks_parity(bp); bnx2x_enable_blocks_parity(bp);
/* Re-enable parity attentions on path 1 */
bnx2x_pretend_func(bp, 1);
bnx2x_clear_blocks_parity(bp);
bnx2x_enable_blocks_parity(bp);
/* Return to current function */
bnx2x_pretend_func(bp, BP_ABS_FUNC(bp));
} }
static int bnx2x_get_preset_regs_len(struct net_device *dev, u32 preset) static int bnx2x_get_preset_regs_len(struct net_device *dev, u32 preset)
...@@ -993,17 +975,8 @@ static int bnx2x_get_dump_data(struct net_device *dev, ...@@ -993,17 +975,8 @@ static int bnx2x_get_dump_data(struct net_device *dev,
* will re-enable parity attentions right after the dump. * will re-enable parity attentions right after the dump.
*/ */
/* Disable parity on path 0 */
bnx2x_pretend_func(bp, 0);
bnx2x_disable_blocks_parity(bp); bnx2x_disable_blocks_parity(bp);
/* Disable parity on path 1 */
bnx2x_pretend_func(bp, 1);
bnx2x_disable_blocks_parity(bp);
/* Return to current function */
bnx2x_pretend_func(bp, BP_ABS_FUNC(bp));
dump_hdr.header_size = (sizeof(struct dump_header) / 4) - 1; dump_hdr.header_size = (sizeof(struct dump_header) / 4) - 1;
dump_hdr.preset = bp->dump_preset_idx; dump_hdr.preset = bp->dump_preset_idx;
dump_hdr.version = BNX2X_DUMP_VERSION; dump_hdr.version = BNX2X_DUMP_VERSION;
...@@ -1032,19 +1005,10 @@ static int bnx2x_get_dump_data(struct net_device *dev, ...@@ -1032,19 +1005,10 @@ static int bnx2x_get_dump_data(struct net_device *dev,
/* Actually read the registers */ /* Actually read the registers */
__bnx2x_get_preset_regs(bp, p, dump_hdr.preset); __bnx2x_get_preset_regs(bp, p, dump_hdr.preset);
/* Re-enable parity attentions on path 0 */ /* Re-enable parity attentions */
bnx2x_pretend_func(bp, 0);
bnx2x_clear_blocks_parity(bp); bnx2x_clear_blocks_parity(bp);
bnx2x_enable_blocks_parity(bp); bnx2x_enable_blocks_parity(bp);
/* Re-enable parity attentions on path 1 */
bnx2x_pretend_func(bp, 1);
bnx2x_clear_blocks_parity(bp);
bnx2x_enable_blocks_parity(bp);
/* Return to current function */
bnx2x_pretend_func(bp, BP_ABS_FUNC(bp));
return 0; return 0;
} }
......
...@@ -640,23 +640,35 @@ static const struct { ...@@ -640,23 +640,35 @@ static const struct {
* [30] MCP Latched ump_tx_parity * [30] MCP Latched ump_tx_parity
* [31] MCP Latched scpad_parity * [31] MCP Latched scpad_parity
*/ */
#define MISC_AEU_ENABLE_MCP_PRTY_BITS \ #define MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS \
(AEU_INPUTS_ATTN_BITS_MCP_LATCHED_ROM_PARITY | \ (AEU_INPUTS_ATTN_BITS_MCP_LATCHED_ROM_PARITY | \
AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_RX_PARITY | \ AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_RX_PARITY | \
AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_TX_PARITY | \ AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_TX_PARITY)
#define MISC_AEU_ENABLE_MCP_PRTY_BITS \
(MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS | \
AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY) AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY)
/* Below registers control the MCP parity attention output. When /* Below registers control the MCP parity attention output. When
* MISC_AEU_ENABLE_MCP_PRTY_BITS are set - attentions are * MISC_AEU_ENABLE_MCP_PRTY_BITS are set - attentions are
* enabled, when cleared - disabled. * enabled, when cleared - disabled.
*/ */
static const u32 mcp_attn_ctl_regs[] = { static const struct {
MISC_REG_AEU_ENABLE4_FUNC_0_OUT_0, u32 addr;
MISC_REG_AEU_ENABLE4_NIG_0, u32 bits;
MISC_REG_AEU_ENABLE4_PXP_0, } mcp_attn_ctl_regs[] = {
MISC_REG_AEU_ENABLE4_FUNC_1_OUT_0, { MISC_REG_AEU_ENABLE4_FUNC_0_OUT_0,
MISC_REG_AEU_ENABLE4_NIG_1, MISC_AEU_ENABLE_MCP_PRTY_BITS },
MISC_REG_AEU_ENABLE4_PXP_1 { MISC_REG_AEU_ENABLE4_NIG_0,
MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS },
{ MISC_REG_AEU_ENABLE4_PXP_0,
MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS },
{ MISC_REG_AEU_ENABLE4_FUNC_1_OUT_0,
MISC_AEU_ENABLE_MCP_PRTY_BITS },
{ MISC_REG_AEU_ENABLE4_NIG_1,
MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS },
{ MISC_REG_AEU_ENABLE4_PXP_1,
MISC_AEU_ENABLE_MCP_PRTY_SUB_BITS }
}; };
static inline void bnx2x_set_mcp_parity(struct bnx2x *bp, u8 enable) static inline void bnx2x_set_mcp_parity(struct bnx2x *bp, u8 enable)
...@@ -665,14 +677,14 @@ static inline void bnx2x_set_mcp_parity(struct bnx2x *bp, u8 enable) ...@@ -665,14 +677,14 @@ static inline void bnx2x_set_mcp_parity(struct bnx2x *bp, u8 enable)
u32 reg_val; u32 reg_val;
for (i = 0; i < ARRAY_SIZE(mcp_attn_ctl_regs); i++) { for (i = 0; i < ARRAY_SIZE(mcp_attn_ctl_regs); i++) {
reg_val = REG_RD(bp, mcp_attn_ctl_regs[i]); reg_val = REG_RD(bp, mcp_attn_ctl_regs[i].addr);
if (enable) if (enable)
reg_val |= MISC_AEU_ENABLE_MCP_PRTY_BITS; reg_val |= mcp_attn_ctl_regs[i].bits;
else else
reg_val &= ~MISC_AEU_ENABLE_MCP_PRTY_BITS; reg_val &= ~mcp_attn_ctl_regs[i].bits;
REG_WR(bp, mcp_attn_ctl_regs[i], reg_val); REG_WR(bp, mcp_attn_ctl_regs[i].addr, reg_val);
} }
} }
......
...@@ -4297,119 +4297,120 @@ static void _print_next_block(int idx, const char *blk) ...@@ -4297,119 +4297,120 @@ static void _print_next_block(int idx, const char *blk)
pr_cont("%s%s", idx ? ", " : "", blk); pr_cont("%s%s", idx ? ", " : "", blk);
} }
static int bnx2x_check_blocks_with_parity0(struct bnx2x *bp, u32 sig, static bool bnx2x_check_blocks_with_parity0(struct bnx2x *bp, u32 sig,
int par_num, bool print) int *par_num, bool print)
{ {
int i = 0; u32 cur_bit;
u32 cur_bit = 0; bool res;
int i;
res = false;
for (i = 0; sig; i++) { for (i = 0; sig; i++) {
cur_bit = ((u32)0x1 << i); cur_bit = (0x1UL << i);
if (sig & cur_bit) { if (sig & cur_bit) {
res |= true; /* Each bit is real error! */
if (print) {
switch (cur_bit) { switch (cur_bit) {
case AEU_INPUTS_ATTN_BITS_BRB_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_BRB_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "BRB");
_print_next_block(par_num++, "BRB");
_print_parity(bp, _print_parity(bp,
BRB1_REG_BRB1_PRTY_STS); BRB1_REG_BRB1_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_PARSER_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_PARSER_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++,
_print_next_block(par_num++, "PARSER"); "PARSER");
_print_parity(bp, PRS_REG_PRS_PRTY_STS); _print_parity(bp, PRS_REG_PRS_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_TSDM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_TSDM_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "TSDM");
_print_next_block(par_num++, "TSDM");
_print_parity(bp, _print_parity(bp,
TSDM_REG_TSDM_PRTY_STS); TSDM_REG_TSDM_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_SEARCHER_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_SEARCHER_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++,
_print_next_block(par_num++,
"SEARCHER"); "SEARCHER");
_print_parity(bp, SRC_REG_SRC_PRTY_STS); _print_parity(bp, SRC_REG_SRC_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_TCM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_TCM_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "TCM");
_print_next_block(par_num++, "TCM"); _print_parity(bp, TCM_REG_TCM_PRTY_STS);
_print_parity(bp,
TCM_REG_TCM_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_TSEMI_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_TSEMI_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++,
_print_next_block(par_num++, "TSEMI"); "TSEMI");
_print_parity(bp, _print_parity(bp,
TSEM_REG_TSEM_PRTY_STS_0); TSEM_REG_TSEM_PRTY_STS_0);
_print_parity(bp, _print_parity(bp,
TSEM_REG_TSEM_PRTY_STS_1); TSEM_REG_TSEM_PRTY_STS_1);
}
break; break;
case AEU_INPUTS_ATTN_BITS_PBCLIENT_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_PBCLIENT_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "XPB");
_print_next_block(par_num++, "XPB");
_print_parity(bp, GRCBASE_XPB + _print_parity(bp, GRCBASE_XPB +
PB_REG_PB_PRTY_STS); PB_REG_PB_PRTY_STS);
}
break; break;
} }
}
/* Clear the bit */ /* Clear the bit */
sig &= ~cur_bit; sig &= ~cur_bit;
} }
} }
return par_num; return res;
} }
static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, static bool bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
int par_num, bool *global, int *par_num, bool *global,
bool print) bool print)
{ {
int i = 0; u32 cur_bit;
u32 cur_bit = 0; bool res;
int i;
res = false;
for (i = 0; sig; i++) { for (i = 0; sig; i++) {
cur_bit = ((u32)0x1 << i); cur_bit = (0x1UL << i);
if (sig & cur_bit) { if (sig & cur_bit) {
res |= true; /* Each bit is real error! */
switch (cur_bit) { switch (cur_bit) {
case AEU_INPUTS_ATTN_BITS_PBF_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_PBF_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "PBF"); _print_next_block((*par_num)++, "PBF");
_print_parity(bp, PBF_REG_PBF_PRTY_STS); _print_parity(bp, PBF_REG_PBF_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_QM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_QM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "QM"); _print_next_block((*par_num)++, "QM");
_print_parity(bp, QM_REG_QM_PRTY_STS); _print_parity(bp, QM_REG_QM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_TIMERS_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_TIMERS_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "TM"); _print_next_block((*par_num)++, "TM");
_print_parity(bp, TM_REG_TM_PRTY_STS); _print_parity(bp, TM_REG_TM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_XSDM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_XSDM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "XSDM"); _print_next_block((*par_num)++, "XSDM");
_print_parity(bp, _print_parity(bp,
XSDM_REG_XSDM_PRTY_STS); XSDM_REG_XSDM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_XCM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_XCM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "XCM"); _print_next_block((*par_num)++, "XCM");
_print_parity(bp, XCM_REG_XCM_PRTY_STS); _print_parity(bp, XCM_REG_XCM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_XSEMI_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_XSEMI_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "XSEMI"); _print_next_block((*par_num)++,
"XSEMI");
_print_parity(bp, _print_parity(bp,
XSEM_REG_XSEM_PRTY_STS_0); XSEM_REG_XSEM_PRTY_STS_0);
_print_parity(bp, _print_parity(bp,
...@@ -4418,7 +4419,7 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, ...@@ -4418,7 +4419,7 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
break; break;
case AEU_INPUTS_ATTN_BITS_DOORBELLQ_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_DOORBELLQ_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, _print_next_block((*par_num)++,
"DOORBELLQ"); "DOORBELLQ");
_print_parity(bp, _print_parity(bp,
DORQ_REG_DORQ_PRTY_STS); DORQ_REG_DORQ_PRTY_STS);
...@@ -4426,7 +4427,7 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, ...@@ -4426,7 +4427,7 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
break; break;
case AEU_INPUTS_ATTN_BITS_NIG_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_NIG_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "NIG"); _print_next_block((*par_num)++, "NIG");
if (CHIP_IS_E1x(bp)) { if (CHIP_IS_E1x(bp)) {
_print_parity(bp, _print_parity(bp,
NIG_REG_NIG_PRTY_STS); NIG_REG_NIG_PRTY_STS);
...@@ -4440,32 +4441,34 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, ...@@ -4440,32 +4441,34 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
break; break;
case AEU_INPUTS_ATTN_BITS_VAUX_PCI_CORE_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_VAUX_PCI_CORE_PARITY_ERROR:
if (print) if (print)
_print_next_block(par_num++, _print_next_block((*par_num)++,
"VAUX PCI CORE"); "VAUX PCI CORE");
*global = true; *global = true;
break; break;
case AEU_INPUTS_ATTN_BITS_DEBUG_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_DEBUG_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "DEBUG"); _print_next_block((*par_num)++,
"DEBUG");
_print_parity(bp, DBG_REG_DBG_PRTY_STS); _print_parity(bp, DBG_REG_DBG_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_USDM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_USDM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "USDM"); _print_next_block((*par_num)++, "USDM");
_print_parity(bp, _print_parity(bp,
USDM_REG_USDM_PRTY_STS); USDM_REG_USDM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_UCM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_UCM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "UCM"); _print_next_block((*par_num)++, "UCM");
_print_parity(bp, UCM_REG_UCM_PRTY_STS); _print_parity(bp, UCM_REG_UCM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_USEMI_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_USEMI_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "USEMI"); _print_next_block((*par_num)++,
"USEMI");
_print_parity(bp, _print_parity(bp,
USEM_REG_USEM_PRTY_STS_0); USEM_REG_USEM_PRTY_STS_0);
_print_parity(bp, _print_parity(bp,
...@@ -4474,21 +4477,21 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, ...@@ -4474,21 +4477,21 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
break; break;
case AEU_INPUTS_ATTN_BITS_UPB_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_UPB_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "UPB"); _print_next_block((*par_num)++, "UPB");
_print_parity(bp, GRCBASE_UPB + _print_parity(bp, GRCBASE_UPB +
PB_REG_PB_PRTY_STS); PB_REG_PB_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_CSDM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_CSDM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "CSDM"); _print_next_block((*par_num)++, "CSDM");
_print_parity(bp, _print_parity(bp,
CSDM_REG_CSDM_PRTY_STS); CSDM_REG_CSDM_PRTY_STS);
} }
break; break;
case AEU_INPUTS_ATTN_BITS_CCM_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_CCM_PARITY_ERROR:
if (print) { if (print) {
_print_next_block(par_num++, "CCM"); _print_next_block((*par_num)++, "CCM");
_print_parity(bp, CCM_REG_CCM_PRTY_STS); _print_parity(bp, CCM_REG_CCM_PRTY_STS);
} }
break; break;
...@@ -4499,121 +4502,123 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig, ...@@ -4499,121 +4502,123 @@ static int bnx2x_check_blocks_with_parity1(struct bnx2x *bp, u32 sig,
} }
} }
return par_num; return res;
} }
static int bnx2x_check_blocks_with_parity2(struct bnx2x *bp, u32 sig, static bool bnx2x_check_blocks_with_parity2(struct bnx2x *bp, u32 sig,
int par_num, bool print) int *par_num, bool print)
{ {
int i = 0; u32 cur_bit;
u32 cur_bit = 0; bool res;
int i;
res = false;
for (i = 0; sig; i++) { for (i = 0; sig; i++) {
cur_bit = ((u32)0x1 << i); cur_bit = (0x1UL << i);
if (sig & cur_bit) { if (sig & cur_bit) {
res |= true; /* Each bit is real error! */
if (print) {
switch (cur_bit) { switch (cur_bit) {
case AEU_INPUTS_ATTN_BITS_CSEMI_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_CSEMI_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++,
_print_next_block(par_num++, "CSEMI"); "CSEMI");
_print_parity(bp, _print_parity(bp,
CSEM_REG_CSEM_PRTY_STS_0); CSEM_REG_CSEM_PRTY_STS_0);
_print_parity(bp, _print_parity(bp,
CSEM_REG_CSEM_PRTY_STS_1); CSEM_REG_CSEM_PRTY_STS_1);
}
break; break;
case AEU_INPUTS_ATTN_BITS_PXP_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_PXP_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "PXP");
_print_next_block(par_num++, "PXP");
_print_parity(bp, PXP_REG_PXP_PRTY_STS); _print_parity(bp, PXP_REG_PXP_PRTY_STS);
_print_parity(bp, _print_parity(bp,
PXP2_REG_PXP2_PRTY_STS_0); PXP2_REG_PXP2_PRTY_STS_0);
_print_parity(bp, _print_parity(bp,
PXP2_REG_PXP2_PRTY_STS_1); PXP2_REG_PXP2_PRTY_STS_1);
}
break; break;
case AEU_IN_ATTN_BITS_PXPPCICLOCKCLIENT_PARITY_ERROR: case AEU_IN_ATTN_BITS_PXPPCICLOCKCLIENT_PARITY_ERROR:
if (print) _print_next_block((*par_num)++,
_print_next_block(par_num++,
"PXPPCICLOCKCLIENT"); "PXPPCICLOCKCLIENT");
break; break;
case AEU_INPUTS_ATTN_BITS_CFC_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_CFC_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "CFC");
_print_next_block(par_num++, "CFC");
_print_parity(bp, _print_parity(bp,
CFC_REG_CFC_PRTY_STS); CFC_REG_CFC_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_CDU_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_CDU_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "CDU");
_print_next_block(par_num++, "CDU");
_print_parity(bp, CDU_REG_CDU_PRTY_STS); _print_parity(bp, CDU_REG_CDU_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_DMAE_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_DMAE_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "DMAE");
_print_next_block(par_num++, "DMAE");
_print_parity(bp, _print_parity(bp,
DMAE_REG_DMAE_PRTY_STS); DMAE_REG_DMAE_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_IGU_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_IGU_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "IGU");
_print_next_block(par_num++, "IGU");
if (CHIP_IS_E1x(bp)) if (CHIP_IS_E1x(bp))
_print_parity(bp, _print_parity(bp,
HC_REG_HC_PRTY_STS); HC_REG_HC_PRTY_STS);
else else
_print_parity(bp, _print_parity(bp,
IGU_REG_IGU_PRTY_STS); IGU_REG_IGU_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_MISC_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_MISC_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "MISC");
_print_next_block(par_num++, "MISC");
_print_parity(bp, _print_parity(bp,
MISC_REG_MISC_PRTY_STS); MISC_REG_MISC_PRTY_STS);
}
break; break;
} }
}
/* Clear the bit */ /* Clear the bit */
sig &= ~cur_bit; sig &= ~cur_bit;
} }
} }
return par_num; return res;
} }
static int bnx2x_check_blocks_with_parity3(u32 sig, int par_num, static bool bnx2x_check_blocks_with_parity3(struct bnx2x *bp, u32 sig,
bool *global, bool print) int *par_num, bool *global,
bool print)
{ {
int i = 0; bool res = false;
u32 cur_bit = 0; u32 cur_bit;
int i;
for (i = 0; sig; i++) { for (i = 0; sig; i++) {
cur_bit = ((u32)0x1 << i); cur_bit = (0x1UL << i);
if (sig & cur_bit) { if (sig & cur_bit) {
switch (cur_bit) { switch (cur_bit) {
case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_ROM_PARITY: case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_ROM_PARITY:
if (print) if (print)
_print_next_block(par_num++, "MCP ROM"); _print_next_block((*par_num)++,
"MCP ROM");
*global = true; *global = true;
res |= true;
break; break;
case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_RX_PARITY: case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_RX_PARITY:
if (print) if (print)
_print_next_block(par_num++, _print_next_block((*par_num)++,
"MCP UMP RX"); "MCP UMP RX");
*global = true; *global = true;
res |= true;
break; break;
case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_TX_PARITY: case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_UMP_TX_PARITY:
if (print) if (print)
_print_next_block(par_num++, _print_next_block((*par_num)++,
"MCP UMP TX"); "MCP UMP TX");
*global = true; *global = true;
res |= true;
break; break;
case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY: case AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY:
if (print) if (print)
_print_next_block(par_num++, _print_next_block((*par_num)++,
"MCP SCPAD"); "MCP SCPAD");
*global = true; /* clear latched SCPAD PATIRY from MCP */
REG_WR(bp, MISC_REG_AEU_CLR_LATCH_SIGNAL,
1UL << 10);
break; break;
} }
...@@ -4622,45 +4627,50 @@ static int bnx2x_check_blocks_with_parity3(u32 sig, int par_num, ...@@ -4622,45 +4627,50 @@ static int bnx2x_check_blocks_with_parity3(u32 sig, int par_num,
} }
} }
return par_num; return res;
} }
static int bnx2x_check_blocks_with_parity4(struct bnx2x *bp, u32 sig, static bool bnx2x_check_blocks_with_parity4(struct bnx2x *bp, u32 sig,
int par_num, bool print) int *par_num, bool print)
{ {
int i = 0; u32 cur_bit;
u32 cur_bit = 0; bool res;
int i;
res = false;
for (i = 0; sig; i++) { for (i = 0; sig; i++) {
cur_bit = ((u32)0x1 << i); cur_bit = (0x1UL << i);
if (sig & cur_bit) { if (sig & cur_bit) {
res |= true; /* Each bit is real error! */
if (print) {
switch (cur_bit) { switch (cur_bit) {
case AEU_INPUTS_ATTN_BITS_PGLUE_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_PGLUE_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++,
_print_next_block(par_num++, "PGLUE_B"); "PGLUE_B");
_print_parity(bp, _print_parity(bp,
PGLUE_B_REG_PGLUE_B_PRTY_STS); PGLUE_B_REG_PGLUE_B_PRTY_STS);
}
break; break;
case AEU_INPUTS_ATTN_BITS_ATC_PARITY_ERROR: case AEU_INPUTS_ATTN_BITS_ATC_PARITY_ERROR:
if (print) { _print_next_block((*par_num)++, "ATC");
_print_next_block(par_num++, "ATC");
_print_parity(bp, _print_parity(bp,
ATC_REG_ATC_PRTY_STS); ATC_REG_ATC_PRTY_STS);
}
break; break;
} }
}
/* Clear the bit */ /* Clear the bit */
sig &= ~cur_bit; sig &= ~cur_bit;
} }
} }
return par_num; return res;
} }
static bool bnx2x_parity_attn(struct bnx2x *bp, bool *global, bool print, static bool bnx2x_parity_attn(struct bnx2x *bp, bool *global, bool print,
u32 *sig) u32 *sig)
{ {
bool res = false;
if ((sig[0] & HW_PRTY_ASSERT_SET_0) || if ((sig[0] & HW_PRTY_ASSERT_SET_0) ||
(sig[1] & HW_PRTY_ASSERT_SET_1) || (sig[1] & HW_PRTY_ASSERT_SET_1) ||
(sig[2] & HW_PRTY_ASSERT_SET_2) || (sig[2] & HW_PRTY_ASSERT_SET_2) ||
...@@ -4677,23 +4687,22 @@ static bool bnx2x_parity_attn(struct bnx2x *bp, bool *global, bool print, ...@@ -4677,23 +4687,22 @@ static bool bnx2x_parity_attn(struct bnx2x *bp, bool *global, bool print,
if (print) if (print)
netdev_err(bp->dev, netdev_err(bp->dev,
"Parity errors detected in blocks: "); "Parity errors detected in blocks: ");
par_num = bnx2x_check_blocks_with_parity0(bp, res |= bnx2x_check_blocks_with_parity0(bp,
sig[0] & HW_PRTY_ASSERT_SET_0, par_num, print); sig[0] & HW_PRTY_ASSERT_SET_0, &par_num, print);
par_num = bnx2x_check_blocks_with_parity1(bp, res |= bnx2x_check_blocks_with_parity1(bp,
sig[1] & HW_PRTY_ASSERT_SET_1, par_num, global, print); sig[1] & HW_PRTY_ASSERT_SET_1, &par_num, global, print);
par_num = bnx2x_check_blocks_with_parity2(bp, res |= bnx2x_check_blocks_with_parity2(bp,
sig[2] & HW_PRTY_ASSERT_SET_2, par_num, print); sig[2] & HW_PRTY_ASSERT_SET_2, &par_num, print);
par_num = bnx2x_check_blocks_with_parity3( res |= bnx2x_check_blocks_with_parity3(bp,
sig[3] & HW_PRTY_ASSERT_SET_3, par_num, global, print); sig[3] & HW_PRTY_ASSERT_SET_3, &par_num, global, print);
par_num = bnx2x_check_blocks_with_parity4(bp, res |= bnx2x_check_blocks_with_parity4(bp,
sig[4] & HW_PRTY_ASSERT_SET_4, par_num, print); sig[4] & HW_PRTY_ASSERT_SET_4, &par_num, print);
if (print) if (print)
pr_cont("\n"); pr_cont("\n");
}
return true; return res;
} else
return false;
} }
/** /**
...@@ -7143,7 +7152,7 @@ static int bnx2x_init_hw_port(struct bnx2x *bp) ...@@ -7143,7 +7152,7 @@ static int bnx2x_init_hw_port(struct bnx2x *bp)
int port = BP_PORT(bp); int port = BP_PORT(bp);
int init_phase = port ? PHASE_PORT1 : PHASE_PORT0; int init_phase = port ? PHASE_PORT1 : PHASE_PORT0;
u32 low, high; u32 low, high;
u32 val; u32 val, reg;
DP(NETIF_MSG_HW, "starting port init port %d\n", port); DP(NETIF_MSG_HW, "starting port init port %d\n", port);
...@@ -7288,6 +7297,17 @@ static int bnx2x_init_hw_port(struct bnx2x *bp) ...@@ -7288,6 +7297,17 @@ static int bnx2x_init_hw_port(struct bnx2x *bp)
val |= CHIP_IS_E1(bp) ? 0 : 0x10; val |= CHIP_IS_E1(bp) ? 0 : 0x10;
REG_WR(bp, MISC_REG_AEU_MASK_ATTN_FUNC_0 + port*4, val); REG_WR(bp, MISC_REG_AEU_MASK_ATTN_FUNC_0 + port*4, val);
/* SCPAD_PARITY should NOT trigger close the gates */
reg = port ? MISC_REG_AEU_ENABLE4_NIG_1 : MISC_REG_AEU_ENABLE4_NIG_0;
REG_WR(bp, reg,
REG_RD(bp, reg) &
~AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY);
reg = port ? MISC_REG_AEU_ENABLE4_PXP_1 : MISC_REG_AEU_ENABLE4_PXP_0;
REG_WR(bp, reg,
REG_RD(bp, reg) &
~AEU_INPUTS_ATTN_BITS_MCP_LATCHED_SCPAD_PARITY);
bnx2x_init_block(bp, BLOCK_NIG, init_phase); bnx2x_init_block(bp, BLOCK_NIG, init_phase);
if (!CHIP_IS_E1x(bp)) { if (!CHIP_IS_E1x(bp)) {
......
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