diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/bnx2x.c | 165 | ||||
-rw-r--r-- | drivers/net/bnx2x.h | 5 |
2 files changed, 92 insertions, 78 deletions
diff --git a/drivers/net/bnx2x.c b/drivers/net/bnx2x.c index 5cd785064ba3..103d3e0f24ba 100644 --- a/drivers/net/bnx2x.c +++ b/drivers/net/bnx2x.c | |||
@@ -298,8 +298,7 @@ static void bnx2x_read_dmae(struct bnx2x *bp, u32 src_addr, u32 len32) | |||
298 | 298 | ||
299 | static int bnx2x_mc_assert(struct bnx2x *bp) | 299 | static int bnx2x_mc_assert(struct bnx2x *bp) |
300 | { | 300 | { |
301 | int i, j; | 301 | int i, j, rc = 0; |
302 | int rc = 0; | ||
303 | char last_idx; | 302 | char last_idx; |
304 | const char storm[] = {"XTCU"}; | 303 | const char storm[] = {"XTCU"}; |
305 | const u32 intmem_base[] = { | 304 | const u32 intmem_base[] = { |
@@ -313,8 +312,9 @@ static int bnx2x_mc_assert(struct bnx2x *bp) | |||
313 | for (i = 0; i < 4; i++) { | 312 | for (i = 0; i < 4; i++) { |
314 | last_idx = REG_RD8(bp, XSTORM_ASSERT_LIST_INDEX_OFFSET + | 313 | last_idx = REG_RD8(bp, XSTORM_ASSERT_LIST_INDEX_OFFSET + |
315 | intmem_base[i]); | 314 | intmem_base[i]); |
316 | BNX2X_ERR("DATA %cSTORM_ASSERT_LIST_INDEX 0x%x\n", | 315 | if (last_idx) |
317 | storm[i], last_idx); | 316 | BNX2X_LOG("DATA %cSTORM_ASSERT_LIST_INDEX 0x%x\n", |
317 | storm[i], last_idx); | ||
318 | 318 | ||
319 | /* print the asserts */ | 319 | /* print the asserts */ |
320 | for (j = 0; j < STROM_ASSERT_ARRAY_SIZE; j++) { | 320 | for (j = 0; j < STROM_ASSERT_ARRAY_SIZE; j++) { |
@@ -330,7 +330,7 @@ static int bnx2x_mc_assert(struct bnx2x *bp) | |||
330 | intmem_base[i]); | 330 | intmem_base[i]); |
331 | 331 | ||
332 | if (row0 != COMMON_ASM_INVALID_ASSERT_OPCODE) { | 332 | if (row0 != COMMON_ASM_INVALID_ASSERT_OPCODE) { |
333 | BNX2X_ERR("DATA %cSTORM_ASSERT_INDEX 0x%x =" | 333 | BNX2X_LOG("DATA %cSTORM_ASSERT_INDEX 0x%x =" |
334 | " 0x%08x 0x%08x 0x%08x 0x%08x\n", | 334 | " 0x%08x 0x%08x 0x%08x 0x%08x\n", |
335 | storm[i], j, row3, row2, row1, row0); | 335 | storm[i], j, row3, row2, row1, row0); |
336 | rc++; | 336 | rc++; |
@@ -349,21 +349,22 @@ static void bnx2x_fw_dump(struct bnx2x *bp) | |||
349 | int word; | 349 | int word; |
350 | 350 | ||
351 | mark = REG_RD(bp, MCP_REG_MCPR_SCRATCH + 0xf104); | 351 | mark = REG_RD(bp, MCP_REG_MCPR_SCRATCH + 0xf104); |
352 | printk(KERN_ERR PFX "begin fw dump (mark 0x%x)\n", mark); | 352 | mark = ((mark + 0x3) & ~0x3); |
353 | printk(KERN_ERR PFX "begin fw dump (mark 0x%x)\n" KERN_ERR, mark); | ||
353 | 354 | ||
354 | for (offset = mark - 0x08000000; offset <= 0xF900; offset += 0x8*4) { | 355 | for (offset = mark - 0x08000000; offset <= 0xF900; offset += 0x8*4) { |
355 | for (word = 0; word < 8; word++) | 356 | for (word = 0; word < 8; word++) |
356 | data[word] = htonl(REG_RD(bp, MCP_REG_MCPR_SCRATCH + | 357 | data[word] = htonl(REG_RD(bp, MCP_REG_MCPR_SCRATCH + |
357 | offset + 4*word)); | 358 | offset + 4*word)); |
358 | data[8] = 0x0; | 359 | data[8] = 0x0; |
359 | printk(KERN_ERR PFX "%s", (char *)data); | 360 | printk(KERN_CONT "%s", (char *)data); |
360 | } | 361 | } |
361 | for (offset = 0xF108; offset <= mark - 0x08000000; offset += 0x8*4) { | 362 | for (offset = 0xF108; offset <= mark - 0x08000000; offset += 0x8*4) { |
362 | for (word = 0; word < 8; word++) | 363 | for (word = 0; word < 8; word++) |
363 | data[word] = htonl(REG_RD(bp, MCP_REG_MCPR_SCRATCH + | 364 | data[word] = htonl(REG_RD(bp, MCP_REG_MCPR_SCRATCH + |
364 | offset + 4*word)); | 365 | offset + 4*word)); |
365 | data[8] = 0x0; | 366 | data[8] = 0x0; |
366 | printk(KERN_ERR PFX "%s", (char *)data); | 367 | printk(KERN_CONT "%s", (char *)data); |
367 | } | 368 | } |
368 | printk("\n" KERN_ERR PFX "end of fw dump\n"); | 369 | printk("\n" KERN_ERR PFX "end of fw dump\n"); |
369 | } | 370 | } |
@@ -428,10 +429,10 @@ static void bnx2x_panic_dump(struct bnx2x *bp) | |||
428 | } | 429 | } |
429 | } | 430 | } |
430 | 431 | ||
431 | BNX2X_ERR("def_c_idx(%u) def_u_idx(%u) def_t_idx(%u)" | 432 | BNX2X_ERR("def_c_idx(%u) def_u_idx(%u) def_x_idx(%u)" |
432 | " def_x_idx(%u) def_att_idx(%u) attn_state(%u)" | 433 | " def_t_idx(%u) def_att_idx(%u) attn_state(%u)" |
433 | " spq_prod_idx(%u)\n", | 434 | " spq_prod_idx(%u)\n", |
434 | bp->def_c_idx, bp->def_u_idx, bp->def_t_idx, bp->def_x_idx, | 435 | bp->def_c_idx, bp->def_u_idx, bp->def_x_idx, bp->def_t_idx, |
435 | bp->def_att_idx, bp->attn_state, bp->spq_prod_idx); | 436 | bp->def_att_idx, bp->attn_state, bp->spq_prod_idx); |
436 | 437 | ||
437 | 438 | ||
@@ -789,20 +790,20 @@ static void bnx2x_sp_event(struct bnx2x_fastpath *fp, | |||
789 | fp->state = BNX2X_FP_STATE_HALTED; | 790 | fp->state = BNX2X_FP_STATE_HALTED; |
790 | break; | 791 | break; |
791 | 792 | ||
792 | case (RAMROD_CMD_ID_ETH_PORT_DEL | BNX2X_STATE_CLOSING_WAIT4_DELETE): | ||
793 | DP(NETIF_MSG_IFDOWN, "got delete ramrod\n"); | ||
794 | bp->state = BNX2X_STATE_CLOSING_WAIT4_UNLOAD; | ||
795 | break; | ||
796 | |||
797 | case (RAMROD_CMD_ID_ETH_CFC_DEL | BNX2X_STATE_CLOSING_WAIT4_HALT): | 793 | case (RAMROD_CMD_ID_ETH_CFC_DEL | BNX2X_STATE_CLOSING_WAIT4_HALT): |
798 | DP(NETIF_MSG_IFDOWN, "got delete ramrod for MULTI[%d]\n", cid); | 794 | DP(NETIF_MSG_IFDOWN, "got delete ramrod for MULTI[%d]\n", |
799 | bnx2x_fp(bp, cid, state) = BNX2X_FP_STATE_DELETED; | 795 | cid); |
796 | bnx2x_fp(bp, cid, state) = BNX2X_FP_STATE_CLOSED; | ||
800 | break; | 797 | break; |
801 | 798 | ||
802 | case (RAMROD_CMD_ID_ETH_SET_MAC | BNX2X_STATE_OPEN): | 799 | case (RAMROD_CMD_ID_ETH_SET_MAC | BNX2X_STATE_OPEN): |
803 | DP(NETIF_MSG_IFUP, "got set mac ramrod\n"); | 800 | DP(NETIF_MSG_IFUP, "got set mac ramrod\n"); |
804 | break; | 801 | break; |
805 | 802 | ||
803 | case (RAMROD_CMD_ID_ETH_SET_MAC | BNX2X_STATE_CLOSING_WAIT4_HALT): | ||
804 | DP(NETIF_MSG_IFUP, "got (un)set mac ramrod\n"); | ||
805 | break; | ||
806 | |||
806 | default: | 807 | default: |
807 | BNX2X_ERR("unexpected ramrod (%d) state is %x\n", | 808 | BNX2X_ERR("unexpected ramrod (%d) state is %x\n", |
808 | command, bp->state); | 809 | command, bp->state); |
@@ -5236,6 +5237,9 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5236 | atten_status_block); | 5237 | atten_status_block); |
5237 | def_sb->atten_status_block.status_block_id = id; | 5238 | def_sb->atten_status_block.status_block_id = id; |
5238 | 5239 | ||
5240 | bp->def_att_idx = 0; | ||
5241 | bp->attn_state = 0; | ||
5242 | |||
5239 | reg_offset = (port ? MISC_REG_AEU_ENABLE1_FUNC_1_OUT_0 : | 5243 | reg_offset = (port ? MISC_REG_AEU_ENABLE1_FUNC_1_OUT_0 : |
5240 | MISC_REG_AEU_ENABLE1_FUNC_0_OUT_0); | 5244 | MISC_REG_AEU_ENABLE1_FUNC_0_OUT_0); |
5241 | 5245 | ||
@@ -5270,6 +5274,8 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5270 | u_def_status_block); | 5274 | u_def_status_block); |
5271 | def_sb->u_def_status_block.status_block_id = id; | 5275 | def_sb->u_def_status_block.status_block_id = id; |
5272 | 5276 | ||
5277 | bp->def_u_idx = 0; | ||
5278 | |||
5273 | REG_WR(bp, BAR_USTRORM_INTMEM + | 5279 | REG_WR(bp, BAR_USTRORM_INTMEM + |
5274 | USTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); | 5280 | USTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); |
5275 | REG_WR(bp, BAR_USTRORM_INTMEM + | 5281 | REG_WR(bp, BAR_USTRORM_INTMEM + |
@@ -5287,6 +5293,8 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5287 | c_def_status_block); | 5293 | c_def_status_block); |
5288 | def_sb->c_def_status_block.status_block_id = id; | 5294 | def_sb->c_def_status_block.status_block_id = id; |
5289 | 5295 | ||
5296 | bp->def_c_idx = 0; | ||
5297 | |||
5290 | REG_WR(bp, BAR_CSTRORM_INTMEM + | 5298 | REG_WR(bp, BAR_CSTRORM_INTMEM + |
5291 | CSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); | 5299 | CSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); |
5292 | REG_WR(bp, BAR_CSTRORM_INTMEM + | 5300 | REG_WR(bp, BAR_CSTRORM_INTMEM + |
@@ -5304,6 +5312,8 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5304 | t_def_status_block); | 5312 | t_def_status_block); |
5305 | def_sb->t_def_status_block.status_block_id = id; | 5313 | def_sb->t_def_status_block.status_block_id = id; |
5306 | 5314 | ||
5315 | bp->def_t_idx = 0; | ||
5316 | |||
5307 | REG_WR(bp, BAR_TSTRORM_INTMEM + | 5317 | REG_WR(bp, BAR_TSTRORM_INTMEM + |
5308 | TSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); | 5318 | TSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); |
5309 | REG_WR(bp, BAR_TSTRORM_INTMEM + | 5319 | REG_WR(bp, BAR_TSTRORM_INTMEM + |
@@ -5321,6 +5331,8 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5321 | x_def_status_block); | 5331 | x_def_status_block); |
5322 | def_sb->x_def_status_block.status_block_id = id; | 5332 | def_sb->x_def_status_block.status_block_id = id; |
5323 | 5333 | ||
5334 | bp->def_x_idx = 0; | ||
5335 | |||
5324 | REG_WR(bp, BAR_XSTRORM_INTMEM + | 5336 | REG_WR(bp, BAR_XSTRORM_INTMEM + |
5325 | XSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); | 5337 | XSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(port), U64_LO(section)); |
5326 | REG_WR(bp, BAR_XSTRORM_INTMEM + | 5338 | REG_WR(bp, BAR_XSTRORM_INTMEM + |
@@ -5333,6 +5345,8 @@ static void bnx2x_init_def_sb(struct bnx2x *bp, | |||
5333 | REG_WR16(bp, BAR_XSTRORM_INTMEM + | 5345 | REG_WR16(bp, BAR_XSTRORM_INTMEM + |
5334 | XSTORM_DEF_SB_HC_DISABLE_OFFSET(port, index), 0x1); | 5346 | XSTORM_DEF_SB_HC_DISABLE_OFFSET(port, index), 0x1); |
5335 | 5347 | ||
5348 | bp->stat_pending = 0; | ||
5349 | |||
5336 | bnx2x_ack_sb(bp, id, CSTORM_ID, 0, IGU_INT_ENABLE, 0); | 5350 | bnx2x_ack_sb(bp, id, CSTORM_ID, 0, IGU_INT_ENABLE, 0); |
5337 | } | 5351 | } |
5338 | 5352 | ||
@@ -5476,7 +5490,6 @@ static void bnx2x_init_sp_ring(struct bnx2x *bp) | |||
5476 | 5490 | ||
5477 | bp->spq_left = MAX_SPQ_PENDING; | 5491 | bp->spq_left = MAX_SPQ_PENDING; |
5478 | bp->spq_prod_idx = 0; | 5492 | bp->spq_prod_idx = 0; |
5479 | bp->dsb_sp_prod_idx = 0; | ||
5480 | bp->dsb_sp_prod = BNX2X_SP_DSB_INDEX; | 5493 | bp->dsb_sp_prod = BNX2X_SP_DSB_INDEX; |
5481 | bp->spq_prod_bd = bp->spq; | 5494 | bp->spq_prod_bd = bp->spq; |
5482 | bp->spq_last_bd = bp->spq_prod_bd + MAX_SP_DESC_CNT; | 5495 | bp->spq_last_bd = bp->spq_prod_bd + MAX_SP_DESC_CNT; |
@@ -5553,6 +5566,42 @@ static void bnx2x_init_ind_table(struct bnx2x *bp) | |||
5553 | REG_WR(bp, PRS_REG_A_PRSU_20, 0xf); | 5566 | REG_WR(bp, PRS_REG_A_PRSU_20, 0xf); |
5554 | } | 5567 | } |
5555 | 5568 | ||
5569 | static void bnx2x_set_client_config(struct bnx2x *bp) | ||
5570 | { | ||
5571 | #ifdef BCM_VLAN | ||
5572 | int mode = bp->rx_mode; | ||
5573 | #endif | ||
5574 | int i, port = bp->port; | ||
5575 | struct tstorm_eth_client_config tstorm_client = {0}; | ||
5576 | |||
5577 | tstorm_client.mtu = bp->dev->mtu; | ||
5578 | tstorm_client.statistics_counter_id = 0; | ||
5579 | tstorm_client.config_flags = | ||
5580 | TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE; | ||
5581 | #ifdef BCM_VLAN | ||
5582 | if (mode && bp->vlgrp) { | ||
5583 | tstorm_client.config_flags |= | ||
5584 | TSTORM_ETH_CLIENT_CONFIG_VLAN_REMOVAL_ENABLE; | ||
5585 | DP(NETIF_MSG_IFUP, "vlan removal enabled\n"); | ||
5586 | } | ||
5587 | #endif | ||
5588 | if (mode != BNX2X_RX_MODE_PROMISC) | ||
5589 | tstorm_client.drop_flags = | ||
5590 | TSTORM_ETH_CLIENT_CONFIG_DROP_MAC_ERR; | ||
5591 | |||
5592 | for_each_queue(bp, i) { | ||
5593 | REG_WR(bp, BAR_TSTRORM_INTMEM + | ||
5594 | TSTORM_CLIENT_CONFIG_OFFSET(port, i), | ||
5595 | ((u32 *)&tstorm_client)[0]); | ||
5596 | REG_WR(bp, BAR_TSTRORM_INTMEM + | ||
5597 | TSTORM_CLIENT_CONFIG_OFFSET(port, i) + 4, | ||
5598 | ((u32 *)&tstorm_client)[1]); | ||
5599 | } | ||
5600 | |||
5601 | /* DP(NETIF_MSG_IFUP, "tstorm_client: 0x%08x 0x%08x\n", | ||
5602 | ((u32 *)&tstorm_client)[0], ((u32 *)&tstorm_client)[1]); */ | ||
5603 | } | ||
5604 | |||
5556 | static void bnx2x_set_storm_rx_mode(struct bnx2x *bp) | 5605 | static void bnx2x_set_storm_rx_mode(struct bnx2x *bp) |
5557 | { | 5606 | { |
5558 | int mode = bp->rx_mode; | 5607 | int mode = bp->rx_mode; |
@@ -5592,41 +5641,9 @@ static void bnx2x_set_storm_rx_mode(struct bnx2x *bp) | |||
5592 | /* DP(NETIF_MSG_IFUP, "tstorm_mac_filter[%d]: 0x%08x\n", i, | 5641 | /* DP(NETIF_MSG_IFUP, "tstorm_mac_filter[%d]: 0x%08x\n", i, |
5593 | ((u32 *)&tstorm_mac_filter)[i]); */ | 5642 | ((u32 *)&tstorm_mac_filter)[i]); */ |
5594 | } | 5643 | } |
5595 | } | ||
5596 | 5644 | ||
5597 | static void bnx2x_set_client_config(struct bnx2x *bp, int client_id) | 5645 | if (mode != BNX2X_RX_MODE_NONE) |
5598 | { | 5646 | bnx2x_set_client_config(bp); |
5599 | #ifdef BCM_VLAN | ||
5600 | int mode = bp->rx_mode; | ||
5601 | #endif | ||
5602 | int port = bp->port; | ||
5603 | struct tstorm_eth_client_config tstorm_client = {0}; | ||
5604 | |||
5605 | tstorm_client.mtu = bp->dev->mtu; | ||
5606 | tstorm_client.statistics_counter_id = 0; | ||
5607 | tstorm_client.config_flags = | ||
5608 | TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE; | ||
5609 | #ifdef BCM_VLAN | ||
5610 | if (mode && bp->vlgrp) { | ||
5611 | tstorm_client.config_flags |= | ||
5612 | TSTORM_ETH_CLIENT_CONFIG_VLAN_REMOVAL_ENABLE; | ||
5613 | DP(NETIF_MSG_IFUP, "vlan removal enabled\n"); | ||
5614 | } | ||
5615 | #endif | ||
5616 | tstorm_client.drop_flags = (TSTORM_ETH_CLIENT_CONFIG_DROP_IP_CS_ERR | | ||
5617 | TSTORM_ETH_CLIENT_CONFIG_DROP_TCP_CS_ERR | | ||
5618 | TSTORM_ETH_CLIENT_CONFIG_DROP_UDP_CS_ERR | | ||
5619 | TSTORM_ETH_CLIENT_CONFIG_DROP_MAC_ERR); | ||
5620 | |||
5621 | REG_WR(bp, BAR_TSTRORM_INTMEM + | ||
5622 | TSTORM_CLIENT_CONFIG_OFFSET(port, client_id), | ||
5623 | ((u32 *)&tstorm_client)[0]); | ||
5624 | REG_WR(bp, BAR_TSTRORM_INTMEM + | ||
5625 | TSTORM_CLIENT_CONFIG_OFFSET(port, client_id) + 4, | ||
5626 | ((u32 *)&tstorm_client)[1]); | ||
5627 | |||
5628 | /* DP(NETIF_MSG_IFUP, "tstorm_client: 0x%08x 0x%08x\n", | ||
5629 | ((u32 *)&tstorm_client)[0], ((u32 *)&tstorm_client)[1]); */ | ||
5630 | } | 5647 | } |
5631 | 5648 | ||
5632 | static void bnx2x_init_internal(struct bnx2x *bp) | 5649 | static void bnx2x_init_internal(struct bnx2x *bp) |
@@ -5634,7 +5651,6 @@ static void bnx2x_init_internal(struct bnx2x *bp) | |||
5634 | int port = bp->port; | 5651 | int port = bp->port; |
5635 | struct tstorm_eth_function_common_config tstorm_config = {0}; | 5652 | struct tstorm_eth_function_common_config tstorm_config = {0}; |
5636 | struct stats_indication_flags stats_flags = {0}; | 5653 | struct stats_indication_flags stats_flags = {0}; |
5637 | int i; | ||
5638 | 5654 | ||
5639 | if (is_multi(bp)) { | 5655 | if (is_multi(bp)) { |
5640 | tstorm_config.config_flags = MULTI_FLAGS; | 5656 | tstorm_config.config_flags = MULTI_FLAGS; |
@@ -5651,10 +5667,6 @@ static void bnx2x_init_internal(struct bnx2x *bp) | |||
5651 | bp->rx_mode = BNX2X_RX_MODE_NONE; /* no rx until link is up */ | 5667 | bp->rx_mode = BNX2X_RX_MODE_NONE; /* no rx until link is up */ |
5652 | bnx2x_set_storm_rx_mode(bp); | 5668 | bnx2x_set_storm_rx_mode(bp); |
5653 | 5669 | ||
5654 | for_each_queue(bp, i) | ||
5655 | bnx2x_set_client_config(bp, i); | ||
5656 | |||
5657 | |||
5658 | stats_flags.collect_eth = cpu_to_le32(1); | 5670 | stats_flags.collect_eth = cpu_to_le32(1); |
5659 | 5671 | ||
5660 | REG_WR(bp, BAR_XSTRORM_INTMEM + XSTORM_STATS_FLAGS_OFFSET(port), | 5672 | REG_WR(bp, BAR_XSTRORM_INTMEM + XSTORM_STATS_FLAGS_OFFSET(port), |
@@ -6961,7 +6973,7 @@ static int bnx2x_wait_ramrod(struct bnx2x *bp, int state, int idx, | |||
6961 | 6973 | ||
6962 | mb(); /* state is changed by bnx2x_sp_event()*/ | 6974 | mb(); /* state is changed by bnx2x_sp_event()*/ |
6963 | 6975 | ||
6964 | if (*state_p != state) | 6976 | if (*state_p == state) |
6965 | return 0; | 6977 | return 0; |
6966 | 6978 | ||
6967 | timeout--; | 6979 | timeout--; |
@@ -6970,9 +6982,10 @@ static int bnx2x_wait_ramrod(struct bnx2x *bp, int state, int idx, | |||
6970 | } | 6982 | } |
6971 | 6983 | ||
6972 | /* timeout! */ | 6984 | /* timeout! */ |
6973 | BNX2X_ERR("timeout waiting for ramrod %d on %d\n", state, idx); | 6985 | BNX2X_ERR("timeout %s for state %x on IDX [%d]\n", |
6974 | return -EBUSY; | 6986 | poll ? "polling" : "waiting", state, idx); |
6975 | 6987 | ||
6988 | return -EBUSY; | ||
6976 | } | 6989 | } |
6977 | 6990 | ||
6978 | static int bnx2x_setup_leading(struct bnx2x *bp) | 6991 | static int bnx2x_setup_leading(struct bnx2x *bp) |
@@ -7239,7 +7252,7 @@ static int bnx2x_stop_multi(struct bnx2x *bp, int index) | |||
7239 | /* delete cfc entry */ | 7252 | /* delete cfc entry */ |
7240 | bnx2x_sp_post(bp, RAMROD_CMD_ID_ETH_CFC_DEL, index, 0, 0, 1); | 7253 | bnx2x_sp_post(bp, RAMROD_CMD_ID_ETH_CFC_DEL, index, 0, 0, 1); |
7241 | 7254 | ||
7242 | return bnx2x_wait_ramrod(bp, BNX2X_FP_STATE_DELETED, index, | 7255 | return bnx2x_wait_ramrod(bp, BNX2X_FP_STATE_CLOSED, index, |
7243 | &(bp->fp[index].state), 1); | 7256 | &(bp->fp[index].state), 1); |
7244 | 7257 | ||
7245 | } | 7258 | } |
@@ -7247,7 +7260,7 @@ static int bnx2x_stop_multi(struct bnx2x *bp, int index) | |||
7247 | 7260 | ||
7248 | static void bnx2x_stop_leading(struct bnx2x *bp) | 7261 | static void bnx2x_stop_leading(struct bnx2x *bp) |
7249 | { | 7262 | { |
7250 | 7263 | u16 dsb_sp_prod_idx; | |
7251 | /* if the other port is handling traffic, | 7264 | /* if the other port is handling traffic, |
7252 | this can take a lot of time */ | 7265 | this can take a lot of time */ |
7253 | int timeout = 500; | 7266 | int timeout = 500; |
@@ -7262,23 +7275,29 @@ static void bnx2x_stop_leading(struct bnx2x *bp) | |||
7262 | &(bp->fp[0].state), 1)) | 7275 | &(bp->fp[0].state), 1)) |
7263 | return; | 7276 | return; |
7264 | 7277 | ||
7265 | bp->dsb_sp_prod_idx = *bp->dsb_sp_prod; | 7278 | dsb_sp_prod_idx = *bp->dsb_sp_prod; |
7266 | 7279 | ||
7267 | /* Send CFC_DELETE ramrod */ | 7280 | /* Send CFC_DELETE ramrod */ |
7268 | bnx2x_sp_post(bp, RAMROD_CMD_ID_ETH_PORT_DEL, 0, 0, 0, 1); | 7281 | bnx2x_sp_post(bp, RAMROD_CMD_ID_ETH_PORT_DEL, 0, 0, 0, 1); |
7269 | 7282 | ||
7270 | /* | 7283 | /* Wait for completion to arrive on default status block |
7271 | Wait for completion. | ||
7272 | we are going to reset the chip anyway | 7284 | we are going to reset the chip anyway |
7273 | so there is not much to do if this times out | 7285 | so there is not much to do if this times out |
7274 | */ | 7286 | */ |
7275 | while (bp->dsb_sp_prod_idx == *bp->dsb_sp_prod && timeout) { | 7287 | while ((dsb_sp_prod_idx == *bp->dsb_sp_prod) && timeout) { |
7276 | timeout--; | 7288 | timeout--; |
7277 | msleep(1); | 7289 | msleep(1); |
7278 | } | 7290 | } |
7279 | 7291 | if (!timeout) { | |
7292 | DP(NETIF_MSG_IFDOWN, "timeout polling for completion " | ||
7293 | "dsb_sp_prod 0x%x != dsb_sp_prod_idx 0x%x\n", | ||
7294 | *bp->dsb_sp_prod, dsb_sp_prod_idx); | ||
7295 | } | ||
7296 | bp->state = BNX2X_STATE_CLOSING_WAIT4_UNLOAD; | ||
7297 | bp->fp[0].state = BNX2X_FP_STATE_CLOSED; | ||
7280 | } | 7298 | } |
7281 | 7299 | ||
7300 | |||
7282 | static int bnx2x_nic_unload(struct bnx2x *bp, int fre_irq) | 7301 | static int bnx2x_nic_unload(struct bnx2x *bp, int fre_irq) |
7283 | { | 7302 | { |
7284 | u32 reset_code = 0; | 7303 | u32 reset_code = 0; |
@@ -8968,9 +8987,7 @@ static int bnx2x_set_power_state(struct bnx2x *bp, pci_power_t state) | |||
8968 | * net_device service functions | 8987 | * net_device service functions |
8969 | */ | 8988 | */ |
8970 | 8989 | ||
8971 | /* Called with rtnl_lock from vlan functions and also netif_tx_lock | 8990 | /* called with netif_tx_lock from set_multicast */ |
8972 | * from set_multicast. | ||
8973 | */ | ||
8974 | static void bnx2x_set_rx_mode(struct net_device *dev) | 8991 | static void bnx2x_set_rx_mode(struct net_device *dev) |
8975 | { | 8992 | { |
8976 | struct bnx2x *bp = netdev_priv(dev); | 8993 | struct bnx2x *bp = netdev_priv(dev); |
@@ -9496,7 +9513,7 @@ static void bnx2x_vlan_rx_register(struct net_device *dev, | |||
9496 | 9513 | ||
9497 | bp->vlgrp = vlgrp; | 9514 | bp->vlgrp = vlgrp; |
9498 | if (netif_running(dev)) | 9515 | if (netif_running(dev)) |
9499 | bnx2x_set_rx_mode(dev); | 9516 | bnx2x_set_client_config(bp); |
9500 | } | 9517 | } |
9501 | #endif | 9518 | #endif |
9502 | 9519 | ||
diff --git a/drivers/net/bnx2x.h b/drivers/net/bnx2x.h index dc423e58dad8..d0e5ab1af444 100644 --- a/drivers/net/bnx2x.h +++ b/drivers/net/bnx2x.h | |||
@@ -1,6 +1,6 @@ | |||
1 | /* bnx2x.h: Broadcom Everest network driver. | 1 | /* bnx2x.h: Broadcom Everest network driver. |
2 | * | 2 | * |
3 | * Copyright (c) 2007 Broadcom Corporation | 3 | * Copyright (c) 2007-2008 Broadcom Corporation |
4 | * | 4 | * |
5 | * This program is free software; you can redistribute it and/or modify | 5 | * This program is free software; you can redistribute it and/or modify |
6 | * it under the terms of the GNU General Public License as published by | 6 | * it under the terms of the GNU General Public License as published by |
@@ -431,8 +431,6 @@ struct bnx2x_fastpath { | |||
431 | #define BNX2X_FP_STATE_OPEN 0xa0000 | 431 | #define BNX2X_FP_STATE_OPEN 0xa0000 |
432 | #define BNX2X_FP_STATE_HALTING 0xb0000 | 432 | #define BNX2X_FP_STATE_HALTING 0xb0000 |
433 | #define BNX2X_FP_STATE_HALTED 0xc0000 | 433 | #define BNX2X_FP_STATE_HALTED 0xc0000 |
434 | #define BNX2X_FP_STATE_DELETED 0xd0000 | ||
435 | #define BNX2X_FP_STATE_CLOSE_IRQ 0xe0000 | ||
436 | 434 | ||
437 | int index; | 435 | int index; |
438 | 436 | ||
@@ -513,7 +511,6 @@ struct bnx2x { | |||
513 | struct eth_spe *spq; | 511 | struct eth_spe *spq; |
514 | dma_addr_t spq_mapping; | 512 | dma_addr_t spq_mapping; |
515 | u16 spq_prod_idx; | 513 | u16 spq_prod_idx; |
516 | u16 dsb_sp_prod_idx; | ||
517 | struct eth_spe *spq_prod_bd; | 514 | struct eth_spe *spq_prod_bd; |
518 | struct eth_spe *spq_last_bd; | 515 | struct eth_spe *spq_last_bd; |
519 | u16 *dsb_sp_prod; | 516 | u16 *dsb_sp_prod; |