diff options
Diffstat (limited to 'drivers/net/bnx2x/bnx2x_ethtool.c')
-rw-r--r-- | drivers/net/bnx2x/bnx2x_ethtool.c | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/drivers/net/bnx2x/bnx2x_ethtool.c b/drivers/net/bnx2x/bnx2x_ethtool.c index 99c672d894c..5b44a8b4850 100644 --- a/drivers/net/bnx2x/bnx2x_ethtool.c +++ b/drivers/net/bnx2x/bnx2x_ethtool.c | |||
@@ -24,6 +24,7 @@ | |||
24 | #include "bnx2x.h" | 24 | #include "bnx2x.h" |
25 | #include "bnx2x_cmn.h" | 25 | #include "bnx2x_cmn.h" |
26 | #include "bnx2x_dump.h" | 26 | #include "bnx2x_dump.h" |
27 | #include "bnx2x_init.h" | ||
27 | 28 | ||
28 | /* Note: in the format strings below %s is replaced by the queue-name which is | 29 | /* Note: in the format strings below %s is replaced by the queue-name which is |
29 | * either its index or 'fcoe' for the fcoe queue. Make sure the format string | 30 | * either its index or 'fcoe' for the fcoe queue. Make sure the format string |
@@ -472,7 +473,7 @@ static int bnx2x_get_regs_len(struct net_device *dev) | |||
472 | { | 473 | { |
473 | struct bnx2x *bp = netdev_priv(dev); | 474 | struct bnx2x *bp = netdev_priv(dev); |
474 | int regdump_len = 0; | 475 | int regdump_len = 0; |
475 | int i; | 476 | int i, j, k; |
476 | 477 | ||
477 | if (CHIP_IS_E1(bp)) { | 478 | if (CHIP_IS_E1(bp)) { |
478 | for (i = 0; i < REGS_COUNT; i++) | 479 | for (i = 0; i < REGS_COUNT; i++) |
@@ -502,6 +503,15 @@ static int bnx2x_get_regs_len(struct net_device *dev) | |||
502 | if (IS_E2_ONLINE(wreg_addrs_e2[i].info)) | 503 | if (IS_E2_ONLINE(wreg_addrs_e2[i].info)) |
503 | regdump_len += wreg_addrs_e2[i].size * | 504 | regdump_len += wreg_addrs_e2[i].size * |
504 | (1 + wreg_addrs_e2[i].read_regs_count); | 505 | (1 + wreg_addrs_e2[i].read_regs_count); |
506 | |||
507 | for (i = 0; i < PAGE_MODE_VALUES_E2; i++) | ||
508 | for (j = 0; j < PAGE_WRITE_REGS_E2; j++) { | ||
509 | for (k = 0; k < PAGE_READ_REGS_E2; k++) | ||
510 | if (IS_E2_ONLINE(page_read_regs_e2[k]. | ||
511 | info)) | ||
512 | regdump_len += | ||
513 | page_read_regs_e2[k].size; | ||
514 | } | ||
505 | } | 515 | } |
506 | regdump_len *= 4; | 516 | regdump_len *= 4; |
507 | regdump_len += sizeof(struct dump_hdr); | 517 | regdump_len += sizeof(struct dump_hdr); |
@@ -539,6 +549,12 @@ static void bnx2x_get_regs(struct net_device *dev, | |||
539 | if (!netif_running(bp->dev)) | 549 | if (!netif_running(bp->dev)) |
540 | return; | 550 | return; |
541 | 551 | ||
552 | /* Disable parity attentions as long as following dump may | ||
553 | * cause false alarms by reading never written registers. We | ||
554 | * will re-enable parity attentions right after the dump. | ||
555 | */ | ||
556 | bnx2x_disable_blocks_parity(bp); | ||
557 | |||
542 | dump_hdr.hdr_size = (sizeof(struct dump_hdr) / 4) - 1; | 558 | dump_hdr.hdr_size = (sizeof(struct dump_hdr) / 4) - 1; |
543 | dump_hdr.dump_sign = dump_sign_all; | 559 | dump_hdr.dump_sign = dump_sign_all; |
544 | dump_hdr.xstorm_waitp = REG_RD(bp, XSTORM_WAITP_ADDR); | 560 | dump_hdr.xstorm_waitp = REG_RD(bp, XSTORM_WAITP_ADDR); |
@@ -580,6 +596,10 @@ static void bnx2x_get_regs(struct net_device *dev, | |||
580 | 596 | ||
581 | bnx2x_read_pages_regs_e2(bp, p); | 597 | bnx2x_read_pages_regs_e2(bp, p); |
582 | } | 598 | } |
599 | /* Re-enable parity attentions */ | ||
600 | bnx2x_clear_blocks_parity(bp); | ||
601 | if (CHIP_PARITY_ENABLED(bp)) | ||
602 | bnx2x_enable_blocks_parity(bp); | ||
583 | } | 603 | } |
584 | 604 | ||
585 | #define PHY_FW_VER_LEN 20 | 605 | #define PHY_FW_VER_LEN 20 |