diff options
Diffstat (limited to 'drivers/net/bnx2x/bnx2x_link.c')
-rw-r--r-- | drivers/net/bnx2x/bnx2x_link.c | 137 |
1 files changed, 10 insertions, 127 deletions
diff --git a/drivers/net/bnx2x/bnx2x_link.c b/drivers/net/bnx2x/bnx2x_link.c index 3e99bf9c42b9..2326774df843 100644 --- a/drivers/net/bnx2x/bnx2x_link.c +++ b/drivers/net/bnx2x/bnx2x_link.c | |||
@@ -181,6 +181,12 @@ | |||
181 | (_bank + (_addr & 0xf)), \ | 181 | (_bank + (_addr & 0xf)), \ |
182 | _val) | 182 | _val) |
183 | 183 | ||
184 | static u8 bnx2x_cl45_read(struct bnx2x *bp, struct bnx2x_phy *phy, | ||
185 | u8 devad, u16 reg, u16 *ret_val); | ||
186 | |||
187 | static u8 bnx2x_cl45_write(struct bnx2x *bp, struct bnx2x_phy *phy, | ||
188 | u8 devad, u16 reg, u16 val); | ||
189 | |||
184 | static u32 bnx2x_bits_en(struct bnx2x *bp, u32 reg, u32 bits) | 190 | static u32 bnx2x_bits_en(struct bnx2x *bp, u32 reg, u32 bits) |
185 | { | 191 | { |
186 | u32 val = REG_RD(bp, reg); | 192 | u32 val = REG_RD(bp, reg); |
@@ -594,7 +600,7 @@ static u8 bnx2x_bmac2_enable(struct link_params *params, | |||
594 | return 0; | 600 | return 0; |
595 | } | 601 | } |
596 | 602 | ||
597 | u8 bnx2x_bmac_enable(struct link_params *params, | 603 | static u8 bnx2x_bmac_enable(struct link_params *params, |
598 | struct link_vars *vars, | 604 | struct link_vars *vars, |
599 | u8 is_lb) | 605 | u8 is_lb) |
600 | { | 606 | { |
@@ -2537,122 +2543,6 @@ static void bnx2x_set_xgxs_loopback(struct bnx2x_phy *phy, | |||
2537 | } | 2543 | } |
2538 | } | 2544 | } |
2539 | 2545 | ||
2540 | /* | ||
2541 | *------------------------------------------------------------------------ | ||
2542 | * bnx2x_override_led_value - | ||
2543 | * | ||
2544 | * Override the led value of the requested led | ||
2545 | * | ||
2546 | *------------------------------------------------------------------------ | ||
2547 | */ | ||
2548 | u8 bnx2x_override_led_value(struct bnx2x *bp, u8 port, | ||
2549 | u32 led_idx, u32 value) | ||
2550 | { | ||
2551 | u32 reg_val; | ||
2552 | |||
2553 | /* If port 0 then use EMAC0, else use EMAC1*/ | ||
2554 | u32 emac_base = (port) ? GRCBASE_EMAC1 : GRCBASE_EMAC0; | ||
2555 | |||
2556 | DP(NETIF_MSG_LINK, | ||
2557 | "bnx2x_override_led_value() port %x led_idx %d value %d\n", | ||
2558 | port, led_idx, value); | ||
2559 | |||
2560 | switch (led_idx) { | ||
2561 | case 0: /* 10MB led */ | ||
2562 | /* Read the current value of the LED register in | ||
2563 | the EMAC block */ | ||
2564 | reg_val = REG_RD(bp, emac_base + EMAC_REG_EMAC_LED); | ||
2565 | /* Set the OVERRIDE bit to 1 */ | ||
2566 | reg_val |= EMAC_LED_OVERRIDE; | ||
2567 | /* If value is 1, set the 10M_OVERRIDE bit, | ||
2568 | otherwise reset it.*/ | ||
2569 | reg_val = (value == 1) ? (reg_val | EMAC_LED_10MB_OVERRIDE) : | ||
2570 | (reg_val & ~EMAC_LED_10MB_OVERRIDE); | ||
2571 | REG_WR(bp, emac_base + EMAC_REG_EMAC_LED, reg_val); | ||
2572 | break; | ||
2573 | case 1: /*100MB led */ | ||
2574 | /*Read the current value of the LED register in | ||
2575 | the EMAC block */ | ||
2576 | reg_val = REG_RD(bp, emac_base + EMAC_REG_EMAC_LED); | ||
2577 | /* Set the OVERRIDE bit to 1 */ | ||
2578 | reg_val |= EMAC_LED_OVERRIDE; | ||
2579 | /* If value is 1, set the 100M_OVERRIDE bit, | ||
2580 | otherwise reset it.*/ | ||
2581 | reg_val = (value == 1) ? (reg_val | EMAC_LED_100MB_OVERRIDE) : | ||
2582 | (reg_val & ~EMAC_LED_100MB_OVERRIDE); | ||
2583 | REG_WR(bp, emac_base + EMAC_REG_EMAC_LED, reg_val); | ||
2584 | break; | ||
2585 | case 2: /* 1000MB led */ | ||
2586 | /* Read the current value of the LED register in the | ||
2587 | EMAC block */ | ||
2588 | reg_val = REG_RD(bp, emac_base + EMAC_REG_EMAC_LED); | ||
2589 | /* Set the OVERRIDE bit to 1 */ | ||
2590 | reg_val |= EMAC_LED_OVERRIDE; | ||
2591 | /* If value is 1, set the 1000M_OVERRIDE bit, otherwise | ||
2592 | reset it. */ | ||
2593 | reg_val = (value == 1) ? (reg_val | EMAC_LED_1000MB_OVERRIDE) : | ||
2594 | (reg_val & ~EMAC_LED_1000MB_OVERRIDE); | ||
2595 | REG_WR(bp, emac_base + EMAC_REG_EMAC_LED, reg_val); | ||
2596 | break; | ||
2597 | case 3: /* 2500MB led */ | ||
2598 | /* Read the current value of the LED register in the | ||
2599 | EMAC block*/ | ||
2600 | reg_val = REG_RD(bp, emac_base + EMAC_REG_EMAC_LED); | ||
2601 | /* Set the OVERRIDE bit to 1 */ | ||
2602 | reg_val |= EMAC_LED_OVERRIDE; | ||
2603 | /* If value is 1, set the 2500M_OVERRIDE bit, otherwise | ||
2604 | reset it.*/ | ||
2605 | reg_val = (value == 1) ? (reg_val | EMAC_LED_2500MB_OVERRIDE) : | ||
2606 | (reg_val & ~EMAC_LED_2500MB_OVERRIDE); | ||
2607 | REG_WR(bp, emac_base + EMAC_REG_EMAC_LED, reg_val); | ||
2608 | break; | ||
2609 | case 4: /*10G led */ | ||
2610 | if (port == 0) { | ||
2611 | REG_WR(bp, NIG_REG_LED_10G_P0, | ||
2612 | value); | ||
2613 | } else { | ||
2614 | REG_WR(bp, NIG_REG_LED_10G_P1, | ||
2615 | value); | ||
2616 | } | ||
2617 | break; | ||
2618 | case 5: /* TRAFFIC led */ | ||
2619 | /* Find if the traffic control is via BMAC or EMAC */ | ||
2620 | if (port == 0) | ||
2621 | reg_val = REG_RD(bp, NIG_REG_NIG_EMAC0_EN); | ||
2622 | else | ||
2623 | reg_val = REG_RD(bp, NIG_REG_NIG_EMAC1_EN); | ||
2624 | |||
2625 | /* Override the traffic led in the EMAC:*/ | ||
2626 | if (reg_val == 1) { | ||
2627 | /* Read the current value of the LED register in | ||
2628 | the EMAC block */ | ||
2629 | reg_val = REG_RD(bp, emac_base + | ||
2630 | EMAC_REG_EMAC_LED); | ||
2631 | /* Set the TRAFFIC_OVERRIDE bit to 1 */ | ||
2632 | reg_val |= EMAC_LED_OVERRIDE; | ||
2633 | /* If value is 1, set the TRAFFIC bit, otherwise | ||
2634 | reset it.*/ | ||
2635 | reg_val = (value == 1) ? (reg_val | EMAC_LED_TRAFFIC) : | ||
2636 | (reg_val & ~EMAC_LED_TRAFFIC); | ||
2637 | REG_WR(bp, emac_base + EMAC_REG_EMAC_LED, reg_val); | ||
2638 | } else { /* Override the traffic led in the BMAC: */ | ||
2639 | REG_WR(bp, NIG_REG_LED_CONTROL_OVERRIDE_TRAFFIC_P0 | ||
2640 | + port*4, 1); | ||
2641 | REG_WR(bp, NIG_REG_LED_CONTROL_TRAFFIC_P0 + port*4, | ||
2642 | value); | ||
2643 | } | ||
2644 | break; | ||
2645 | default: | ||
2646 | DP(NETIF_MSG_LINK, | ||
2647 | "bnx2x_override_led_value() unknown led index %d " | ||
2648 | "(should be 0-5)\n", led_idx); | ||
2649 | return -EINVAL; | ||
2650 | } | ||
2651 | |||
2652 | return 0; | ||
2653 | } | ||
2654 | |||
2655 | |||
2656 | u8 bnx2x_set_led(struct link_params *params, | 2546 | u8 bnx2x_set_led(struct link_params *params, |
2657 | struct link_vars *vars, u8 mode, u32 speed) | 2547 | struct link_vars *vars, u8 mode, u32 speed) |
2658 | { | 2548 | { |
@@ -4099,9 +3989,9 @@ static u8 bnx2x_8727_read_sfp_module_eeprom(struct bnx2x_phy *phy, | |||
4099 | return -EINVAL; | 3989 | return -EINVAL; |
4100 | } | 3990 | } |
4101 | 3991 | ||
4102 | u8 bnx2x_read_sfp_module_eeprom(struct bnx2x_phy *phy, | 3992 | static u8 bnx2x_read_sfp_module_eeprom(struct bnx2x_phy *phy, |
4103 | struct link_params *params, u16 addr, | 3993 | struct link_params *params, u16 addr, |
4104 | u8 byte_cnt, u8 *o_buf) | 3994 | u8 byte_cnt, u8 *o_buf) |
4105 | { | 3995 | { |
4106 | if (phy->type == PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8726) | 3996 | if (phy->type == PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8726) |
4107 | return bnx2x_8726_read_sfp_module_eeprom(phy, params, addr, | 3997 | return bnx2x_8726_read_sfp_module_eeprom(phy, params, addr, |
@@ -6819,13 +6709,6 @@ u8 bnx2x_phy_probe(struct link_params *params) | |||
6819 | return 0; | 6709 | return 0; |
6820 | } | 6710 | } |
6821 | 6711 | ||
6822 | u32 bnx2x_supported_attr(struct link_params *params, u8 phy_idx) | ||
6823 | { | ||
6824 | if (phy_idx < params->num_phys) | ||
6825 | return params->phy[phy_idx].supported; | ||
6826 | return 0; | ||
6827 | } | ||
6828 | |||
6829 | static void set_phy_vars(struct link_params *params) | 6712 | static void set_phy_vars(struct link_params *params) |
6830 | { | 6713 | { |
6831 | struct bnx2x *bp = params->bp; | 6714 | struct bnx2x *bp = params->bp; |