diff options
Diffstat (limited to 'drivers/net/e1000e/phy.c')
-rw-r--r-- | drivers/net/e1000e/phy.c | 108 |
1 files changed, 58 insertions, 50 deletions
diff --git a/drivers/net/e1000e/phy.c b/drivers/net/e1000e/phy.c index 3d3dc0c82355..484774c13c21 100644 --- a/drivers/net/e1000e/phy.c +++ b/drivers/net/e1000e/phy.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /******************************************************************************* | 1 | /******************************************************************************* |
2 | 2 | ||
3 | Intel PRO/1000 Linux driver | 3 | Intel PRO/1000 Linux driver |
4 | Copyright(c) 1999 - 2010 Intel Corporation. | 4 | Copyright(c) 1999 - 2011 Intel Corporation. |
5 | 5 | ||
6 | This program is free software; you can redistribute it and/or modify it | 6 | This program is free software; you can redistribute it and/or modify it |
7 | under the terms and conditions of the GNU General Public License, | 7 | under the terms and conditions of the GNU General Public License, |
@@ -42,20 +42,20 @@ static s32 e1000_access_phy_debug_regs_hv(struct e1000_hw *hw, u32 offset, | |||
42 | u16 *data, bool read); | 42 | u16 *data, bool read); |
43 | 43 | ||
44 | /* Cable length tables */ | 44 | /* Cable length tables */ |
45 | static const u16 e1000_m88_cable_length_table[] = | 45 | static const u16 e1000_m88_cable_length_table[] = { |
46 | { 0, 50, 80, 110, 140, 140, E1000_CABLE_LENGTH_UNDEFINED }; | 46 | 0, 50, 80, 110, 140, 140, E1000_CABLE_LENGTH_UNDEFINED }; |
47 | #define M88E1000_CABLE_LENGTH_TABLE_SIZE \ | 47 | #define M88E1000_CABLE_LENGTH_TABLE_SIZE \ |
48 | ARRAY_SIZE(e1000_m88_cable_length_table) | 48 | ARRAY_SIZE(e1000_m88_cable_length_table) |
49 | 49 | ||
50 | static const u16 e1000_igp_2_cable_length_table[] = | 50 | static const u16 e1000_igp_2_cable_length_table[] = { |
51 | { 0, 0, 0, 0, 0, 0, 0, 0, 3, 5, 8, 11, 13, 16, 18, 21, 0, 0, 0, 3, | 51 | 0, 0, 0, 0, 0, 0, 0, 0, 3, 5, 8, 11, 13, 16, 18, 21, 0, 0, 0, 3, |
52 | 6, 10, 13, 16, 19, 23, 26, 29, 32, 35, 38, 41, 6, 10, 14, 18, 22, | 52 | 6, 10, 13, 16, 19, 23, 26, 29, 32, 35, 38, 41, 6, 10, 14, 18, 22, |
53 | 26, 30, 33, 37, 41, 44, 48, 51, 54, 58, 61, 21, 26, 31, 35, 40, | 53 | 26, 30, 33, 37, 41, 44, 48, 51, 54, 58, 61, 21, 26, 31, 35, 40, |
54 | 44, 49, 53, 57, 61, 65, 68, 72, 75, 79, 82, 40, 45, 51, 56, 61, | 54 | 44, 49, 53, 57, 61, 65, 68, 72, 75, 79, 82, 40, 45, 51, 56, 61, |
55 | 66, 70, 75, 79, 83, 87, 91, 94, 98, 101, 104, 60, 66, 72, 77, 82, | 55 | 66, 70, 75, 79, 83, 87, 91, 94, 98, 101, 104, 60, 66, 72, 77, 82, |
56 | 87, 92, 96, 100, 104, 108, 111, 114, 117, 119, 121, 83, 89, 95, | 56 | 87, 92, 96, 100, 104, 108, 111, 114, 117, 119, 121, 83, 89, 95, |
57 | 100, 105, 109, 113, 116, 119, 122, 124, 104, 109, 114, 118, 121, | 57 | 100, 105, 109, 113, 116, 119, 122, 124, 104, 109, 114, 118, 121, |
58 | 124}; | 58 | 124}; |
59 | #define IGP02E1000_CABLE_LENGTH_TABLE_SIZE \ | 59 | #define IGP02E1000_CABLE_LENGTH_TABLE_SIZE \ |
60 | ARRAY_SIZE(e1000_igp_2_cable_length_table) | 60 | ARRAY_SIZE(e1000_igp_2_cable_length_table) |
61 | 61 | ||
@@ -226,6 +226,13 @@ s32 e1000e_read_phy_reg_mdic(struct e1000_hw *hw, u32 offset, u16 *data) | |||
226 | } | 226 | } |
227 | *data = (u16) mdic; | 227 | *data = (u16) mdic; |
228 | 228 | ||
229 | /* | ||
230 | * Allow some time after each MDIC transaction to avoid | ||
231 | * reading duplicate data in the next MDIC transaction. | ||
232 | */ | ||
233 | if (hw->mac.type == e1000_pch2lan) | ||
234 | udelay(100); | ||
235 | |||
229 | return 0; | 236 | return 0; |
230 | } | 237 | } |
231 | 238 | ||
@@ -279,6 +286,13 @@ s32 e1000e_write_phy_reg_mdic(struct e1000_hw *hw, u32 offset, u16 data) | |||
279 | return -E1000_ERR_PHY; | 286 | return -E1000_ERR_PHY; |
280 | } | 287 | } |
281 | 288 | ||
289 | /* | ||
290 | * Allow some time after each MDIC transaction to avoid | ||
291 | * reading duplicate data in the next MDIC transaction. | ||
292 | */ | ||
293 | if (hw->mac.type == e1000_pch2lan) | ||
294 | udelay(100); | ||
295 | |||
282 | return 0; | 296 | return 0; |
283 | } | 297 | } |
284 | 298 | ||
@@ -623,12 +637,11 @@ s32 e1000e_write_kmrn_reg_locked(struct e1000_hw *hw, u32 offset, u16 data) | |||
623 | **/ | 637 | **/ |
624 | s32 e1000_copper_link_setup_82577(struct e1000_hw *hw) | 638 | s32 e1000_copper_link_setup_82577(struct e1000_hw *hw) |
625 | { | 639 | { |
626 | struct e1000_phy_info *phy = &hw->phy; | ||
627 | s32 ret_val; | 640 | s32 ret_val; |
628 | u16 phy_data; | 641 | u16 phy_data; |
629 | 642 | ||
630 | /* Enable CRS on TX. This must be set for half-duplex operation. */ | 643 | /* Enable CRS on Tx. This must be set for half-duplex operation. */ |
631 | ret_val = phy->ops.read_reg(hw, I82577_CFG_REG, &phy_data); | 644 | ret_val = e1e_rphy(hw, I82577_CFG_REG, &phy_data); |
632 | if (ret_val) | 645 | if (ret_val) |
633 | goto out; | 646 | goto out; |
634 | 647 | ||
@@ -637,7 +650,7 @@ s32 e1000_copper_link_setup_82577(struct e1000_hw *hw) | |||
637 | /* Enable downshift */ | 650 | /* Enable downshift */ |
638 | phy_data |= I82577_CFG_ENABLE_DOWNSHIFT; | 651 | phy_data |= I82577_CFG_ENABLE_DOWNSHIFT; |
639 | 652 | ||
640 | ret_val = phy->ops.write_reg(hw, I82577_CFG_REG, phy_data); | 653 | ret_val = e1e_wphy(hw, I82577_CFG_REG, phy_data); |
641 | 654 | ||
642 | out: | 655 | out: |
643 | return ret_val; | 656 | return ret_val; |
@@ -760,16 +773,14 @@ s32 e1000e_copper_link_setup_m88(struct e1000_hw *hw) | |||
760 | } | 773 | } |
761 | 774 | ||
762 | if (phy->type == e1000_phy_82578) { | 775 | if (phy->type == e1000_phy_82578) { |
763 | ret_val = phy->ops.read_reg(hw, M88E1000_EXT_PHY_SPEC_CTRL, | 776 | ret_val = e1e_rphy(hw, M88E1000_EXT_PHY_SPEC_CTRL, &phy_data); |
764 | &phy_data); | ||
765 | if (ret_val) | 777 | if (ret_val) |
766 | return ret_val; | 778 | return ret_val; |
767 | 779 | ||
768 | /* 82578 PHY - set the downshift count to 1x. */ | 780 | /* 82578 PHY - set the downshift count to 1x. */ |
769 | phy_data |= I82578_EPSCR_DOWNSHIFT_ENABLE; | 781 | phy_data |= I82578_EPSCR_DOWNSHIFT_ENABLE; |
770 | phy_data &= ~I82578_EPSCR_DOWNSHIFT_COUNTER_MASK; | 782 | phy_data &= ~I82578_EPSCR_DOWNSHIFT_COUNTER_MASK; |
771 | ret_val = phy->ops.write_reg(hw, M88E1000_EXT_PHY_SPEC_CTRL, | 783 | ret_val = e1e_wphy(hw, M88E1000_EXT_PHY_SPEC_CTRL, phy_data); |
772 | phy_data); | ||
773 | if (ret_val) | 784 | if (ret_val) |
774 | return ret_val; | 785 | return ret_val; |
775 | } | 786 | } |
@@ -1043,9 +1054,8 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw) | |||
1043 | 1054 | ||
1044 | e_dbg("Auto-Neg Advertising %x\n", mii_autoneg_adv_reg); | 1055 | e_dbg("Auto-Neg Advertising %x\n", mii_autoneg_adv_reg); |
1045 | 1056 | ||
1046 | if (phy->autoneg_mask & ADVERTISE_1000_FULL) { | 1057 | if (phy->autoneg_mask & ADVERTISE_1000_FULL) |
1047 | ret_val = e1e_wphy(hw, PHY_1000T_CTRL, mii_1000t_ctrl_reg); | 1058 | ret_val = e1e_wphy(hw, PHY_1000T_CTRL, mii_1000t_ctrl_reg); |
1048 | } | ||
1049 | 1059 | ||
1050 | return ret_val; | 1060 | return ret_val; |
1051 | } | 1061 | } |
@@ -1306,9 +1316,8 @@ s32 e1000e_phy_force_speed_duplex_m88(struct e1000_hw *hw) | |||
1306 | * We didn't get link. | 1316 | * We didn't get link. |
1307 | * Reset the DSP and cross our fingers. | 1317 | * Reset the DSP and cross our fingers. |
1308 | */ | 1318 | */ |
1309 | ret_val = e1e_wphy(hw, | 1319 | ret_val = e1e_wphy(hw, M88E1000_PHY_PAGE_SELECT, |
1310 | M88E1000_PHY_PAGE_SELECT, | 1320 | 0x001d); |
1311 | 0x001d); | ||
1312 | if (ret_val) | 1321 | if (ret_val) |
1313 | return ret_val; | 1322 | return ret_val; |
1314 | ret_val = e1000e_phy_reset_dsp(hw); | 1323 | ret_val = e1000e_phy_reset_dsp(hw); |
@@ -1840,11 +1849,12 @@ s32 e1000e_get_cable_length_igp_2(struct e1000_hw *hw) | |||
1840 | u16 phy_data, i, agc_value = 0; | 1849 | u16 phy_data, i, agc_value = 0; |
1841 | u16 cur_agc_index, max_agc_index = 0; | 1850 | u16 cur_agc_index, max_agc_index = 0; |
1842 | u16 min_agc_index = IGP02E1000_CABLE_LENGTH_TABLE_SIZE - 1; | 1851 | u16 min_agc_index = IGP02E1000_CABLE_LENGTH_TABLE_SIZE - 1; |
1843 | u16 agc_reg_array[IGP02E1000_PHY_CHANNEL_NUM] = | 1852 | static const u16 agc_reg_array[IGP02E1000_PHY_CHANNEL_NUM] = { |
1844 | {IGP02E1000_PHY_AGC_A, | 1853 | IGP02E1000_PHY_AGC_A, |
1845 | IGP02E1000_PHY_AGC_B, | 1854 | IGP02E1000_PHY_AGC_B, |
1846 | IGP02E1000_PHY_AGC_C, | 1855 | IGP02E1000_PHY_AGC_C, |
1847 | IGP02E1000_PHY_AGC_D}; | 1856 | IGP02E1000_PHY_AGC_D |
1857 | }; | ||
1848 | 1858 | ||
1849 | /* Read the AGC registers for all channels */ | 1859 | /* Read the AGC registers for all channels */ |
1850 | for (i = 0; i < IGP02E1000_PHY_CHANNEL_NUM; i++) { | 1860 | for (i = 0; i < IGP02E1000_PHY_CHANNEL_NUM; i++) { |
@@ -2362,7 +2372,7 @@ s32 e1000e_determine_phy_address(struct e1000_hw *hw) | |||
2362 | ret_val = 0; | 2372 | ret_val = 0; |
2363 | goto out; | 2373 | goto out; |
2364 | } | 2374 | } |
2365 | msleep(1); | 2375 | usleep_range(1000, 2000); |
2366 | i++; | 2376 | i++; |
2367 | } while (i < 10); | 2377 | } while (i < 10); |
2368 | } | 2378 | } |
@@ -2399,9 +2409,7 @@ static u32 e1000_get_phy_addr_for_bm_page(u32 page, u32 reg) | |||
2399 | s32 e1000e_write_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 data) | 2409 | s32 e1000e_write_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 data) |
2400 | { | 2410 | { |
2401 | s32 ret_val; | 2411 | s32 ret_val; |
2402 | u32 page_select = 0; | ||
2403 | u32 page = offset >> IGP_PAGE_SHIFT; | 2412 | u32 page = offset >> IGP_PAGE_SHIFT; |
2404 | u32 page_shift = 0; | ||
2405 | 2413 | ||
2406 | ret_val = hw->phy.ops.acquire(hw); | 2414 | ret_val = hw->phy.ops.acquire(hw); |
2407 | if (ret_val) | 2415 | if (ret_val) |
@@ -2417,6 +2425,8 @@ s32 e1000e_write_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 data) | |||
2417 | hw->phy.addr = e1000_get_phy_addr_for_bm_page(page, offset); | 2425 | hw->phy.addr = e1000_get_phy_addr_for_bm_page(page, offset); |
2418 | 2426 | ||
2419 | if (offset > MAX_PHY_MULTI_PAGE_REG) { | 2427 | if (offset > MAX_PHY_MULTI_PAGE_REG) { |
2428 | u32 page_shift, page_select; | ||
2429 | |||
2420 | /* | 2430 | /* |
2421 | * Page select is register 31 for phy address 1 and 22 for | 2431 | * Page select is register 31 for phy address 1 and 22 for |
2422 | * phy address 2 and 3. Page select is shifted only for | 2432 | * phy address 2 and 3. Page select is shifted only for |
@@ -2458,9 +2468,7 @@ out: | |||
2458 | s32 e1000e_read_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 *data) | 2468 | s32 e1000e_read_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 *data) |
2459 | { | 2469 | { |
2460 | s32 ret_val; | 2470 | s32 ret_val; |
2461 | u32 page_select = 0; | ||
2462 | u32 page = offset >> IGP_PAGE_SHIFT; | 2471 | u32 page = offset >> IGP_PAGE_SHIFT; |
2463 | u32 page_shift = 0; | ||
2464 | 2472 | ||
2465 | ret_val = hw->phy.ops.acquire(hw); | 2473 | ret_val = hw->phy.ops.acquire(hw); |
2466 | if (ret_val) | 2474 | if (ret_val) |
@@ -2476,6 +2484,8 @@ s32 e1000e_read_phy_reg_bm(struct e1000_hw *hw, u32 offset, u16 *data) | |||
2476 | hw->phy.addr = e1000_get_phy_addr_for_bm_page(page, offset); | 2484 | hw->phy.addr = e1000_get_phy_addr_for_bm_page(page, offset); |
2477 | 2485 | ||
2478 | if (offset > MAX_PHY_MULTI_PAGE_REG) { | 2486 | if (offset > MAX_PHY_MULTI_PAGE_REG) { |
2487 | u32 page_shift, page_select; | ||
2488 | |||
2479 | /* | 2489 | /* |
2480 | * Page select is register 31 for phy address 1 and 22 for | 2490 | * Page select is register 31 for phy address 1 and 22 for |
2481 | * phy address 2 and 3. Page select is shifted only for | 2491 | * phy address 2 and 3. Page select is shifted only for |
@@ -2730,7 +2740,7 @@ void e1000_power_down_phy_copper(struct e1000_hw *hw) | |||
2730 | e1e_rphy(hw, PHY_CONTROL, &mii_reg); | 2740 | e1e_rphy(hw, PHY_CONTROL, &mii_reg); |
2731 | mii_reg |= MII_CR_POWER_DOWN; | 2741 | mii_reg |= MII_CR_POWER_DOWN; |
2732 | e1e_wphy(hw, PHY_CONTROL, mii_reg); | 2742 | e1e_wphy(hw, PHY_CONTROL, mii_reg); |
2733 | msleep(1); | 2743 | usleep_range(1000, 2000); |
2734 | } | 2744 | } |
2735 | 2745 | ||
2736 | /** | 2746 | /** |
@@ -2976,7 +2986,7 @@ s32 e1000_write_phy_reg_hv_locked(struct e1000_hw *hw, u32 offset, u16 data) | |||
2976 | } | 2986 | } |
2977 | 2987 | ||
2978 | /** | 2988 | /** |
2979 | * e1000_get_phy_addr_for_hv_page - Get PHY adrress based on page | 2989 | * e1000_get_phy_addr_for_hv_page - Get PHY address based on page |
2980 | * @page: page to be accessed | 2990 | * @page: page to be accessed |
2981 | **/ | 2991 | **/ |
2982 | static u32 e1000_get_phy_addr_for_hv_page(u32 page) | 2992 | static u32 e1000_get_phy_addr_for_hv_page(u32 page) |
@@ -3057,12 +3067,12 @@ s32 e1000_link_stall_workaround_hv(struct e1000_hw *hw) | |||
3057 | goto out; | 3067 | goto out; |
3058 | 3068 | ||
3059 | /* Do not apply workaround if in PHY loopback bit 14 set */ | 3069 | /* Do not apply workaround if in PHY loopback bit 14 set */ |
3060 | hw->phy.ops.read_reg(hw, PHY_CONTROL, &data); | 3070 | e1e_rphy(hw, PHY_CONTROL, &data); |
3061 | if (data & PHY_CONTROL_LB) | 3071 | if (data & PHY_CONTROL_LB) |
3062 | goto out; | 3072 | goto out; |
3063 | 3073 | ||
3064 | /* check if link is up and at 1Gbps */ | 3074 | /* check if link is up and at 1Gbps */ |
3065 | ret_val = hw->phy.ops.read_reg(hw, BM_CS_STATUS, &data); | 3075 | ret_val = e1e_rphy(hw, BM_CS_STATUS, &data); |
3066 | if (ret_val) | 3076 | if (ret_val) |
3067 | goto out; | 3077 | goto out; |
3068 | 3078 | ||
@@ -3078,14 +3088,12 @@ s32 e1000_link_stall_workaround_hv(struct e1000_hw *hw) | |||
3078 | mdelay(200); | 3088 | mdelay(200); |
3079 | 3089 | ||
3080 | /* flush the packets in the fifo buffer */ | 3090 | /* flush the packets in the fifo buffer */ |
3081 | ret_val = hw->phy.ops.write_reg(hw, HV_MUX_DATA_CTRL, | 3091 | ret_val = e1e_wphy(hw, HV_MUX_DATA_CTRL, HV_MUX_DATA_CTRL_GEN_TO_MAC | |
3082 | HV_MUX_DATA_CTRL_GEN_TO_MAC | | 3092 | HV_MUX_DATA_CTRL_FORCE_SPEED); |
3083 | HV_MUX_DATA_CTRL_FORCE_SPEED); | ||
3084 | if (ret_val) | 3093 | if (ret_val) |
3085 | goto out; | 3094 | goto out; |
3086 | 3095 | ||
3087 | ret_val = hw->phy.ops.write_reg(hw, HV_MUX_DATA_CTRL, | 3096 | ret_val = e1e_wphy(hw, HV_MUX_DATA_CTRL, HV_MUX_DATA_CTRL_GEN_TO_MAC); |
3088 | HV_MUX_DATA_CTRL_GEN_TO_MAC); | ||
3089 | 3097 | ||
3090 | out: | 3098 | out: |
3091 | return ret_val; | 3099 | return ret_val; |
@@ -3105,7 +3113,7 @@ s32 e1000_check_polarity_82577(struct e1000_hw *hw) | |||
3105 | s32 ret_val; | 3113 | s32 ret_val; |
3106 | u16 data; | 3114 | u16 data; |
3107 | 3115 | ||
3108 | ret_val = phy->ops.read_reg(hw, I82577_PHY_STATUS_2, &data); | 3116 | ret_val = e1e_rphy(hw, I82577_PHY_STATUS_2, &data); |
3109 | 3117 | ||
3110 | if (!ret_val) | 3118 | if (!ret_val) |
3111 | phy->cable_polarity = (data & I82577_PHY_STATUS2_REV_POLARITY) | 3119 | phy->cable_polarity = (data & I82577_PHY_STATUS2_REV_POLARITY) |
@@ -3128,13 +3136,13 @@ s32 e1000_phy_force_speed_duplex_82577(struct e1000_hw *hw) | |||
3128 | u16 phy_data; | 3136 | u16 phy_data; |
3129 | bool link; | 3137 | bool link; |
3130 | 3138 | ||
3131 | ret_val = phy->ops.read_reg(hw, PHY_CONTROL, &phy_data); | 3139 | ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_data); |
3132 | if (ret_val) | 3140 | if (ret_val) |
3133 | goto out; | 3141 | goto out; |
3134 | 3142 | ||
3135 | e1000e_phy_force_speed_duplex_setup(hw, &phy_data); | 3143 | e1000e_phy_force_speed_duplex_setup(hw, &phy_data); |
3136 | 3144 | ||
3137 | ret_val = phy->ops.write_reg(hw, PHY_CONTROL, phy_data); | 3145 | ret_val = e1e_wphy(hw, PHY_CONTROL, phy_data); |
3138 | if (ret_val) | 3146 | if (ret_val) |
3139 | goto out; | 3147 | goto out; |
3140 | 3148 | ||
@@ -3198,7 +3206,7 @@ s32 e1000_get_phy_info_82577(struct e1000_hw *hw) | |||
3198 | if (ret_val) | 3206 | if (ret_val) |
3199 | goto out; | 3207 | goto out; |
3200 | 3208 | ||
3201 | ret_val = phy->ops.read_reg(hw, I82577_PHY_STATUS_2, &data); | 3209 | ret_val = e1e_rphy(hw, I82577_PHY_STATUS_2, &data); |
3202 | if (ret_val) | 3210 | if (ret_val) |
3203 | goto out; | 3211 | goto out; |
3204 | 3212 | ||
@@ -3210,7 +3218,7 @@ s32 e1000_get_phy_info_82577(struct e1000_hw *hw) | |||
3210 | if (ret_val) | 3218 | if (ret_val) |
3211 | goto out; | 3219 | goto out; |
3212 | 3220 | ||
3213 | ret_val = phy->ops.read_reg(hw, PHY_1000T_STATUS, &data); | 3221 | ret_val = e1e_rphy(hw, PHY_1000T_STATUS, &data); |
3214 | if (ret_val) | 3222 | if (ret_val) |
3215 | goto out; | 3223 | goto out; |
3216 | 3224 | ||
@@ -3244,7 +3252,7 @@ s32 e1000_get_cable_length_82577(struct e1000_hw *hw) | |||
3244 | s32 ret_val; | 3252 | s32 ret_val; |
3245 | u16 phy_data, length; | 3253 | u16 phy_data, length; |
3246 | 3254 | ||
3247 | ret_val = phy->ops.read_reg(hw, I82577_PHY_DIAG_STATUS, &phy_data); | 3255 | ret_val = e1e_rphy(hw, I82577_PHY_DIAG_STATUS, &phy_data); |
3248 | if (ret_val) | 3256 | if (ret_val) |
3249 | goto out; | 3257 | goto out; |
3250 | 3258 | ||