1 /****************************************************************************** 2 SPDX-License-Identifier: BSD-3-Clause 3 4 Copyright (c) 2001-2015, Intel Corporation 5 All rights reserved. 6 7 Redistribution and use in source and binary forms, with or without 8 modification, are permitted provided that the following conditions are met: 9 10 1. Redistributions of source code must retain the above copyright notice, 11 this list of conditions and the following disclaimer. 12 13 2. Redistributions in binary form must reproduce the above copyright 14 notice, this list of conditions and the following disclaimer in the 15 documentation and/or other materials provided with the distribution. 16 17 3. Neither the name of the Intel Corporation nor the names of its 18 contributors may be used to endorse or promote products derived from 19 this software without specific prior written permission. 20 21 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 22 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 25 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 26 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 27 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 28 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 29 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 30 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 31 POSSIBILITY OF SUCH DAMAGE. 32 33 ******************************************************************************/ 34 /*$FreeBSD$*/ 35 36 /* 37 * 82575EB Gigabit Network Connection 38 * 82575EB Gigabit Backplane Connection 39 * 82575GB Gigabit Network Connection 40 * 82576 Gigabit Network Connection 41 * 82576 Quad Port Gigabit Mezzanine Adapter 42 * 82580 Gigabit Network Connection 43 * I350 Gigabit Network Connection 44 */ 45 46 #include "e1000_api.h" 47 #include "e1000_i210.h" 48 49 static s32 e1000_init_phy_params_82575(struct e1000_hw *hw); 50 static s32 e1000_init_mac_params_82575(struct e1000_hw *hw); 51 static s32 e1000_acquire_phy_82575(struct e1000_hw *hw); 52 static void e1000_release_phy_82575(struct e1000_hw *hw); 53 static s32 e1000_acquire_nvm_82575(struct e1000_hw *hw); 54 static void e1000_release_nvm_82575(struct e1000_hw *hw); 55 static s32 e1000_check_for_link_82575(struct e1000_hw *hw); 56 static s32 e1000_check_for_link_media_swap(struct e1000_hw *hw); 57 static s32 e1000_get_cfg_done_82575(struct e1000_hw *hw); 58 static s32 e1000_get_link_up_info_82575(struct e1000_hw *hw, u16 *speed, 59 u16 *duplex); 60 static s32 e1000_phy_hw_reset_sgmii_82575(struct e1000_hw *hw); 61 static s32 e1000_read_phy_reg_sgmii_82575(struct e1000_hw *hw, u32 offset, 62 u16 *data); 63 static s32 e1000_reset_hw_82575(struct e1000_hw *hw); 64 static s32 e1000_reset_hw_82580(struct e1000_hw *hw); 65 static s32 e1000_read_phy_reg_82580(struct e1000_hw *hw, 66 u32 offset, u16 *data); 67 static s32 e1000_write_phy_reg_82580(struct e1000_hw *hw, 68 u32 offset, u16 data); 69 static s32 e1000_set_d0_lplu_state_82580(struct e1000_hw *hw, 70 bool active); 71 static s32 e1000_set_d3_lplu_state_82580(struct e1000_hw *hw, 72 bool active); 73 static s32 e1000_set_d0_lplu_state_82575(struct e1000_hw *hw, 74 bool active); 75 static s32 e1000_setup_copper_link_82575(struct e1000_hw *hw); 76 static s32 e1000_setup_serdes_link_82575(struct e1000_hw *hw); 77 static s32 e1000_get_media_type_82575(struct e1000_hw *hw); 78 static s32 e1000_set_sfp_media_type_82575(struct e1000_hw *hw); 79 static s32 e1000_valid_led_default_82575(struct e1000_hw *hw, u16 *data); 80 static s32 e1000_write_phy_reg_sgmii_82575(struct e1000_hw *hw, 81 u32 offset, u16 data); 82 static void e1000_clear_hw_cntrs_82575(struct e1000_hw *hw); 83 static s32 e1000_get_pcs_speed_and_duplex_82575(struct e1000_hw *hw, 84 u16 *speed, u16 *duplex); 85 static s32 e1000_get_phy_id_82575(struct e1000_hw *hw); 86 static bool e1000_sgmii_active_82575(struct e1000_hw *hw); 87 static s32 e1000_reset_init_script_82575(struct e1000_hw *hw); 88 static s32 e1000_read_mac_addr_82575(struct e1000_hw *hw); 89 static void e1000_config_collision_dist_82575(struct e1000_hw *hw); 90 static void e1000_power_down_phy_copper_82575(struct e1000_hw *hw); 91 static void e1000_shutdown_serdes_link_82575(struct e1000_hw *hw); 92 static void e1000_power_up_serdes_link_82575(struct e1000_hw *hw); 93 static s32 e1000_set_pcie_completion_timeout(struct e1000_hw *hw); 94 static s32 e1000_reset_mdicnfg_82580(struct e1000_hw *hw); 95 static s32 e1000_validate_nvm_checksum_82580(struct e1000_hw *hw); 96 static s32 e1000_update_nvm_checksum_82580(struct e1000_hw *hw); 97 static s32 e1000_update_nvm_checksum_with_offset(struct e1000_hw *hw, 98 u16 offset); 99 static s32 e1000_validate_nvm_checksum_with_offset(struct e1000_hw *hw, 100 u16 offset); 101 static s32 e1000_validate_nvm_checksum_i350(struct e1000_hw *hw); 102 static s32 e1000_update_nvm_checksum_i350(struct e1000_hw *hw); 103 static void e1000_clear_vfta_i350(struct e1000_hw *hw); 104 105 static void e1000_i2c_start(struct e1000_hw *hw); 106 static void e1000_i2c_stop(struct e1000_hw *hw); 107 static s32 e1000_clock_in_i2c_byte(struct e1000_hw *hw, u8 *data); 108 static s32 e1000_clock_out_i2c_byte(struct e1000_hw *hw, u8 data); 109 static s32 e1000_get_i2c_ack(struct e1000_hw *hw); 110 static s32 e1000_clock_in_i2c_bit(struct e1000_hw *hw, bool *data); 111 static s32 e1000_clock_out_i2c_bit(struct e1000_hw *hw, bool data); 112 static void e1000_raise_i2c_clk(struct e1000_hw *hw, u32 *i2cctl); 113 static void e1000_lower_i2c_clk(struct e1000_hw *hw, u32 *i2cctl); 114 static s32 e1000_set_i2c_data(struct e1000_hw *hw, u32 *i2cctl, bool data); 115 static bool e1000_get_i2c_data(u32 *i2cctl); 116 117 static const u16 e1000_82580_rxpbs_table[] = { 118 36, 72, 144, 1, 2, 4, 8, 16, 35, 70, 140 }; 119 #define E1000_82580_RXPBS_TABLE_SIZE \ 120 (sizeof(e1000_82580_rxpbs_table) / \ 121 sizeof(e1000_82580_rxpbs_table[0])) 122 123 124 /** 125 * e1000_sgmii_uses_mdio_82575 - Determine if I2C pins are for external MDIO 126 * @hw: pointer to the HW structure 127 * 128 * Called to determine if the I2C pins are being used for I2C or as an 129 * external MDIO interface since the two options are mutually exclusive. 130 **/ 131 static bool e1000_sgmii_uses_mdio_82575(struct e1000_hw *hw) 132 { 133 u32 reg = 0; 134 bool ext_mdio = FALSE; 135 136 DEBUGFUNC("e1000_sgmii_uses_mdio_82575"); 137 138 switch (hw->mac.type) { 139 case e1000_82575: 140 case e1000_82576: 141 reg = E1000_READ_REG(hw, E1000_MDIC); 142 ext_mdio = !!(reg & E1000_MDIC_DEST); 143 break; 144 case e1000_82580: 145 case e1000_i350: 146 case e1000_i354: 147 case e1000_i210: 148 case e1000_i211: 149 reg = E1000_READ_REG(hw, E1000_MDICNFG); 150 ext_mdio = !!(reg & E1000_MDICNFG_EXT_MDIO); 151 break; 152 default: 153 break; 154 } 155 return ext_mdio; 156 } 157 158 /** 159 * e1000_init_phy_params_82575 - Init PHY func ptrs. 160 * @hw: pointer to the HW structure 161 **/ 162 static s32 e1000_init_phy_params_82575(struct e1000_hw *hw) 163 { 164 struct e1000_phy_info *phy = &hw->phy; 165 s32 ret_val = E1000_SUCCESS; 166 u32 ctrl_ext; 167 168 DEBUGFUNC("e1000_init_phy_params_82575"); 169 170 phy->ops.read_i2c_byte = e1000_read_i2c_byte_generic; 171 phy->ops.write_i2c_byte = e1000_write_i2c_byte_generic; 172 173 if (hw->phy.media_type != e1000_media_type_copper) { 174 phy->type = e1000_phy_none; 175 goto out; 176 } 177 178 phy->ops.power_up = e1000_power_up_phy_copper; 179 phy->ops.power_down = e1000_power_down_phy_copper_82575; 180 181 phy->autoneg_mask = AUTONEG_ADVERTISE_SPEED_DEFAULT; 182 phy->reset_delay_us = 100; 183 184 phy->ops.acquire = e1000_acquire_phy_82575; 185 phy->ops.check_reset_block = e1000_check_reset_block_generic; 186 phy->ops.commit = e1000_phy_sw_reset_generic; 187 phy->ops.get_cfg_done = e1000_get_cfg_done_82575; 188 phy->ops.release = e1000_release_phy_82575; 189 190 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 191 192 if (e1000_sgmii_active_82575(hw)) { 193 phy->ops.reset = e1000_phy_hw_reset_sgmii_82575; 194 ctrl_ext |= E1000_CTRL_I2C_ENA; 195 } else { 196 phy->ops.reset = e1000_phy_hw_reset_generic; 197 ctrl_ext &= ~E1000_CTRL_I2C_ENA; 198 } 199 200 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 201 e1000_reset_mdicnfg_82580(hw); 202 203 if (e1000_sgmii_active_82575(hw) && !e1000_sgmii_uses_mdio_82575(hw)) { 204 phy->ops.read_reg = e1000_read_phy_reg_sgmii_82575; 205 phy->ops.write_reg = e1000_write_phy_reg_sgmii_82575; 206 } else { 207 switch (hw->mac.type) { 208 case e1000_82580: 209 case e1000_i350: 210 case e1000_i354: 211 phy->ops.read_reg = e1000_read_phy_reg_82580; 212 phy->ops.write_reg = e1000_write_phy_reg_82580; 213 break; 214 case e1000_i210: 215 case e1000_i211: 216 phy->ops.read_reg = e1000_read_phy_reg_gs40g; 217 phy->ops.write_reg = e1000_write_phy_reg_gs40g; 218 break; 219 default: 220 phy->ops.read_reg = e1000_read_phy_reg_igp; 221 phy->ops.write_reg = e1000_write_phy_reg_igp; 222 } 223 } 224 225 /* Set phy->phy_addr and phy->id. */ 226 ret_val = e1000_get_phy_id_82575(hw); 227 228 /* Verify phy id and set remaining function pointers */ 229 switch (phy->id) { 230 case M88E1543_E_PHY_ID: 231 case M88E1512_E_PHY_ID: 232 case I347AT4_E_PHY_ID: 233 case M88E1112_E_PHY_ID: 234 case M88E1340M_E_PHY_ID: 235 case M88E1111_I_PHY_ID: 236 phy->type = e1000_phy_m88; 237 phy->ops.check_polarity = e1000_check_polarity_m88; 238 phy->ops.get_info = e1000_get_phy_info_m88; 239 if (phy->id == I347AT4_E_PHY_ID || 240 phy->id == M88E1112_E_PHY_ID || 241 phy->id == M88E1340M_E_PHY_ID) 242 phy->ops.get_cable_length = 243 e1000_get_cable_length_m88_gen2; 244 else if (phy->id == M88E1543_E_PHY_ID || 245 phy->id == M88E1512_E_PHY_ID) 246 phy->ops.get_cable_length = 247 e1000_get_cable_length_m88_gen2; 248 else 249 phy->ops.get_cable_length = e1000_get_cable_length_m88; 250 phy->ops.force_speed_duplex = e1000_phy_force_speed_duplex_m88; 251 /* Check if this PHY is confgured for media swap. */ 252 if (phy->id == M88E1112_E_PHY_ID) { 253 u16 data; 254 255 ret_val = phy->ops.write_reg(hw, 256 E1000_M88E1112_PAGE_ADDR, 257 2); 258 if (ret_val) 259 goto out; 260 261 ret_val = phy->ops.read_reg(hw, 262 E1000_M88E1112_MAC_CTRL_1, 263 &data); 264 if (ret_val) 265 goto out; 266 267 data = (data & E1000_M88E1112_MAC_CTRL_1_MODE_MASK) >> 268 E1000_M88E1112_MAC_CTRL_1_MODE_SHIFT; 269 if (data == E1000_M88E1112_AUTO_COPPER_SGMII || 270 data == E1000_M88E1112_AUTO_COPPER_BASEX) 271 hw->mac.ops.check_for_link = 272 e1000_check_for_link_media_swap; 273 } 274 if (phy->id == M88E1512_E_PHY_ID) { 275 ret_val = e1000_initialize_M88E1512_phy(hw); 276 if (ret_val) 277 goto out; 278 } 279 if (phy->id == M88E1543_E_PHY_ID) { 280 ret_val = e1000_initialize_M88E1543_phy(hw); 281 if (ret_val) 282 goto out; 283 } 284 break; 285 case IGP03E1000_E_PHY_ID: 286 case IGP04E1000_E_PHY_ID: 287 phy->type = e1000_phy_igp_3; 288 phy->ops.check_polarity = e1000_check_polarity_igp; 289 phy->ops.get_info = e1000_get_phy_info_igp; 290 phy->ops.get_cable_length = e1000_get_cable_length_igp_2; 291 phy->ops.force_speed_duplex = e1000_phy_force_speed_duplex_igp; 292 phy->ops.set_d0_lplu_state = e1000_set_d0_lplu_state_82575; 293 phy->ops.set_d3_lplu_state = e1000_set_d3_lplu_state_generic; 294 break; 295 case I82580_I_PHY_ID: 296 case I350_I_PHY_ID: 297 phy->type = e1000_phy_82580; 298 phy->ops.check_polarity = e1000_check_polarity_82577; 299 phy->ops.force_speed_duplex = 300 e1000_phy_force_speed_duplex_82577; 301 phy->ops.get_cable_length = e1000_get_cable_length_82577; 302 phy->ops.get_info = e1000_get_phy_info_82577; 303 phy->ops.set_d0_lplu_state = e1000_set_d0_lplu_state_82580; 304 phy->ops.set_d3_lplu_state = e1000_set_d3_lplu_state_82580; 305 break; 306 case I210_I_PHY_ID: 307 phy->type = e1000_phy_i210; 308 phy->ops.check_polarity = e1000_check_polarity_m88; 309 phy->ops.get_info = e1000_get_phy_info_m88; 310 phy->ops.get_cable_length = e1000_get_cable_length_m88_gen2; 311 phy->ops.set_d0_lplu_state = e1000_set_d0_lplu_state_82580; 312 phy->ops.set_d3_lplu_state = e1000_set_d3_lplu_state_82580; 313 phy->ops.force_speed_duplex = e1000_phy_force_speed_duplex_m88; 314 break; 315 default: 316 ret_val = -E1000_ERR_PHY; 317 goto out; 318 } 319 320 out: 321 return ret_val; 322 } 323 324 /** 325 * e1000_init_nvm_params_82575 - Init NVM func ptrs. 326 * @hw: pointer to the HW structure 327 **/ 328 s32 e1000_init_nvm_params_82575(struct e1000_hw *hw) 329 { 330 struct e1000_nvm_info *nvm = &hw->nvm; 331 u32 eecd = E1000_READ_REG(hw, E1000_EECD); 332 u16 size; 333 334 DEBUGFUNC("e1000_init_nvm_params_82575"); 335 336 size = (u16)((eecd & E1000_EECD_SIZE_EX_MASK) >> 337 E1000_EECD_SIZE_EX_SHIFT); 338 /* 339 * Added to a constant, "size" becomes the left-shift value 340 * for setting word_size. 341 */ 342 size += NVM_WORD_SIZE_BASE_SHIFT; 343 344 /* Just in case size is out of range, cap it to the largest 345 * EEPROM size supported 346 */ 347 if (size > 15) 348 size = 15; 349 350 nvm->word_size = 1 << size; 351 if (hw->mac.type < e1000_i210) { 352 nvm->opcode_bits = 8; 353 nvm->delay_usec = 1; 354 355 switch (nvm->override) { 356 case e1000_nvm_override_spi_large: 357 nvm->page_size = 32; 358 nvm->address_bits = 16; 359 break; 360 case e1000_nvm_override_spi_small: 361 nvm->page_size = 8; 362 nvm->address_bits = 8; 363 break; 364 default: 365 nvm->page_size = eecd & E1000_EECD_ADDR_BITS ? 32 : 8; 366 nvm->address_bits = eecd & E1000_EECD_ADDR_BITS ? 367 16 : 8; 368 break; 369 } 370 if (nvm->word_size == (1 << 15)) 371 nvm->page_size = 128; 372 373 nvm->type = e1000_nvm_eeprom_spi; 374 } else { 375 nvm->type = e1000_nvm_flash_hw; 376 } 377 378 /* Function Pointers */ 379 nvm->ops.acquire = e1000_acquire_nvm_82575; 380 nvm->ops.release = e1000_release_nvm_82575; 381 if (nvm->word_size < (1 << 15)) 382 nvm->ops.read = e1000_read_nvm_eerd; 383 else 384 nvm->ops.read = e1000_read_nvm_spi; 385 386 nvm->ops.write = e1000_write_nvm_spi; 387 nvm->ops.validate = e1000_validate_nvm_checksum_generic; 388 nvm->ops.update = e1000_update_nvm_checksum_generic; 389 nvm->ops.valid_led_default = e1000_valid_led_default_82575; 390 391 /* override generic family function pointers for specific descendants */ 392 switch (hw->mac.type) { 393 case e1000_82580: 394 nvm->ops.validate = e1000_validate_nvm_checksum_82580; 395 nvm->ops.update = e1000_update_nvm_checksum_82580; 396 break; 397 case e1000_i350: 398 case e1000_i354: 399 nvm->ops.validate = e1000_validate_nvm_checksum_i350; 400 nvm->ops.update = e1000_update_nvm_checksum_i350; 401 break; 402 default: 403 break; 404 } 405 406 return E1000_SUCCESS; 407 } 408 409 /** 410 * e1000_init_mac_params_82575 - Init MAC func ptrs. 411 * @hw: pointer to the HW structure 412 **/ 413 static s32 e1000_init_mac_params_82575(struct e1000_hw *hw) 414 { 415 struct e1000_mac_info *mac = &hw->mac; 416 struct e1000_dev_spec_82575 *dev_spec = &hw->dev_spec._82575; 417 418 DEBUGFUNC("e1000_init_mac_params_82575"); 419 420 /* Derives media type */ 421 e1000_get_media_type_82575(hw); 422 /* Set mta register count */ 423 mac->mta_reg_count = 128; 424 /* Set uta register count */ 425 mac->uta_reg_count = (hw->mac.type == e1000_82575) ? 0 : 128; 426 /* Set rar entry count */ 427 mac->rar_entry_count = E1000_RAR_ENTRIES_82575; 428 if (mac->type == e1000_82576) 429 mac->rar_entry_count = E1000_RAR_ENTRIES_82576; 430 if (mac->type == e1000_82580) 431 mac->rar_entry_count = E1000_RAR_ENTRIES_82580; 432 if (mac->type == e1000_i350 || mac->type == e1000_i354) 433 mac->rar_entry_count = E1000_RAR_ENTRIES_I350; 434 435 /* Enable EEE default settings for EEE supported devices */ 436 if (mac->type >= e1000_i350) 437 dev_spec->eee_disable = FALSE; 438 439 /* Allow a single clear of the SW semaphore on I210 and newer */ 440 if (mac->type >= e1000_i210) 441 dev_spec->clear_semaphore_once = TRUE; 442 443 /* Set if part includes ASF firmware */ 444 mac->asf_firmware_present = TRUE; 445 /* FWSM register */ 446 mac->has_fwsm = TRUE; 447 /* ARC supported; valid only if manageability features are enabled. */ 448 mac->arc_subsystem_valid = 449 !!(E1000_READ_REG(hw, E1000_FWSM) & E1000_FWSM_MODE_MASK); 450 451 /* Function pointers */ 452 453 /* bus type/speed/width */ 454 mac->ops.get_bus_info = e1000_get_bus_info_pcie_generic; 455 /* reset */ 456 if (mac->type >= e1000_82580) 457 mac->ops.reset_hw = e1000_reset_hw_82580; 458 else 459 mac->ops.reset_hw = e1000_reset_hw_82575; 460 /* hw initialization */ 461 if ((mac->type == e1000_i210) || (mac->type == e1000_i211)) 462 mac->ops.init_hw = e1000_init_hw_i210; 463 else 464 mac->ops.init_hw = e1000_init_hw_82575; 465 /* link setup */ 466 mac->ops.setup_link = e1000_setup_link_generic; 467 /* physical interface link setup */ 468 mac->ops.setup_physical_interface = 469 (hw->phy.media_type == e1000_media_type_copper) 470 ? e1000_setup_copper_link_82575 : e1000_setup_serdes_link_82575; 471 /* physical interface shutdown */ 472 mac->ops.shutdown_serdes = e1000_shutdown_serdes_link_82575; 473 /* physical interface power up */ 474 mac->ops.power_up_serdes = e1000_power_up_serdes_link_82575; 475 /* check for link */ 476 mac->ops.check_for_link = e1000_check_for_link_82575; 477 /* read mac address */ 478 mac->ops.read_mac_addr = e1000_read_mac_addr_82575; 479 /* configure collision distance */ 480 mac->ops.config_collision_dist = e1000_config_collision_dist_82575; 481 /* multicast address update */ 482 mac->ops.update_mc_addr_list = e1000_update_mc_addr_list_generic; 483 if (hw->mac.type == e1000_i350 || mac->type == e1000_i354) { 484 /* writing VFTA */ 485 mac->ops.write_vfta = e1000_write_vfta_i350; 486 /* clearing VFTA */ 487 mac->ops.clear_vfta = e1000_clear_vfta_i350; 488 } else { 489 /* writing VFTA */ 490 mac->ops.write_vfta = e1000_write_vfta_generic; 491 /* clearing VFTA */ 492 mac->ops.clear_vfta = e1000_clear_vfta_generic; 493 } 494 if (hw->mac.type >= e1000_82580) 495 mac->ops.validate_mdi_setting = 496 e1000_validate_mdi_setting_crossover_generic; 497 /* ID LED init */ 498 mac->ops.id_led_init = e1000_id_led_init_generic; 499 /* blink LED */ 500 mac->ops.blink_led = e1000_blink_led_generic; 501 /* setup LED */ 502 mac->ops.setup_led = e1000_setup_led_generic; 503 /* cleanup LED */ 504 mac->ops.cleanup_led = e1000_cleanup_led_generic; 505 /* turn on/off LED */ 506 mac->ops.led_on = e1000_led_on_generic; 507 mac->ops.led_off = e1000_led_off_generic; 508 /* clear hardware counters */ 509 mac->ops.clear_hw_cntrs = e1000_clear_hw_cntrs_82575; 510 /* link info */ 511 mac->ops.get_link_up_info = e1000_get_link_up_info_82575; 512 /* acquire SW_FW sync */ 513 mac->ops.acquire_swfw_sync = e1000_acquire_swfw_sync; 514 mac->ops.release_swfw_sync = e1000_release_swfw_sync; 515 516 /* set lan id for port to determine which phy lock to use */ 517 hw->mac.ops.set_lan_id(hw); 518 519 return E1000_SUCCESS; 520 } 521 522 /** 523 * e1000_init_function_pointers_82575 - Init func ptrs. 524 * @hw: pointer to the HW structure 525 * 526 * Called to initialize all function pointers and parameters. 527 **/ 528 void e1000_init_function_pointers_82575(struct e1000_hw *hw) 529 { 530 DEBUGFUNC("e1000_init_function_pointers_82575"); 531 532 hw->mac.ops.init_params = e1000_init_mac_params_82575; 533 hw->nvm.ops.init_params = e1000_init_nvm_params_82575; 534 hw->phy.ops.init_params = e1000_init_phy_params_82575; 535 hw->mbx.ops.init_params = e1000_init_mbx_params_pf; 536 } 537 538 /** 539 * e1000_acquire_phy_82575 - Acquire rights to access PHY 540 * @hw: pointer to the HW structure 541 * 542 * Acquire access rights to the correct PHY. 543 **/ 544 static s32 e1000_acquire_phy_82575(struct e1000_hw *hw) 545 { 546 u16 mask = E1000_SWFW_PHY0_SM; 547 548 DEBUGFUNC("e1000_acquire_phy_82575"); 549 550 if (hw->bus.func == E1000_FUNC_1) 551 mask = E1000_SWFW_PHY1_SM; 552 else if (hw->bus.func == E1000_FUNC_2) 553 mask = E1000_SWFW_PHY2_SM; 554 else if (hw->bus.func == E1000_FUNC_3) 555 mask = E1000_SWFW_PHY3_SM; 556 557 return hw->mac.ops.acquire_swfw_sync(hw, mask); 558 } 559 560 /** 561 * e1000_release_phy_82575 - Release rights to access PHY 562 * @hw: pointer to the HW structure 563 * 564 * A wrapper to release access rights to the correct PHY. 565 **/ 566 static void e1000_release_phy_82575(struct e1000_hw *hw) 567 { 568 u16 mask = E1000_SWFW_PHY0_SM; 569 570 DEBUGFUNC("e1000_release_phy_82575"); 571 572 if (hw->bus.func == E1000_FUNC_1) 573 mask = E1000_SWFW_PHY1_SM; 574 else if (hw->bus.func == E1000_FUNC_2) 575 mask = E1000_SWFW_PHY2_SM; 576 else if (hw->bus.func == E1000_FUNC_3) 577 mask = E1000_SWFW_PHY3_SM; 578 579 hw->mac.ops.release_swfw_sync(hw, mask); 580 } 581 582 /** 583 * e1000_read_phy_reg_sgmii_82575 - Read PHY register using sgmii 584 * @hw: pointer to the HW structure 585 * @offset: register offset to be read 586 * @data: pointer to the read data 587 * 588 * Reads the PHY register at offset using the serial gigabit media independent 589 * interface and stores the retrieved information in data. 590 **/ 591 static s32 e1000_read_phy_reg_sgmii_82575(struct e1000_hw *hw, u32 offset, 592 u16 *data) 593 { 594 s32 ret_val = -E1000_ERR_PARAM; 595 596 DEBUGFUNC("e1000_read_phy_reg_sgmii_82575"); 597 598 if (offset > E1000_MAX_SGMII_PHY_REG_ADDR) { 599 DEBUGOUT1("PHY Address %u is out of range\n", offset); 600 goto out; 601 } 602 603 ret_val = hw->phy.ops.acquire(hw); 604 if (ret_val) 605 goto out; 606 607 ret_val = e1000_read_phy_reg_i2c(hw, offset, data); 608 609 hw->phy.ops.release(hw); 610 611 out: 612 return ret_val; 613 } 614 615 /** 616 * e1000_write_phy_reg_sgmii_82575 - Write PHY register using sgmii 617 * @hw: pointer to the HW structure 618 * @offset: register offset to write to 619 * @data: data to write at register offset 620 * 621 * Writes the data to PHY register at the offset using the serial gigabit 622 * media independent interface. 623 **/ 624 static s32 e1000_write_phy_reg_sgmii_82575(struct e1000_hw *hw, u32 offset, 625 u16 data) 626 { 627 s32 ret_val = -E1000_ERR_PARAM; 628 629 DEBUGFUNC("e1000_write_phy_reg_sgmii_82575"); 630 631 if (offset > E1000_MAX_SGMII_PHY_REG_ADDR) { 632 DEBUGOUT1("PHY Address %d is out of range\n", offset); 633 goto out; 634 } 635 636 ret_val = hw->phy.ops.acquire(hw); 637 if (ret_val) 638 goto out; 639 640 ret_val = e1000_write_phy_reg_i2c(hw, offset, data); 641 642 hw->phy.ops.release(hw); 643 644 out: 645 return ret_val; 646 } 647 648 /** 649 * e1000_get_phy_id_82575 - Retrieve PHY addr and id 650 * @hw: pointer to the HW structure 651 * 652 * Retrieves the PHY address and ID for both PHY's which do and do not use 653 * sgmi interface. 654 **/ 655 static s32 e1000_get_phy_id_82575(struct e1000_hw *hw) 656 { 657 struct e1000_phy_info *phy = &hw->phy; 658 s32 ret_val = E1000_SUCCESS; 659 u16 phy_id; 660 u32 ctrl_ext; 661 u32 mdic; 662 663 DEBUGFUNC("e1000_get_phy_id_82575"); 664 665 /* some i354 devices need an extra read for phy id */ 666 if (hw->mac.type == e1000_i354) 667 e1000_get_phy_id(hw); 668 669 /* 670 * For SGMII PHYs, we try the list of possible addresses until 671 * we find one that works. For non-SGMII PHYs 672 * (e.g. integrated copper PHYs), an address of 1 should 673 * work. The result of this function should mean phy->phy_addr 674 * and phy->id are set correctly. 675 */ 676 if (!e1000_sgmii_active_82575(hw)) { 677 phy->addr = 1; 678 ret_val = e1000_get_phy_id(hw); 679 goto out; 680 } 681 682 if (e1000_sgmii_uses_mdio_82575(hw)) { 683 switch (hw->mac.type) { 684 case e1000_82575: 685 case e1000_82576: 686 mdic = E1000_READ_REG(hw, E1000_MDIC); 687 mdic &= E1000_MDIC_PHY_MASK; 688 phy->addr = mdic >> E1000_MDIC_PHY_SHIFT; 689 break; 690 case e1000_82580: 691 case e1000_i350: 692 case e1000_i354: 693 case e1000_i210: 694 case e1000_i211: 695 mdic = E1000_READ_REG(hw, E1000_MDICNFG); 696 mdic &= E1000_MDICNFG_PHY_MASK; 697 phy->addr = mdic >> E1000_MDICNFG_PHY_SHIFT; 698 break; 699 default: 700 ret_val = -E1000_ERR_PHY; 701 goto out; 702 break; 703 } 704 ret_val = e1000_get_phy_id(hw); 705 goto out; 706 } 707 708 /* Power on sgmii phy if it is disabled */ 709 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 710 E1000_WRITE_REG(hw, E1000_CTRL_EXT, 711 ctrl_ext & ~E1000_CTRL_EXT_SDP3_DATA); 712 E1000_WRITE_FLUSH(hw); 713 msec_delay(300); 714 715 /* 716 * The address field in the I2CCMD register is 3 bits and 0 is invalid. 717 * Therefore, we need to test 1-7 718 */ 719 for (phy->addr = 1; phy->addr < 8; phy->addr++) { 720 ret_val = e1000_read_phy_reg_sgmii_82575(hw, PHY_ID1, &phy_id); 721 if (ret_val == E1000_SUCCESS) { 722 DEBUGOUT2("Vendor ID 0x%08X read at address %u\n", 723 phy_id, phy->addr); 724 /* 725 * At the time of this writing, The M88 part is 726 * the only supported SGMII PHY product. 727 */ 728 if (phy_id == M88_VENDOR) 729 break; 730 } else { 731 DEBUGOUT1("PHY address %u was unreadable\n", 732 phy->addr); 733 } 734 } 735 736 /* A valid PHY type couldn't be found. */ 737 if (phy->addr == 8) { 738 phy->addr = 0; 739 ret_val = -E1000_ERR_PHY; 740 } else { 741 ret_val = e1000_get_phy_id(hw); 742 } 743 744 /* restore previous sfp cage power state */ 745 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 746 747 out: 748 return ret_val; 749 } 750 751 /** 752 * e1000_phy_hw_reset_sgmii_82575 - Performs a PHY reset 753 * @hw: pointer to the HW structure 754 * 755 * Resets the PHY using the serial gigabit media independent interface. 756 **/ 757 static s32 e1000_phy_hw_reset_sgmii_82575(struct e1000_hw *hw) 758 { 759 s32 ret_val = E1000_SUCCESS; 760 struct e1000_phy_info *phy = &hw->phy; 761 762 DEBUGFUNC("e1000_phy_hw_reset_sgmii_82575"); 763 764 /* 765 * This isn't a TRUE "hard" reset, but is the only reset 766 * available to us at this time. 767 */ 768 769 DEBUGOUT("Soft resetting SGMII attached PHY...\n"); 770 771 if (!(hw->phy.ops.write_reg)) 772 goto out; 773 774 /* 775 * SFP documentation requires the following to configure the SPF module 776 * to work on SGMII. No further documentation is given. 777 */ 778 ret_val = hw->phy.ops.write_reg(hw, 0x1B, 0x8084); 779 if (ret_val) 780 goto out; 781 782 ret_val = hw->phy.ops.commit(hw); 783 if (ret_val) 784 goto out; 785 786 if (phy->id == M88E1512_E_PHY_ID) 787 ret_val = e1000_initialize_M88E1512_phy(hw); 788 out: 789 return ret_val; 790 } 791 792 /** 793 * e1000_set_d0_lplu_state_82575 - Set Low Power Linkup D0 state 794 * @hw: pointer to the HW structure 795 * @active: TRUE to enable LPLU, FALSE to disable 796 * 797 * Sets the LPLU D0 state according to the active flag. When 798 * activating LPLU this function also disables smart speed 799 * and vice versa. LPLU will not be activated unless the 800 * device autonegotiation advertisement meets standards of 801 * either 10 or 10/100 or 10/100/1000 at all duplexes. 802 * This is a function pointer entry point only called by 803 * PHY setup routines. 804 **/ 805 static s32 e1000_set_d0_lplu_state_82575(struct e1000_hw *hw, bool active) 806 { 807 struct e1000_phy_info *phy = &hw->phy; 808 s32 ret_val = E1000_SUCCESS; 809 u16 data; 810 811 DEBUGFUNC("e1000_set_d0_lplu_state_82575"); 812 813 if (!(hw->phy.ops.read_reg)) 814 goto out; 815 816 ret_val = phy->ops.read_reg(hw, IGP02E1000_PHY_POWER_MGMT, &data); 817 if (ret_val) 818 goto out; 819 820 if (active) { 821 data |= IGP02E1000_PM_D0_LPLU; 822 ret_val = phy->ops.write_reg(hw, IGP02E1000_PHY_POWER_MGMT, 823 data); 824 if (ret_val) 825 goto out; 826 827 /* When LPLU is enabled, we should disable SmartSpeed */ 828 ret_val = phy->ops.read_reg(hw, IGP01E1000_PHY_PORT_CONFIG, 829 &data); 830 data &= ~IGP01E1000_PSCFR_SMART_SPEED; 831 ret_val = phy->ops.write_reg(hw, IGP01E1000_PHY_PORT_CONFIG, 832 data); 833 if (ret_val) 834 goto out; 835 } else { 836 data &= ~IGP02E1000_PM_D0_LPLU; 837 ret_val = phy->ops.write_reg(hw, IGP02E1000_PHY_POWER_MGMT, 838 data); 839 /* 840 * LPLU and SmartSpeed are mutually exclusive. LPLU is used 841 * during Dx states where the power conservation is most 842 * important. During driver activity we should enable 843 * SmartSpeed, so performance is maintained. 844 */ 845 if (phy->smart_speed == e1000_smart_speed_on) { 846 ret_val = phy->ops.read_reg(hw, 847 IGP01E1000_PHY_PORT_CONFIG, 848 &data); 849 if (ret_val) 850 goto out; 851 852 data |= IGP01E1000_PSCFR_SMART_SPEED; 853 ret_val = phy->ops.write_reg(hw, 854 IGP01E1000_PHY_PORT_CONFIG, 855 data); 856 if (ret_val) 857 goto out; 858 } else if (phy->smart_speed == e1000_smart_speed_off) { 859 ret_val = phy->ops.read_reg(hw, 860 IGP01E1000_PHY_PORT_CONFIG, 861 &data); 862 if (ret_val) 863 goto out; 864 865 data &= ~IGP01E1000_PSCFR_SMART_SPEED; 866 ret_val = phy->ops.write_reg(hw, 867 IGP01E1000_PHY_PORT_CONFIG, 868 data); 869 if (ret_val) 870 goto out; 871 } 872 } 873 874 out: 875 return ret_val; 876 } 877 878 /** 879 * e1000_set_d0_lplu_state_82580 - Set Low Power Linkup D0 state 880 * @hw: pointer to the HW structure 881 * @active: TRUE to enable LPLU, FALSE to disable 882 * 883 * Sets the LPLU D0 state according to the active flag. When 884 * activating LPLU this function also disables smart speed 885 * and vice versa. LPLU will not be activated unless the 886 * device autonegotiation advertisement meets standards of 887 * either 10 or 10/100 or 10/100/1000 at all duplexes. 888 * This is a function pointer entry point only called by 889 * PHY setup routines. 890 **/ 891 static s32 e1000_set_d0_lplu_state_82580(struct e1000_hw *hw, bool active) 892 { 893 struct e1000_phy_info *phy = &hw->phy; 894 u32 data; 895 896 DEBUGFUNC("e1000_set_d0_lplu_state_82580"); 897 898 data = E1000_READ_REG(hw, E1000_82580_PHY_POWER_MGMT); 899 900 if (active) { 901 data |= E1000_82580_PM_D0_LPLU; 902 903 /* When LPLU is enabled, we should disable SmartSpeed */ 904 data &= ~E1000_82580_PM_SPD; 905 } else { 906 data &= ~E1000_82580_PM_D0_LPLU; 907 908 /* 909 * LPLU and SmartSpeed are mutually exclusive. LPLU is used 910 * during Dx states where the power conservation is most 911 * important. During driver activity we should enable 912 * SmartSpeed, so performance is maintained. 913 */ 914 if (phy->smart_speed == e1000_smart_speed_on) 915 data |= E1000_82580_PM_SPD; 916 else if (phy->smart_speed == e1000_smart_speed_off) 917 data &= ~E1000_82580_PM_SPD; 918 } 919 920 E1000_WRITE_REG(hw, E1000_82580_PHY_POWER_MGMT, data); 921 return E1000_SUCCESS; 922 } 923 924 /** 925 * e1000_set_d3_lplu_state_82580 - Sets low power link up state for D3 926 * @hw: pointer to the HW structure 927 * @active: boolean used to enable/disable lplu 928 * 929 * Success returns 0, Failure returns 1 930 * 931 * The low power link up (lplu) state is set to the power management level D3 932 * and SmartSpeed is disabled when active is TRUE, else clear lplu for D3 933 * and enable Smartspeed. LPLU and Smartspeed are mutually exclusive. LPLU 934 * is used during Dx states where the power conservation is most important. 935 * During driver activity, SmartSpeed should be enabled so performance is 936 * maintained. 937 **/ 938 s32 e1000_set_d3_lplu_state_82580(struct e1000_hw *hw, bool active) 939 { 940 struct e1000_phy_info *phy = &hw->phy; 941 u32 data; 942 943 DEBUGFUNC("e1000_set_d3_lplu_state_82580"); 944 945 data = E1000_READ_REG(hw, E1000_82580_PHY_POWER_MGMT); 946 947 if (!active) { 948 data &= ~E1000_82580_PM_D3_LPLU; 949 /* 950 * LPLU and SmartSpeed are mutually exclusive. LPLU is used 951 * during Dx states where the power conservation is most 952 * important. During driver activity we should enable 953 * SmartSpeed, so performance is maintained. 954 */ 955 if (phy->smart_speed == e1000_smart_speed_on) 956 data |= E1000_82580_PM_SPD; 957 else if (phy->smart_speed == e1000_smart_speed_off) 958 data &= ~E1000_82580_PM_SPD; 959 } else if ((phy->autoneg_advertised == E1000_ALL_SPEED_DUPLEX) || 960 (phy->autoneg_advertised == E1000_ALL_NOT_GIG) || 961 (phy->autoneg_advertised == E1000_ALL_10_SPEED)) { 962 data |= E1000_82580_PM_D3_LPLU; 963 /* When LPLU is enabled, we should disable SmartSpeed */ 964 data &= ~E1000_82580_PM_SPD; 965 } 966 967 E1000_WRITE_REG(hw, E1000_82580_PHY_POWER_MGMT, data); 968 return E1000_SUCCESS; 969 } 970 971 /** 972 * e1000_acquire_nvm_82575 - Request for access to EEPROM 973 * @hw: pointer to the HW structure 974 * 975 * Acquire the necessary semaphores for exclusive access to the EEPROM. 976 * Set the EEPROM access request bit and wait for EEPROM access grant bit. 977 * Return successful if access grant bit set, else clear the request for 978 * EEPROM access and return -E1000_ERR_NVM (-1). 979 **/ 980 static s32 e1000_acquire_nvm_82575(struct e1000_hw *hw) 981 { 982 s32 ret_val = E1000_SUCCESS; 983 984 DEBUGFUNC("e1000_acquire_nvm_82575"); 985 986 ret_val = e1000_acquire_swfw_sync(hw, E1000_SWFW_EEP_SM); 987 if (ret_val) 988 goto out; 989 990 /* 991 * Check if there is some access 992 * error this access may hook on 993 */ 994 if (hw->mac.type == e1000_i350) { 995 u32 eecd = E1000_READ_REG(hw, E1000_EECD); 996 if (eecd & (E1000_EECD_BLOCKED | E1000_EECD_ABORT | 997 E1000_EECD_TIMEOUT)) { 998 /* Clear all access error flags */ 999 E1000_WRITE_REG(hw, E1000_EECD, eecd | 1000 E1000_EECD_ERROR_CLR); 1001 DEBUGOUT("Nvm bit banging access error detected and cleared.\n"); 1002 } 1003 } 1004 1005 if (hw->mac.type == e1000_82580) { 1006 u32 eecd = E1000_READ_REG(hw, E1000_EECD); 1007 if (eecd & E1000_EECD_BLOCKED) { 1008 /* Clear access error flag */ 1009 E1000_WRITE_REG(hw, E1000_EECD, eecd | 1010 E1000_EECD_BLOCKED); 1011 DEBUGOUT("Nvm bit banging access error detected and cleared.\n"); 1012 } 1013 } 1014 1015 ret_val = e1000_acquire_nvm_generic(hw); 1016 if (ret_val) 1017 e1000_release_swfw_sync(hw, E1000_SWFW_EEP_SM); 1018 1019 out: 1020 return ret_val; 1021 } 1022 1023 /** 1024 * e1000_release_nvm_82575 - Release exclusive access to EEPROM 1025 * @hw: pointer to the HW structure 1026 * 1027 * Stop any current commands to the EEPROM and clear the EEPROM request bit, 1028 * then release the semaphores acquired. 1029 **/ 1030 static void e1000_release_nvm_82575(struct e1000_hw *hw) 1031 { 1032 DEBUGFUNC("e1000_release_nvm_82575"); 1033 1034 e1000_release_nvm_generic(hw); 1035 1036 e1000_release_swfw_sync(hw, E1000_SWFW_EEP_SM); 1037 } 1038 1039 /** 1040 * e1000_get_cfg_done_82575 - Read config done bit 1041 * @hw: pointer to the HW structure 1042 * 1043 * Read the management control register for the config done bit for 1044 * completion status. NOTE: silicon which is EEPROM-less will fail trying 1045 * to read the config done bit, so an error is *ONLY* logged and returns 1046 * E1000_SUCCESS. If we were to return with error, EEPROM-less silicon 1047 * would not be able to be reset or change link. 1048 **/ 1049 static s32 e1000_get_cfg_done_82575(struct e1000_hw *hw) 1050 { 1051 s32 timeout = PHY_CFG_TIMEOUT; 1052 u32 mask = E1000_NVM_CFG_DONE_PORT_0; 1053 1054 DEBUGFUNC("e1000_get_cfg_done_82575"); 1055 1056 if (hw->bus.func == E1000_FUNC_1) 1057 mask = E1000_NVM_CFG_DONE_PORT_1; 1058 else if (hw->bus.func == E1000_FUNC_2) 1059 mask = E1000_NVM_CFG_DONE_PORT_2; 1060 else if (hw->bus.func == E1000_FUNC_3) 1061 mask = E1000_NVM_CFG_DONE_PORT_3; 1062 while (timeout) { 1063 if (E1000_READ_REG(hw, E1000_EEMNGCTL) & mask) 1064 break; 1065 msec_delay(1); 1066 timeout--; 1067 } 1068 if (!timeout) 1069 DEBUGOUT("MNG configuration cycle has not completed.\n"); 1070 1071 /* If EEPROM is not marked present, init the PHY manually */ 1072 if (!(E1000_READ_REG(hw, E1000_EECD) & E1000_EECD_PRES) && 1073 (hw->phy.type == e1000_phy_igp_3)) 1074 e1000_phy_init_script_igp3(hw); 1075 1076 return E1000_SUCCESS; 1077 } 1078 1079 /** 1080 * e1000_get_link_up_info_82575 - Get link speed/duplex info 1081 * @hw: pointer to the HW structure 1082 * @speed: stores the current speed 1083 * @duplex: stores the current duplex 1084 * 1085 * This is a wrapper function, if using the serial gigabit media independent 1086 * interface, use PCS to retrieve the link speed and duplex information. 1087 * Otherwise, use the generic function to get the link speed and duplex info. 1088 **/ 1089 static s32 e1000_get_link_up_info_82575(struct e1000_hw *hw, u16 *speed, 1090 u16 *duplex) 1091 { 1092 s32 ret_val; 1093 1094 DEBUGFUNC("e1000_get_link_up_info_82575"); 1095 1096 if (hw->phy.media_type != e1000_media_type_copper) 1097 ret_val = e1000_get_pcs_speed_and_duplex_82575(hw, speed, 1098 duplex); 1099 else 1100 ret_val = e1000_get_speed_and_duplex_copper_generic(hw, speed, 1101 duplex); 1102 1103 return ret_val; 1104 } 1105 1106 /** 1107 * e1000_check_for_link_82575 - Check for link 1108 * @hw: pointer to the HW structure 1109 * 1110 * If sgmii is enabled, then use the pcs register to determine link, otherwise 1111 * use the generic interface for determining link. 1112 **/ 1113 static s32 e1000_check_for_link_82575(struct e1000_hw *hw) 1114 { 1115 s32 ret_val; 1116 u16 speed, duplex; 1117 1118 DEBUGFUNC("e1000_check_for_link_82575"); 1119 1120 if (hw->phy.media_type != e1000_media_type_copper) { 1121 ret_val = e1000_get_pcs_speed_and_duplex_82575(hw, &speed, 1122 &duplex); 1123 /* 1124 * Use this flag to determine if link needs to be checked or 1125 * not. If we have link clear the flag so that we do not 1126 * continue to check for link. 1127 */ 1128 hw->mac.get_link_status = !hw->mac.serdes_has_link; 1129 1130 /* 1131 * Configure Flow Control now that Auto-Neg has completed. 1132 * First, we need to restore the desired flow control 1133 * settings because we may have had to re-autoneg with a 1134 * different link partner. 1135 */ 1136 ret_val = e1000_config_fc_after_link_up_generic(hw); 1137 if (ret_val) 1138 DEBUGOUT("Error configuring flow control\n"); 1139 } else { 1140 ret_val = e1000_check_for_copper_link_generic(hw); 1141 } 1142 1143 return ret_val; 1144 } 1145 1146 /** 1147 * e1000_check_for_link_media_swap - Check which M88E1112 interface linked 1148 * @hw: pointer to the HW structure 1149 * 1150 * Poll the M88E1112 interfaces to see which interface achieved link. 1151 */ 1152 static s32 e1000_check_for_link_media_swap(struct e1000_hw *hw) 1153 { 1154 struct e1000_phy_info *phy = &hw->phy; 1155 s32 ret_val; 1156 u16 data; 1157 u8 port = 0; 1158 1159 DEBUGFUNC("e1000_check_for_link_media_swap"); 1160 1161 /* Check for copper. */ 1162 ret_val = phy->ops.write_reg(hw, E1000_M88E1112_PAGE_ADDR, 0); 1163 if (ret_val) 1164 return ret_val; 1165 1166 ret_val = phy->ops.read_reg(hw, E1000_M88E1112_STATUS, &data); 1167 if (ret_val) 1168 return ret_val; 1169 1170 if (data & E1000_M88E1112_STATUS_LINK) 1171 port = E1000_MEDIA_PORT_COPPER; 1172 1173 /* Check for other. */ 1174 ret_val = phy->ops.write_reg(hw, E1000_M88E1112_PAGE_ADDR, 1); 1175 if (ret_val) 1176 return ret_val; 1177 1178 ret_val = phy->ops.read_reg(hw, E1000_M88E1112_STATUS, &data); 1179 if (ret_val) 1180 return ret_val; 1181 1182 if (data & E1000_M88E1112_STATUS_LINK) 1183 port = E1000_MEDIA_PORT_OTHER; 1184 1185 /* Determine if a swap needs to happen. */ 1186 if (port && (hw->dev_spec._82575.media_port != port)) { 1187 hw->dev_spec._82575.media_port = port; 1188 hw->dev_spec._82575.media_changed = TRUE; 1189 } 1190 1191 if (port == E1000_MEDIA_PORT_COPPER) { 1192 /* reset page to 0 */ 1193 ret_val = phy->ops.write_reg(hw, E1000_M88E1112_PAGE_ADDR, 0); 1194 if (ret_val) 1195 return ret_val; 1196 e1000_check_for_link_82575(hw); 1197 } else { 1198 e1000_check_for_link_82575(hw); 1199 /* reset page to 0 */ 1200 ret_val = phy->ops.write_reg(hw, E1000_M88E1112_PAGE_ADDR, 0); 1201 if (ret_val) 1202 return ret_val; 1203 } 1204 1205 return E1000_SUCCESS; 1206 } 1207 1208 /** 1209 * e1000_power_up_serdes_link_82575 - Power up the serdes link after shutdown 1210 * @hw: pointer to the HW structure 1211 **/ 1212 static void e1000_power_up_serdes_link_82575(struct e1000_hw *hw) 1213 { 1214 u32 reg; 1215 1216 DEBUGFUNC("e1000_power_up_serdes_link_82575"); 1217 1218 if ((hw->phy.media_type != e1000_media_type_internal_serdes) && 1219 !e1000_sgmii_active_82575(hw)) 1220 return; 1221 1222 /* Enable PCS to turn on link */ 1223 reg = E1000_READ_REG(hw, E1000_PCS_CFG0); 1224 reg |= E1000_PCS_CFG_PCS_EN; 1225 E1000_WRITE_REG(hw, E1000_PCS_CFG0, reg); 1226 1227 /* Power up the laser */ 1228 reg = E1000_READ_REG(hw, E1000_CTRL_EXT); 1229 reg &= ~E1000_CTRL_EXT_SDP3_DATA; 1230 E1000_WRITE_REG(hw, E1000_CTRL_EXT, reg); 1231 1232 /* flush the write to verify completion */ 1233 E1000_WRITE_FLUSH(hw); 1234 msec_delay(1); 1235 } 1236 1237 /** 1238 * e1000_get_pcs_speed_and_duplex_82575 - Retrieve current speed/duplex 1239 * @hw: pointer to the HW structure 1240 * @speed: stores the current speed 1241 * @duplex: stores the current duplex 1242 * 1243 * Using the physical coding sub-layer (PCS), retrieve the current speed and 1244 * duplex, then store the values in the pointers provided. 1245 **/ 1246 static s32 e1000_get_pcs_speed_and_duplex_82575(struct e1000_hw *hw, 1247 u16 *speed, u16 *duplex) 1248 { 1249 struct e1000_mac_info *mac = &hw->mac; 1250 u32 pcs; 1251 u32 status; 1252 1253 DEBUGFUNC("e1000_get_pcs_speed_and_duplex_82575"); 1254 1255 /* 1256 * Read the PCS Status register for link state. For non-copper mode, 1257 * the status register is not accurate. The PCS status register is 1258 * used instead. 1259 */ 1260 pcs = E1000_READ_REG(hw, E1000_PCS_LSTAT); 1261 1262 /* 1263 * The link up bit determines when link is up on autoneg. 1264 */ 1265 if (pcs & E1000_PCS_LSTS_LINK_OK) { 1266 mac->serdes_has_link = TRUE; 1267 1268 /* Detect and store PCS speed */ 1269 if (pcs & E1000_PCS_LSTS_SPEED_1000) 1270 *speed = SPEED_1000; 1271 else if (pcs & E1000_PCS_LSTS_SPEED_100) 1272 *speed = SPEED_100; 1273 else 1274 *speed = SPEED_10; 1275 1276 /* Detect and store PCS duplex */ 1277 if (pcs & E1000_PCS_LSTS_DUPLEX_FULL) 1278 *duplex = FULL_DUPLEX; 1279 else 1280 *duplex = HALF_DUPLEX; 1281 1282 /* Check if it is an I354 2.5Gb backplane connection. */ 1283 if (mac->type == e1000_i354) { 1284 status = E1000_READ_REG(hw, E1000_STATUS); 1285 if ((status & E1000_STATUS_2P5_SKU) && 1286 !(status & E1000_STATUS_2P5_SKU_OVER)) { 1287 *speed = SPEED_2500; 1288 *duplex = FULL_DUPLEX; 1289 DEBUGOUT("2500 Mbs, "); 1290 DEBUGOUT("Full Duplex\n"); 1291 } 1292 } 1293 1294 } else { 1295 mac->serdes_has_link = FALSE; 1296 *speed = 0; 1297 *duplex = 0; 1298 } 1299 1300 return E1000_SUCCESS; 1301 } 1302 1303 /** 1304 * e1000_shutdown_serdes_link_82575 - Remove link during power down 1305 * @hw: pointer to the HW structure 1306 * 1307 * In the case of serdes shut down sfp and PCS on driver unload 1308 * when management pass thru is not enabled. 1309 **/ 1310 void e1000_shutdown_serdes_link_82575(struct e1000_hw *hw) 1311 { 1312 u32 reg; 1313 1314 DEBUGFUNC("e1000_shutdown_serdes_link_82575"); 1315 1316 if ((hw->phy.media_type != e1000_media_type_internal_serdes) && 1317 !e1000_sgmii_active_82575(hw)) 1318 return; 1319 1320 if (!e1000_enable_mng_pass_thru(hw)) { 1321 /* Disable PCS to turn off link */ 1322 reg = E1000_READ_REG(hw, E1000_PCS_CFG0); 1323 reg &= ~E1000_PCS_CFG_PCS_EN; 1324 E1000_WRITE_REG(hw, E1000_PCS_CFG0, reg); 1325 1326 /* shutdown the laser */ 1327 reg = E1000_READ_REG(hw, E1000_CTRL_EXT); 1328 reg |= E1000_CTRL_EXT_SDP3_DATA; 1329 E1000_WRITE_REG(hw, E1000_CTRL_EXT, reg); 1330 1331 /* flush the write to verify completion */ 1332 E1000_WRITE_FLUSH(hw); 1333 msec_delay(1); 1334 } 1335 1336 return; 1337 } 1338 1339 /** 1340 * e1000_reset_hw_82575 - Reset hardware 1341 * @hw: pointer to the HW structure 1342 * 1343 * This resets the hardware into a known state. 1344 **/ 1345 static s32 e1000_reset_hw_82575(struct e1000_hw *hw) 1346 { 1347 u32 ctrl; 1348 s32 ret_val; 1349 1350 DEBUGFUNC("e1000_reset_hw_82575"); 1351 1352 /* 1353 * Prevent the PCI-E bus from sticking if there is no TLP connection 1354 * on the last TLP read/write transaction when MAC is reset. 1355 */ 1356 ret_val = e1000_disable_pcie_master_generic(hw); 1357 if (ret_val) 1358 DEBUGOUT("PCI-E Master disable polling has failed.\n"); 1359 1360 /* set the completion timeout for interface */ 1361 ret_val = e1000_set_pcie_completion_timeout(hw); 1362 if (ret_val) 1363 DEBUGOUT("PCI-E Set completion timeout has failed.\n"); 1364 1365 DEBUGOUT("Masking off all interrupts\n"); 1366 E1000_WRITE_REG(hw, E1000_IMC, 0xffffffff); 1367 1368 E1000_WRITE_REG(hw, E1000_RCTL, 0); 1369 E1000_WRITE_REG(hw, E1000_TCTL, E1000_TCTL_PSP); 1370 E1000_WRITE_FLUSH(hw); 1371 1372 msec_delay(10); 1373 1374 ctrl = E1000_READ_REG(hw, E1000_CTRL); 1375 1376 DEBUGOUT("Issuing a global reset to MAC\n"); 1377 E1000_WRITE_REG(hw, E1000_CTRL, ctrl | E1000_CTRL_RST); 1378 1379 ret_val = e1000_get_auto_rd_done_generic(hw); 1380 if (ret_val) { 1381 /* 1382 * When auto config read does not complete, do not 1383 * return with an error. This can happen in situations 1384 * where there is no eeprom and prevents getting link. 1385 */ 1386 DEBUGOUT("Auto Read Done did not complete\n"); 1387 } 1388 1389 /* If EEPROM is not present, run manual init scripts */ 1390 if (!(E1000_READ_REG(hw, E1000_EECD) & E1000_EECD_PRES)) 1391 e1000_reset_init_script_82575(hw); 1392 1393 /* Clear any pending interrupt events. */ 1394 E1000_WRITE_REG(hw, E1000_IMC, 0xffffffff); 1395 E1000_READ_REG(hw, E1000_ICR); 1396 1397 /* Install any alternate MAC address into RAR0 */ 1398 ret_val = e1000_check_alt_mac_addr_generic(hw); 1399 1400 return ret_val; 1401 } 1402 1403 /** 1404 * e1000_init_hw_82575 - Initialize hardware 1405 * @hw: pointer to the HW structure 1406 * 1407 * This inits the hardware readying it for operation. 1408 **/ 1409 s32 e1000_init_hw_82575(struct e1000_hw *hw) 1410 { 1411 struct e1000_mac_info *mac = &hw->mac; 1412 s32 ret_val; 1413 u16 i, rar_count = mac->rar_entry_count; 1414 1415 DEBUGFUNC("e1000_init_hw_82575"); 1416 1417 /* Initialize identification LED */ 1418 ret_val = mac->ops.id_led_init(hw); 1419 if (ret_val) { 1420 DEBUGOUT("Error initializing identification LED\n"); 1421 /* This is not fatal and we should not stop init due to this */ 1422 } 1423 1424 /* Disabling VLAN filtering */ 1425 DEBUGOUT("Initializing the IEEE VLAN\n"); 1426 mac->ops.clear_vfta(hw); 1427 1428 /* Setup the receive address */ 1429 e1000_init_rx_addrs_generic(hw, rar_count); 1430 1431 /* Zero out the Multicast HASH table */ 1432 DEBUGOUT("Zeroing the MTA\n"); 1433 for (i = 0; i < mac->mta_reg_count; i++) 1434 E1000_WRITE_REG_ARRAY(hw, E1000_MTA, i, 0); 1435 1436 /* Zero out the Unicast HASH table */ 1437 DEBUGOUT("Zeroing the UTA\n"); 1438 for (i = 0; i < mac->uta_reg_count; i++) 1439 E1000_WRITE_REG_ARRAY(hw, E1000_UTA, i, 0); 1440 1441 /* Setup link and flow control */ 1442 ret_val = mac->ops.setup_link(hw); 1443 1444 /* Set the default MTU size */ 1445 hw->dev_spec._82575.mtu = 1500; 1446 1447 /* 1448 * Clear all of the statistics registers (clear on read). It is 1449 * important that we do this after we have tried to establish link 1450 * because the symbol error count will increment wildly if there 1451 * is no link. 1452 */ 1453 e1000_clear_hw_cntrs_82575(hw); 1454 1455 return ret_val; 1456 } 1457 1458 /** 1459 * e1000_setup_copper_link_82575 - Configure copper link settings 1460 * @hw: pointer to the HW structure 1461 * 1462 * Configures the link for auto-neg or forced speed and duplex. Then we check 1463 * for link, once link is established calls to configure collision distance 1464 * and flow control are called. 1465 **/ 1466 static s32 e1000_setup_copper_link_82575(struct e1000_hw *hw) 1467 { 1468 u32 ctrl; 1469 s32 ret_val; 1470 u32 phpm_reg; 1471 1472 DEBUGFUNC("e1000_setup_copper_link_82575"); 1473 1474 ctrl = E1000_READ_REG(hw, E1000_CTRL); 1475 ctrl |= E1000_CTRL_SLU; 1476 ctrl &= ~(E1000_CTRL_FRCSPD | E1000_CTRL_FRCDPX); 1477 E1000_WRITE_REG(hw, E1000_CTRL, ctrl); 1478 1479 /* Clear Go Link Disconnect bit on supported devices */ 1480 switch (hw->mac.type) { 1481 case e1000_82580: 1482 case e1000_i350: 1483 case e1000_i210: 1484 case e1000_i211: 1485 phpm_reg = E1000_READ_REG(hw, E1000_82580_PHY_POWER_MGMT); 1486 phpm_reg &= ~E1000_82580_PM_GO_LINKD; 1487 E1000_WRITE_REG(hw, E1000_82580_PHY_POWER_MGMT, phpm_reg); 1488 break; 1489 default: 1490 break; 1491 } 1492 1493 ret_val = e1000_setup_serdes_link_82575(hw); 1494 if (ret_val) 1495 goto out; 1496 1497 if (e1000_sgmii_active_82575(hw)) { 1498 /* allow time for SFP cage time to power up phy */ 1499 msec_delay(300); 1500 1501 ret_val = hw->phy.ops.reset(hw); 1502 if (ret_val) { 1503 DEBUGOUT("Error resetting the PHY.\n"); 1504 goto out; 1505 } 1506 } 1507 switch (hw->phy.type) { 1508 case e1000_phy_i210: 1509 case e1000_phy_m88: 1510 switch (hw->phy.id) { 1511 case I347AT4_E_PHY_ID: 1512 case M88E1112_E_PHY_ID: 1513 case M88E1340M_E_PHY_ID: 1514 case M88E1543_E_PHY_ID: 1515 case M88E1512_E_PHY_ID: 1516 case I210_I_PHY_ID: 1517 ret_val = e1000_copper_link_setup_m88_gen2(hw); 1518 break; 1519 default: 1520 ret_val = e1000_copper_link_setup_m88(hw); 1521 break; 1522 } 1523 break; 1524 case e1000_phy_igp_3: 1525 ret_val = e1000_copper_link_setup_igp(hw); 1526 break; 1527 case e1000_phy_82580: 1528 ret_val = e1000_copper_link_setup_82577(hw); 1529 break; 1530 default: 1531 ret_val = -E1000_ERR_PHY; 1532 break; 1533 } 1534 1535 if (ret_val) 1536 goto out; 1537 1538 ret_val = e1000_setup_copper_link_generic(hw); 1539 out: 1540 return ret_val; 1541 } 1542 1543 /** 1544 * e1000_setup_serdes_link_82575 - Setup link for serdes 1545 * @hw: pointer to the HW structure 1546 * 1547 * Configure the physical coding sub-layer (PCS) link. The PCS link is 1548 * used on copper connections where the serialized gigabit media independent 1549 * interface (sgmii), or serdes fiber is being used. Configures the link 1550 * for auto-negotiation or forces speed/duplex. 1551 **/ 1552 static s32 e1000_setup_serdes_link_82575(struct e1000_hw *hw) 1553 { 1554 u32 ctrl_ext, ctrl_reg, reg, anadv_reg; 1555 bool pcs_autoneg; 1556 s32 ret_val = E1000_SUCCESS; 1557 u16 data; 1558 1559 DEBUGFUNC("e1000_setup_serdes_link_82575"); 1560 1561 if ((hw->phy.media_type != e1000_media_type_internal_serdes) && 1562 !e1000_sgmii_active_82575(hw)) 1563 return ret_val; 1564 1565 /* 1566 * On the 82575, SerDes loopback mode persists until it is 1567 * explicitly turned off or a power cycle is performed. A read to 1568 * the register does not indicate its status. Therefore, we ensure 1569 * loopback mode is disabled during initialization. 1570 */ 1571 E1000_WRITE_REG(hw, E1000_SCTL, E1000_SCTL_DISABLE_SERDES_LOOPBACK); 1572 1573 /* power on the sfp cage if present */ 1574 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 1575 ctrl_ext &= ~E1000_CTRL_EXT_SDP3_DATA; 1576 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 1577 1578 ctrl_reg = E1000_READ_REG(hw, E1000_CTRL); 1579 ctrl_reg |= E1000_CTRL_SLU; 1580 1581 /* set both sw defined pins on 82575/82576*/ 1582 if (hw->mac.type == e1000_82575 || hw->mac.type == e1000_82576) 1583 ctrl_reg |= E1000_CTRL_SWDPIN0 | E1000_CTRL_SWDPIN1; 1584 1585 reg = E1000_READ_REG(hw, E1000_PCS_LCTL); 1586 1587 /* default pcs_autoneg to the same setting as mac autoneg */ 1588 pcs_autoneg = hw->mac.autoneg; 1589 1590 switch (ctrl_ext & E1000_CTRL_EXT_LINK_MODE_MASK) { 1591 case E1000_CTRL_EXT_LINK_MODE_SGMII: 1592 /* sgmii mode lets the phy handle forcing speed/duplex */ 1593 pcs_autoneg = TRUE; 1594 /* autoneg time out should be disabled for SGMII mode */ 1595 reg &= ~(E1000_PCS_LCTL_AN_TIMEOUT); 1596 break; 1597 case E1000_CTRL_EXT_LINK_MODE_1000BASE_KX: 1598 /* disable PCS autoneg and support parallel detect only */ 1599 pcs_autoneg = FALSE; 1600 /* FALLTHROUGH */ 1601 default: 1602 if (hw->mac.type == e1000_82575 || 1603 hw->mac.type == e1000_82576) { 1604 ret_val = hw->nvm.ops.read(hw, NVM_COMPAT, 1, &data); 1605 if (ret_val) { 1606 DEBUGOUT("NVM Read Error\n"); 1607 return ret_val; 1608 } 1609 1610 if (data & E1000_EEPROM_PCS_AUTONEG_DISABLE_BIT) 1611 pcs_autoneg = FALSE; 1612 } 1613 1614 /* 1615 * non-SGMII modes only supports a speed of 1000/Full for the 1616 * link so it is best to just force the MAC and let the pcs 1617 * link either autoneg or be forced to 1000/Full 1618 */ 1619 ctrl_reg |= E1000_CTRL_SPD_1000 | E1000_CTRL_FRCSPD | 1620 E1000_CTRL_FD | E1000_CTRL_FRCDPX; 1621 1622 /* set speed of 1000/Full if speed/duplex is forced */ 1623 reg |= E1000_PCS_LCTL_FSV_1000 | E1000_PCS_LCTL_FDV_FULL; 1624 break; 1625 } 1626 1627 E1000_WRITE_REG(hw, E1000_CTRL, ctrl_reg); 1628 1629 /* 1630 * New SerDes mode allows for forcing speed or autonegotiating speed 1631 * at 1gb. Autoneg should be default set by most drivers. This is the 1632 * mode that will be compatible with older link partners and switches. 1633 * However, both are supported by the hardware and some drivers/tools. 1634 */ 1635 reg &= ~(E1000_PCS_LCTL_AN_ENABLE | E1000_PCS_LCTL_FLV_LINK_UP | 1636 E1000_PCS_LCTL_FSD | E1000_PCS_LCTL_FORCE_LINK); 1637 1638 if (pcs_autoneg) { 1639 /* Set PCS register for autoneg */ 1640 reg |= E1000_PCS_LCTL_AN_ENABLE | /* Enable Autoneg */ 1641 E1000_PCS_LCTL_AN_RESTART; /* Restart autoneg */ 1642 1643 /* Disable force flow control for autoneg */ 1644 reg &= ~E1000_PCS_LCTL_FORCE_FCTRL; 1645 1646 /* Configure flow control advertisement for autoneg */ 1647 anadv_reg = E1000_READ_REG(hw, E1000_PCS_ANADV); 1648 anadv_reg &= ~(E1000_TXCW_ASM_DIR | E1000_TXCW_PAUSE); 1649 1650 switch (hw->fc.requested_mode) { 1651 case e1000_fc_full: 1652 case e1000_fc_rx_pause: 1653 anadv_reg |= E1000_TXCW_ASM_DIR; 1654 anadv_reg |= E1000_TXCW_PAUSE; 1655 break; 1656 case e1000_fc_tx_pause: 1657 anadv_reg |= E1000_TXCW_ASM_DIR; 1658 break; 1659 default: 1660 break; 1661 } 1662 1663 E1000_WRITE_REG(hw, E1000_PCS_ANADV, anadv_reg); 1664 1665 DEBUGOUT1("Configuring Autoneg:PCS_LCTL=0x%08X\n", reg); 1666 } else { 1667 /* Set PCS register for forced link */ 1668 reg |= E1000_PCS_LCTL_FSD; /* Force Speed */ 1669 1670 /* Force flow control for forced link */ 1671 reg |= E1000_PCS_LCTL_FORCE_FCTRL; 1672 1673 DEBUGOUT1("Configuring Forced Link:PCS_LCTL=0x%08X\n", reg); 1674 } 1675 1676 E1000_WRITE_REG(hw, E1000_PCS_LCTL, reg); 1677 1678 if (!pcs_autoneg && !e1000_sgmii_active_82575(hw)) 1679 e1000_force_mac_fc_generic(hw); 1680 1681 return ret_val; 1682 } 1683 1684 /** 1685 * e1000_get_media_type_82575 - derives current media type. 1686 * @hw: pointer to the HW structure 1687 * 1688 * The media type is chosen reflecting few settings. 1689 * The following are taken into account: 1690 * - link mode set in the current port Init Control Word #3 1691 * - current link mode settings in CSR register 1692 * - MDIO vs. I2C PHY control interface chosen 1693 * - SFP module media type 1694 **/ 1695 static s32 e1000_get_media_type_82575(struct e1000_hw *hw) 1696 { 1697 struct e1000_dev_spec_82575 *dev_spec = &hw->dev_spec._82575; 1698 s32 ret_val = E1000_SUCCESS; 1699 u32 ctrl_ext = 0; 1700 u32 link_mode = 0; 1701 1702 /* Set internal phy as default */ 1703 dev_spec->sgmii_active = FALSE; 1704 dev_spec->module_plugged = FALSE; 1705 1706 /* Get CSR setting */ 1707 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 1708 1709 /* extract link mode setting */ 1710 link_mode = ctrl_ext & E1000_CTRL_EXT_LINK_MODE_MASK; 1711 1712 switch (link_mode) { 1713 case E1000_CTRL_EXT_LINK_MODE_1000BASE_KX: 1714 hw->phy.media_type = e1000_media_type_internal_serdes; 1715 break; 1716 case E1000_CTRL_EXT_LINK_MODE_GMII: 1717 hw->phy.media_type = e1000_media_type_copper; 1718 break; 1719 case E1000_CTRL_EXT_LINK_MODE_SGMII: 1720 /* Get phy control interface type set (MDIO vs. I2C)*/ 1721 if (e1000_sgmii_uses_mdio_82575(hw)) { 1722 hw->phy.media_type = e1000_media_type_copper; 1723 dev_spec->sgmii_active = TRUE; 1724 break; 1725 } 1726 /* fall through for I2C based SGMII */ 1727 /* FALLTHROUGH */ 1728 case E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES: 1729 /* read media type from SFP EEPROM */ 1730 ret_val = e1000_set_sfp_media_type_82575(hw); 1731 if ((ret_val != E1000_SUCCESS) || 1732 (hw->phy.media_type == e1000_media_type_unknown)) { 1733 /* 1734 * If media type was not identified then return media 1735 * type defined by the CTRL_EXT settings. 1736 */ 1737 hw->phy.media_type = e1000_media_type_internal_serdes; 1738 1739 if (link_mode == E1000_CTRL_EXT_LINK_MODE_SGMII) { 1740 hw->phy.media_type = e1000_media_type_copper; 1741 dev_spec->sgmii_active = TRUE; 1742 } 1743 1744 break; 1745 } 1746 1747 /* do not change link mode for 100BaseFX */ 1748 if (dev_spec->eth_flags.e100_base_fx) 1749 break; 1750 1751 /* change current link mode setting */ 1752 ctrl_ext &= ~E1000_CTRL_EXT_LINK_MODE_MASK; 1753 1754 if (hw->phy.media_type == e1000_media_type_copper) 1755 ctrl_ext |= E1000_CTRL_EXT_LINK_MODE_SGMII; 1756 else 1757 ctrl_ext |= E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES; 1758 1759 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 1760 1761 break; 1762 } 1763 1764 return ret_val; 1765 } 1766 1767 /** 1768 * e1000_set_sfp_media_type_82575 - derives SFP module media type. 1769 * @hw: pointer to the HW structure 1770 * 1771 * The media type is chosen based on SFP module. 1772 * compatibility flags retrieved from SFP ID EEPROM. 1773 **/ 1774 static s32 e1000_set_sfp_media_type_82575(struct e1000_hw *hw) 1775 { 1776 s32 ret_val = E1000_ERR_CONFIG; 1777 u32 ctrl_ext = 0; 1778 struct e1000_dev_spec_82575 *dev_spec = &hw->dev_spec._82575; 1779 struct sfp_e1000_flags *eth_flags = &dev_spec->eth_flags; 1780 u8 tranceiver_type = 0; 1781 s32 timeout = 3; 1782 1783 /* Turn I2C interface ON and power on sfp cage */ 1784 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 1785 ctrl_ext &= ~E1000_CTRL_EXT_SDP3_DATA; 1786 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext | E1000_CTRL_I2C_ENA); 1787 1788 E1000_WRITE_FLUSH(hw); 1789 1790 /* Read SFP module data */ 1791 while (timeout) { 1792 ret_val = e1000_read_sfp_data_byte(hw, 1793 E1000_I2CCMD_SFP_DATA_ADDR(E1000_SFF_IDENTIFIER_OFFSET), 1794 &tranceiver_type); 1795 if (ret_val == E1000_SUCCESS) 1796 break; 1797 msec_delay(100); 1798 timeout--; 1799 } 1800 if (ret_val != E1000_SUCCESS) 1801 goto out; 1802 1803 ret_val = e1000_read_sfp_data_byte(hw, 1804 E1000_I2CCMD_SFP_DATA_ADDR(E1000_SFF_ETH_FLAGS_OFFSET), 1805 (u8 *)eth_flags); 1806 if (ret_val != E1000_SUCCESS) 1807 goto out; 1808 1809 /* Check if there is some SFP module plugged and powered */ 1810 if ((tranceiver_type == E1000_SFF_IDENTIFIER_SFP) || 1811 (tranceiver_type == E1000_SFF_IDENTIFIER_SFF)) { 1812 dev_spec->module_plugged = TRUE; 1813 if (eth_flags->e1000_base_lx || eth_flags->e1000_base_sx) { 1814 hw->phy.media_type = e1000_media_type_internal_serdes; 1815 } else if (eth_flags->e100_base_fx) { 1816 dev_spec->sgmii_active = TRUE; 1817 hw->phy.media_type = e1000_media_type_internal_serdes; 1818 } else if (eth_flags->e1000_base_t) { 1819 dev_spec->sgmii_active = TRUE; 1820 hw->phy.media_type = e1000_media_type_copper; 1821 } else { 1822 hw->phy.media_type = e1000_media_type_unknown; 1823 DEBUGOUT("PHY module has not been recognized\n"); 1824 goto out; 1825 } 1826 } else { 1827 hw->phy.media_type = e1000_media_type_unknown; 1828 } 1829 ret_val = E1000_SUCCESS; 1830 out: 1831 /* Restore I2C interface setting */ 1832 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 1833 return ret_val; 1834 } 1835 1836 /** 1837 * e1000_valid_led_default_82575 - Verify a valid default LED config 1838 * @hw: pointer to the HW structure 1839 * @data: pointer to the NVM (EEPROM) 1840 * 1841 * Read the EEPROM for the current default LED configuration. If the 1842 * LED configuration is not valid, set to a valid LED configuration. 1843 **/ 1844 static s32 e1000_valid_led_default_82575(struct e1000_hw *hw, u16 *data) 1845 { 1846 s32 ret_val; 1847 1848 DEBUGFUNC("e1000_valid_led_default_82575"); 1849 1850 ret_val = hw->nvm.ops.read(hw, NVM_ID_LED_SETTINGS, 1, data); 1851 if (ret_val) { 1852 DEBUGOUT("NVM Read Error\n"); 1853 goto out; 1854 } 1855 1856 if (*data == ID_LED_RESERVED_0000 || *data == ID_LED_RESERVED_FFFF) { 1857 switch (hw->phy.media_type) { 1858 case e1000_media_type_internal_serdes: 1859 *data = ID_LED_DEFAULT_82575_SERDES; 1860 break; 1861 case e1000_media_type_copper: 1862 default: 1863 *data = ID_LED_DEFAULT; 1864 break; 1865 } 1866 } 1867 out: 1868 return ret_val; 1869 } 1870 1871 /** 1872 * e1000_sgmii_active_82575 - Return sgmii state 1873 * @hw: pointer to the HW structure 1874 * 1875 * 82575 silicon has a serialized gigabit media independent interface (sgmii) 1876 * which can be enabled for use in the embedded applications. Simply 1877 * return the current state of the sgmii interface. 1878 **/ 1879 static bool e1000_sgmii_active_82575(struct e1000_hw *hw) 1880 { 1881 struct e1000_dev_spec_82575 *dev_spec = &hw->dev_spec._82575; 1882 return dev_spec->sgmii_active; 1883 } 1884 1885 /** 1886 * e1000_reset_init_script_82575 - Inits HW defaults after reset 1887 * @hw: pointer to the HW structure 1888 * 1889 * Inits recommended HW defaults after a reset when there is no EEPROM 1890 * detected. This is only for the 82575. 1891 **/ 1892 static s32 e1000_reset_init_script_82575(struct e1000_hw *hw) 1893 { 1894 DEBUGFUNC("e1000_reset_init_script_82575"); 1895 1896 if (hw->mac.type == e1000_82575) { 1897 DEBUGOUT("Running reset init script for 82575\n"); 1898 /* SerDes configuration via SERDESCTRL */ 1899 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCTL, 0x00, 0x0C); 1900 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCTL, 0x01, 0x78); 1901 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCTL, 0x1B, 0x23); 1902 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCTL, 0x23, 0x15); 1903 1904 /* CCM configuration via CCMCTL register */ 1905 e1000_write_8bit_ctrl_reg_generic(hw, E1000_CCMCTL, 0x14, 0x00); 1906 e1000_write_8bit_ctrl_reg_generic(hw, E1000_CCMCTL, 0x10, 0x00); 1907 1908 /* PCIe lanes configuration */ 1909 e1000_write_8bit_ctrl_reg_generic(hw, E1000_GIOCTL, 0x00, 0xEC); 1910 e1000_write_8bit_ctrl_reg_generic(hw, E1000_GIOCTL, 0x61, 0xDF); 1911 e1000_write_8bit_ctrl_reg_generic(hw, E1000_GIOCTL, 0x34, 0x05); 1912 e1000_write_8bit_ctrl_reg_generic(hw, E1000_GIOCTL, 0x2F, 0x81); 1913 1914 /* PCIe PLL Configuration */ 1915 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCCTL, 0x02, 0x47); 1916 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCCTL, 0x14, 0x00); 1917 e1000_write_8bit_ctrl_reg_generic(hw, E1000_SCCTL, 0x10, 0x00); 1918 } 1919 1920 return E1000_SUCCESS; 1921 } 1922 1923 /** 1924 * e1000_read_mac_addr_82575 - Read device MAC address 1925 * @hw: pointer to the HW structure 1926 **/ 1927 static s32 e1000_read_mac_addr_82575(struct e1000_hw *hw) 1928 { 1929 s32 ret_val; 1930 1931 DEBUGFUNC("e1000_read_mac_addr_82575"); 1932 1933 /* 1934 * If there's an alternate MAC address place it in RAR0 1935 * so that it will override the Si installed default perm 1936 * address. 1937 */ 1938 ret_val = e1000_check_alt_mac_addr_generic(hw); 1939 if (ret_val) 1940 goto out; 1941 1942 ret_val = e1000_read_mac_addr_generic(hw); 1943 1944 out: 1945 return ret_val; 1946 } 1947 1948 /** 1949 * e1000_config_collision_dist_82575 - Configure collision distance 1950 * @hw: pointer to the HW structure 1951 * 1952 * Configures the collision distance to the default value and is used 1953 * during link setup. 1954 **/ 1955 static void e1000_config_collision_dist_82575(struct e1000_hw *hw) 1956 { 1957 u32 tctl_ext; 1958 1959 DEBUGFUNC("e1000_config_collision_dist_82575"); 1960 1961 tctl_ext = E1000_READ_REG(hw, E1000_TCTL_EXT); 1962 1963 tctl_ext &= ~E1000_TCTL_EXT_COLD; 1964 tctl_ext |= E1000_COLLISION_DISTANCE << E1000_TCTL_EXT_COLD_SHIFT; 1965 1966 E1000_WRITE_REG(hw, E1000_TCTL_EXT, tctl_ext); 1967 E1000_WRITE_FLUSH(hw); 1968 } 1969 1970 /** 1971 * e1000_power_down_phy_copper_82575 - Remove link during PHY power down 1972 * @hw: pointer to the HW structure 1973 * 1974 * In the case of a PHY power down to save power, or to turn off link during a 1975 * driver unload, or wake on lan is not enabled, remove the link. 1976 **/ 1977 static void e1000_power_down_phy_copper_82575(struct e1000_hw *hw) 1978 { 1979 struct e1000_phy_info *phy = &hw->phy; 1980 1981 if (!(phy->ops.check_reset_block)) 1982 return; 1983 1984 /* If the management interface is not enabled, then power down */ 1985 if (!(e1000_enable_mng_pass_thru(hw) || phy->ops.check_reset_block(hw))) 1986 e1000_power_down_phy_copper(hw); 1987 1988 return; 1989 } 1990 1991 /** 1992 * e1000_clear_hw_cntrs_82575 - Clear device specific hardware counters 1993 * @hw: pointer to the HW structure 1994 * 1995 * Clears the hardware counters by reading the counter registers. 1996 **/ 1997 static void e1000_clear_hw_cntrs_82575(struct e1000_hw *hw) 1998 { 1999 DEBUGFUNC("e1000_clear_hw_cntrs_82575"); 2000 2001 e1000_clear_hw_cntrs_base_generic(hw); 2002 2003 E1000_READ_REG(hw, E1000_PRC64); 2004 E1000_READ_REG(hw, E1000_PRC127); 2005 E1000_READ_REG(hw, E1000_PRC255); 2006 E1000_READ_REG(hw, E1000_PRC511); 2007 E1000_READ_REG(hw, E1000_PRC1023); 2008 E1000_READ_REG(hw, E1000_PRC1522); 2009 E1000_READ_REG(hw, E1000_PTC64); 2010 E1000_READ_REG(hw, E1000_PTC127); 2011 E1000_READ_REG(hw, E1000_PTC255); 2012 E1000_READ_REG(hw, E1000_PTC511); 2013 E1000_READ_REG(hw, E1000_PTC1023); 2014 E1000_READ_REG(hw, E1000_PTC1522); 2015 2016 E1000_READ_REG(hw, E1000_ALGNERRC); 2017 E1000_READ_REG(hw, E1000_RXERRC); 2018 E1000_READ_REG(hw, E1000_TNCRS); 2019 E1000_READ_REG(hw, E1000_CEXTERR); 2020 E1000_READ_REG(hw, E1000_TSCTC); 2021 E1000_READ_REG(hw, E1000_TSCTFC); 2022 2023 E1000_READ_REG(hw, E1000_MGTPRC); 2024 E1000_READ_REG(hw, E1000_MGTPDC); 2025 E1000_READ_REG(hw, E1000_MGTPTC); 2026 2027 E1000_READ_REG(hw, E1000_IAC); 2028 E1000_READ_REG(hw, E1000_ICRXOC); 2029 2030 E1000_READ_REG(hw, E1000_ICRXPTC); 2031 E1000_READ_REG(hw, E1000_ICRXATC); 2032 E1000_READ_REG(hw, E1000_ICTXPTC); 2033 E1000_READ_REG(hw, E1000_ICTXATC); 2034 E1000_READ_REG(hw, E1000_ICTXQEC); 2035 E1000_READ_REG(hw, E1000_ICTXQMTC); 2036 E1000_READ_REG(hw, E1000_ICRXDMTC); 2037 2038 E1000_READ_REG(hw, E1000_CBTMPC); 2039 E1000_READ_REG(hw, E1000_HTDPMC); 2040 E1000_READ_REG(hw, E1000_CBRMPC); 2041 E1000_READ_REG(hw, E1000_RPTHC); 2042 E1000_READ_REG(hw, E1000_HGPTC); 2043 E1000_READ_REG(hw, E1000_HTCBDPC); 2044 E1000_READ_REG(hw, E1000_HGORCL); 2045 E1000_READ_REG(hw, E1000_HGORCH); 2046 E1000_READ_REG(hw, E1000_HGOTCL); 2047 E1000_READ_REG(hw, E1000_HGOTCH); 2048 E1000_READ_REG(hw, E1000_LENERRS); 2049 2050 /* This register should not be read in copper configurations */ 2051 if ((hw->phy.media_type == e1000_media_type_internal_serdes) || 2052 e1000_sgmii_active_82575(hw)) 2053 E1000_READ_REG(hw, E1000_SCVPC); 2054 } 2055 2056 /** 2057 * e1000_rx_fifo_flush_82575 - Clean rx fifo after Rx enable 2058 * @hw: pointer to the HW structure 2059 * 2060 * After Rx enable, if manageability is enabled then there is likely some 2061 * bad data at the start of the fifo and possibly in the DMA fifo. This 2062 * function clears the fifos and flushes any packets that came in as rx was 2063 * being enabled. 2064 **/ 2065 void e1000_rx_fifo_flush_82575(struct e1000_hw *hw) 2066 { 2067 u32 rctl, rlpml, rxdctl[4], rfctl, temp_rctl, rx_enabled; 2068 int i, ms_wait; 2069 2070 DEBUGFUNC("e1000_rx_fifo_flush_82575"); 2071 2072 /* disable IPv6 options as per hardware errata */ 2073 rfctl = E1000_READ_REG(hw, E1000_RFCTL); 2074 rfctl |= E1000_RFCTL_IPV6_EX_DIS; 2075 E1000_WRITE_REG(hw, E1000_RFCTL, rfctl); 2076 2077 if (hw->mac.type != e1000_82575 || 2078 !(E1000_READ_REG(hw, E1000_MANC) & E1000_MANC_RCV_TCO_EN)) 2079 return; 2080 2081 /* Disable all Rx queues */ 2082 for (i = 0; i < 4; i++) { 2083 rxdctl[i] = E1000_READ_REG(hw, E1000_RXDCTL(i)); 2084 E1000_WRITE_REG(hw, E1000_RXDCTL(i), 2085 rxdctl[i] & ~E1000_RXDCTL_QUEUE_ENABLE); 2086 } 2087 /* Poll all queues to verify they have shut down */ 2088 for (ms_wait = 0; ms_wait < 10; ms_wait++) { 2089 msec_delay(1); 2090 rx_enabled = 0; 2091 for (i = 0; i < 4; i++) 2092 rx_enabled |= E1000_READ_REG(hw, E1000_RXDCTL(i)); 2093 if (!(rx_enabled & E1000_RXDCTL_QUEUE_ENABLE)) 2094 break; 2095 } 2096 2097 if (ms_wait == 10) 2098 DEBUGOUT("Queue disable timed out after 10ms\n"); 2099 2100 /* Clear RLPML, RCTL.SBP, RFCTL.LEF, and set RCTL.LPE so that all 2101 * incoming packets are rejected. Set enable and wait 2ms so that 2102 * any packet that was coming in as RCTL.EN was set is flushed 2103 */ 2104 E1000_WRITE_REG(hw, E1000_RFCTL, rfctl & ~E1000_RFCTL_LEF); 2105 2106 rlpml = E1000_READ_REG(hw, E1000_RLPML); 2107 E1000_WRITE_REG(hw, E1000_RLPML, 0); 2108 2109 rctl = E1000_READ_REG(hw, E1000_RCTL); 2110 temp_rctl = rctl & ~(E1000_RCTL_EN | E1000_RCTL_SBP); 2111 temp_rctl |= E1000_RCTL_LPE; 2112 2113 E1000_WRITE_REG(hw, E1000_RCTL, temp_rctl); 2114 E1000_WRITE_REG(hw, E1000_RCTL, temp_rctl | E1000_RCTL_EN); 2115 E1000_WRITE_FLUSH(hw); 2116 msec_delay(2); 2117 2118 /* Enable Rx queues that were previously enabled and restore our 2119 * previous state 2120 */ 2121 for (i = 0; i < 4; i++) 2122 E1000_WRITE_REG(hw, E1000_RXDCTL(i), rxdctl[i]); 2123 E1000_WRITE_REG(hw, E1000_RCTL, rctl); 2124 E1000_WRITE_FLUSH(hw); 2125 2126 E1000_WRITE_REG(hw, E1000_RLPML, rlpml); 2127 E1000_WRITE_REG(hw, E1000_RFCTL, rfctl); 2128 2129 /* Flush receive errors generated by workaround */ 2130 E1000_READ_REG(hw, E1000_ROC); 2131 E1000_READ_REG(hw, E1000_RNBC); 2132 E1000_READ_REG(hw, E1000_MPC); 2133 } 2134 2135 /** 2136 * e1000_set_pcie_completion_timeout - set pci-e completion timeout 2137 * @hw: pointer to the HW structure 2138 * 2139 * The defaults for 82575 and 82576 should be in the range of 50us to 50ms, 2140 * however the hardware default for these parts is 500us to 1ms which is less 2141 * than the 10ms recommended by the pci-e spec. To address this we need to 2142 * increase the value to either 10ms to 200ms for capability version 1 config, 2143 * or 16ms to 55ms for version 2. 2144 **/ 2145 static s32 e1000_set_pcie_completion_timeout(struct e1000_hw *hw) 2146 { 2147 u32 gcr = E1000_READ_REG(hw, E1000_GCR); 2148 s32 ret_val = E1000_SUCCESS; 2149 u16 pcie_devctl2; 2150 2151 /* only take action if timeout value is defaulted to 0 */ 2152 if (gcr & E1000_GCR_CMPL_TMOUT_MASK) 2153 goto out; 2154 2155 /* 2156 * if capababilities version is type 1 we can write the 2157 * timeout of 10ms to 200ms through the GCR register 2158 */ 2159 if (!(gcr & E1000_GCR_CAP_VER2)) { 2160 gcr |= E1000_GCR_CMPL_TMOUT_10ms; 2161 goto out; 2162 } 2163 2164 /* 2165 * for version 2 capabilities we need to write the config space 2166 * directly in order to set the completion timeout value for 2167 * 16ms to 55ms 2168 */ 2169 ret_val = e1000_read_pcie_cap_reg(hw, PCIE_DEVICE_CONTROL2, 2170 &pcie_devctl2); 2171 if (ret_val) 2172 goto out; 2173 2174 pcie_devctl2 |= PCIE_DEVICE_CONTROL2_16ms; 2175 2176 ret_val = e1000_write_pcie_cap_reg(hw, PCIE_DEVICE_CONTROL2, 2177 &pcie_devctl2); 2178 out: 2179 /* disable completion timeout resend */ 2180 gcr &= ~E1000_GCR_CMPL_TMOUT_RESEND; 2181 2182 E1000_WRITE_REG(hw, E1000_GCR, gcr); 2183 return ret_val; 2184 } 2185 2186 /** 2187 * e1000_vmdq_set_anti_spoofing_pf - enable or disable anti-spoofing 2188 * @hw: pointer to the hardware struct 2189 * @enable: state to enter, either enabled or disabled 2190 * @pf: Physical Function pool - do not set anti-spoofing for the PF 2191 * 2192 * enables/disables L2 switch anti-spoofing functionality. 2193 **/ 2194 void e1000_vmdq_set_anti_spoofing_pf(struct e1000_hw *hw, bool enable, int pf) 2195 { 2196 u32 reg_val, reg_offset; 2197 2198 switch (hw->mac.type) { 2199 case e1000_82576: 2200 reg_offset = E1000_DTXSWC; 2201 break; 2202 case e1000_i350: 2203 case e1000_i354: 2204 reg_offset = E1000_TXSWC; 2205 break; 2206 default: 2207 return; 2208 } 2209 2210 reg_val = E1000_READ_REG(hw, reg_offset); 2211 if (enable) { 2212 reg_val |= (E1000_DTXSWC_MAC_SPOOF_MASK | 2213 E1000_DTXSWC_VLAN_SPOOF_MASK); 2214 /* The PF can spoof - it has to in order to 2215 * support emulation mode NICs 2216 */ 2217 reg_val ^= (1 << pf | 1 << (pf + MAX_NUM_VFS)); 2218 } else { 2219 reg_val &= ~(E1000_DTXSWC_MAC_SPOOF_MASK | 2220 E1000_DTXSWC_VLAN_SPOOF_MASK); 2221 } 2222 E1000_WRITE_REG(hw, reg_offset, reg_val); 2223 } 2224 2225 /** 2226 * e1000_vmdq_set_loopback_pf - enable or disable vmdq loopback 2227 * @hw: pointer to the hardware struct 2228 * @enable: state to enter, either enabled or disabled 2229 * 2230 * enables/disables L2 switch loopback functionality. 2231 **/ 2232 void e1000_vmdq_set_loopback_pf(struct e1000_hw *hw, bool enable) 2233 { 2234 u32 dtxswc; 2235 2236 switch (hw->mac.type) { 2237 case e1000_82576: 2238 dtxswc = E1000_READ_REG(hw, E1000_DTXSWC); 2239 if (enable) 2240 dtxswc |= E1000_DTXSWC_VMDQ_LOOPBACK_EN; 2241 else 2242 dtxswc &= ~E1000_DTXSWC_VMDQ_LOOPBACK_EN; 2243 E1000_WRITE_REG(hw, E1000_DTXSWC, dtxswc); 2244 break; 2245 case e1000_i350: 2246 case e1000_i354: 2247 dtxswc = E1000_READ_REG(hw, E1000_TXSWC); 2248 if (enable) 2249 dtxswc |= E1000_DTXSWC_VMDQ_LOOPBACK_EN; 2250 else 2251 dtxswc &= ~E1000_DTXSWC_VMDQ_LOOPBACK_EN; 2252 E1000_WRITE_REG(hw, E1000_TXSWC, dtxswc); 2253 break; 2254 default: 2255 /* Currently no other hardware supports loopback */ 2256 break; 2257 } 2258 2259 2260 } 2261 2262 /** 2263 * e1000_vmdq_set_replication_pf - enable or disable vmdq replication 2264 * @hw: pointer to the hardware struct 2265 * @enable: state to enter, either enabled or disabled 2266 * 2267 * enables/disables replication of packets across multiple pools. 2268 **/ 2269 void e1000_vmdq_set_replication_pf(struct e1000_hw *hw, bool enable) 2270 { 2271 u32 vt_ctl = E1000_READ_REG(hw, E1000_VT_CTL); 2272 2273 if (enable) 2274 vt_ctl |= E1000_VT_CTL_VM_REPL_EN; 2275 else 2276 vt_ctl &= ~E1000_VT_CTL_VM_REPL_EN; 2277 2278 E1000_WRITE_REG(hw, E1000_VT_CTL, vt_ctl); 2279 } 2280 2281 /** 2282 * e1000_read_phy_reg_82580 - Read 82580 MDI control register 2283 * @hw: pointer to the HW structure 2284 * @offset: register offset to be read 2285 * @data: pointer to the read data 2286 * 2287 * Reads the MDI control register in the PHY at offset and stores the 2288 * information read to data. 2289 **/ 2290 static s32 e1000_read_phy_reg_82580(struct e1000_hw *hw, u32 offset, u16 *data) 2291 { 2292 s32 ret_val; 2293 2294 DEBUGFUNC("e1000_read_phy_reg_82580"); 2295 2296 ret_val = hw->phy.ops.acquire(hw); 2297 if (ret_val) 2298 goto out; 2299 2300 ret_val = e1000_read_phy_reg_mdic(hw, offset, data); 2301 2302 hw->phy.ops.release(hw); 2303 2304 out: 2305 return ret_val; 2306 } 2307 2308 /** 2309 * e1000_write_phy_reg_82580 - Write 82580 MDI control register 2310 * @hw: pointer to the HW structure 2311 * @offset: register offset to write to 2312 * @data: data to write to register at offset 2313 * 2314 * Writes data to MDI control register in the PHY at offset. 2315 **/ 2316 static s32 e1000_write_phy_reg_82580(struct e1000_hw *hw, u32 offset, u16 data) 2317 { 2318 s32 ret_val; 2319 2320 DEBUGFUNC("e1000_write_phy_reg_82580"); 2321 2322 ret_val = hw->phy.ops.acquire(hw); 2323 if (ret_val) 2324 goto out; 2325 2326 ret_val = e1000_write_phy_reg_mdic(hw, offset, data); 2327 2328 hw->phy.ops.release(hw); 2329 2330 out: 2331 return ret_val; 2332 } 2333 2334 /** 2335 * e1000_reset_mdicnfg_82580 - Reset MDICNFG destination and com_mdio bits 2336 * @hw: pointer to the HW structure 2337 * 2338 * This resets the MDICNFG.Destination and MDICNFG.Com_MDIO bits based on 2339 * the values found in the EEPROM. This addresses an issue in which these 2340 * bits are not restored from EEPROM after reset. 2341 **/ 2342 static s32 e1000_reset_mdicnfg_82580(struct e1000_hw *hw) 2343 { 2344 s32 ret_val = E1000_SUCCESS; 2345 u32 mdicnfg; 2346 u16 nvm_data = 0; 2347 2348 DEBUGFUNC("e1000_reset_mdicnfg_82580"); 2349 2350 if (hw->mac.type != e1000_82580) 2351 goto out; 2352 if (!e1000_sgmii_active_82575(hw)) 2353 goto out; 2354 2355 ret_val = hw->nvm.ops.read(hw, NVM_INIT_CONTROL3_PORT_A + 2356 NVM_82580_LAN_FUNC_OFFSET(hw->bus.func), 1, 2357 &nvm_data); 2358 if (ret_val) { 2359 DEBUGOUT("NVM Read Error\n"); 2360 goto out; 2361 } 2362 2363 mdicnfg = E1000_READ_REG(hw, E1000_MDICNFG); 2364 if (nvm_data & NVM_WORD24_EXT_MDIO) 2365 mdicnfg |= E1000_MDICNFG_EXT_MDIO; 2366 if (nvm_data & NVM_WORD24_COM_MDIO) 2367 mdicnfg |= E1000_MDICNFG_COM_MDIO; 2368 E1000_WRITE_REG(hw, E1000_MDICNFG, mdicnfg); 2369 out: 2370 return ret_val; 2371 } 2372 2373 /** 2374 * e1000_reset_hw_82580 - Reset hardware 2375 * @hw: pointer to the HW structure 2376 * 2377 * This resets function or entire device (all ports, etc.) 2378 * to a known state. 2379 **/ 2380 static s32 e1000_reset_hw_82580(struct e1000_hw *hw) 2381 { 2382 s32 ret_val = E1000_SUCCESS; 2383 /* BH SW mailbox bit in SW_FW_SYNC */ 2384 u16 swmbsw_mask = E1000_SW_SYNCH_MB; 2385 u32 ctrl; 2386 bool global_device_reset = hw->dev_spec._82575.global_device_reset; 2387 2388 DEBUGFUNC("e1000_reset_hw_82580"); 2389 2390 hw->dev_spec._82575.global_device_reset = FALSE; 2391 2392 /* 82580 does not reliably do global_device_reset due to hw errata */ 2393 if (hw->mac.type == e1000_82580) 2394 global_device_reset = FALSE; 2395 2396 /* Get current control state. */ 2397 ctrl = E1000_READ_REG(hw, E1000_CTRL); 2398 2399 /* 2400 * Prevent the PCI-E bus from sticking if there is no TLP connection 2401 * on the last TLP read/write transaction when MAC is reset. 2402 */ 2403 ret_val = e1000_disable_pcie_master_generic(hw); 2404 if (ret_val) 2405 DEBUGOUT("PCI-E Master disable polling has failed.\n"); 2406 2407 DEBUGOUT("Masking off all interrupts\n"); 2408 E1000_WRITE_REG(hw, E1000_IMC, 0xffffffff); 2409 E1000_WRITE_REG(hw, E1000_RCTL, 0); 2410 E1000_WRITE_REG(hw, E1000_TCTL, E1000_TCTL_PSP); 2411 E1000_WRITE_FLUSH(hw); 2412 2413 msec_delay(10); 2414 2415 /* Determine whether or not a global dev reset is requested */ 2416 if (global_device_reset && hw->mac.ops.acquire_swfw_sync(hw, 2417 swmbsw_mask)) 2418 global_device_reset = FALSE; 2419 2420 if (global_device_reset && !(E1000_READ_REG(hw, E1000_STATUS) & 2421 E1000_STAT_DEV_RST_SET)) 2422 ctrl |= E1000_CTRL_DEV_RST; 2423 else 2424 ctrl |= E1000_CTRL_RST; 2425 2426 E1000_WRITE_REG(hw, E1000_CTRL, ctrl); 2427 2428 switch (hw->device_id) { 2429 case E1000_DEV_ID_DH89XXCC_SGMII: 2430 break; 2431 default: 2432 E1000_WRITE_FLUSH(hw); 2433 break; 2434 } 2435 2436 /* Add delay to insure DEV_RST or RST has time to complete */ 2437 msec_delay(5); 2438 2439 ret_val = e1000_get_auto_rd_done_generic(hw); 2440 if (ret_val) { 2441 /* 2442 * When auto config read does not complete, do not 2443 * return with an error. This can happen in situations 2444 * where there is no eeprom and prevents getting link. 2445 */ 2446 DEBUGOUT("Auto Read Done did not complete\n"); 2447 } 2448 2449 /* clear global device reset status bit */ 2450 E1000_WRITE_REG(hw, E1000_STATUS, E1000_STAT_DEV_RST_SET); 2451 2452 /* Clear any pending interrupt events. */ 2453 E1000_WRITE_REG(hw, E1000_IMC, 0xffffffff); 2454 E1000_READ_REG(hw, E1000_ICR); 2455 2456 ret_val = e1000_reset_mdicnfg_82580(hw); 2457 if (ret_val) 2458 DEBUGOUT("Could not reset MDICNFG based on EEPROM\n"); 2459 2460 /* Install any alternate MAC address into RAR0 */ 2461 ret_val = e1000_check_alt_mac_addr_generic(hw); 2462 2463 /* Release semaphore */ 2464 if (global_device_reset) 2465 hw->mac.ops.release_swfw_sync(hw, swmbsw_mask); 2466 2467 return ret_val; 2468 } 2469 2470 /** 2471 * e1000_rxpbs_adjust_82580 - adjust RXPBS value to reflect actual Rx PBA size 2472 * @data: data received by reading RXPBS register 2473 * 2474 * The 82580 uses a table based approach for packet buffer allocation sizes. 2475 * This function converts the retrieved value into the correct table value 2476 * 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 2477 * 0x0 36 72 144 1 2 4 8 16 2478 * 0x8 35 70 140 rsv rsv rsv rsv rsv 2479 */ 2480 u16 e1000_rxpbs_adjust_82580(u32 data) 2481 { 2482 u16 ret_val = 0; 2483 2484 if (data < E1000_82580_RXPBS_TABLE_SIZE) 2485 ret_val = e1000_82580_rxpbs_table[data]; 2486 2487 return ret_val; 2488 } 2489 2490 /** 2491 * e1000_validate_nvm_checksum_with_offset - Validate EEPROM 2492 * checksum 2493 * @hw: pointer to the HW structure 2494 * @offset: offset in words of the checksum protected region 2495 * 2496 * Calculates the EEPROM checksum by reading/adding each word of the EEPROM 2497 * and then verifies that the sum of the EEPROM is equal to 0xBABA. 2498 **/ 2499 s32 e1000_validate_nvm_checksum_with_offset(struct e1000_hw *hw, u16 offset) 2500 { 2501 s32 ret_val = E1000_SUCCESS; 2502 u16 checksum = 0; 2503 u16 i, nvm_data; 2504 2505 DEBUGFUNC("e1000_validate_nvm_checksum_with_offset"); 2506 2507 for (i = offset; i < ((NVM_CHECKSUM_REG + offset) + 1); i++) { 2508 ret_val = hw->nvm.ops.read(hw, i, 1, &nvm_data); 2509 if (ret_val) { 2510 DEBUGOUT("NVM Read Error\n"); 2511 goto out; 2512 } 2513 checksum += nvm_data; 2514 } 2515 2516 if (checksum != (u16) NVM_SUM) { 2517 DEBUGOUT("NVM Checksum Invalid\n"); 2518 ret_val = -E1000_ERR_NVM; 2519 goto out; 2520 } 2521 2522 out: 2523 return ret_val; 2524 } 2525 2526 /** 2527 * e1000_update_nvm_checksum_with_offset - Update EEPROM 2528 * checksum 2529 * @hw: pointer to the HW structure 2530 * @offset: offset in words of the checksum protected region 2531 * 2532 * Updates the EEPROM checksum by reading/adding each word of the EEPROM 2533 * up to the checksum. Then calculates the EEPROM checksum and writes the 2534 * value to the EEPROM. 2535 **/ 2536 s32 e1000_update_nvm_checksum_with_offset(struct e1000_hw *hw, u16 offset) 2537 { 2538 s32 ret_val; 2539 u16 checksum = 0; 2540 u16 i, nvm_data; 2541 2542 DEBUGFUNC("e1000_update_nvm_checksum_with_offset"); 2543 2544 for (i = offset; i < (NVM_CHECKSUM_REG + offset); i++) { 2545 ret_val = hw->nvm.ops.read(hw, i, 1, &nvm_data); 2546 if (ret_val) { 2547 DEBUGOUT("NVM Read Error while updating checksum.\n"); 2548 goto out; 2549 } 2550 checksum += nvm_data; 2551 } 2552 checksum = (u16) NVM_SUM - checksum; 2553 ret_val = hw->nvm.ops.write(hw, (NVM_CHECKSUM_REG + offset), 1, 2554 &checksum); 2555 if (ret_val) 2556 DEBUGOUT("NVM Write Error while updating checksum.\n"); 2557 2558 out: 2559 return ret_val; 2560 } 2561 2562 /** 2563 * e1000_validate_nvm_checksum_82580 - Validate EEPROM checksum 2564 * @hw: pointer to the HW structure 2565 * 2566 * Calculates the EEPROM section checksum by reading/adding each word of 2567 * the EEPROM and then verifies that the sum of the EEPROM is 2568 * equal to 0xBABA. 2569 **/ 2570 static s32 e1000_validate_nvm_checksum_82580(struct e1000_hw *hw) 2571 { 2572 s32 ret_val; 2573 u16 eeprom_regions_count = 1; 2574 u16 j, nvm_data; 2575 u16 nvm_offset; 2576 2577 DEBUGFUNC("e1000_validate_nvm_checksum_82580"); 2578 2579 ret_val = hw->nvm.ops.read(hw, NVM_COMPATIBILITY_REG_3, 1, &nvm_data); 2580 if (ret_val) { 2581 DEBUGOUT("NVM Read Error\n"); 2582 goto out; 2583 } 2584 2585 if (nvm_data & NVM_COMPATIBILITY_BIT_MASK) { 2586 /* if chekcsums compatibility bit is set validate checksums 2587 * for all 4 ports. */ 2588 eeprom_regions_count = 4; 2589 } 2590 2591 for (j = 0; j < eeprom_regions_count; j++) { 2592 nvm_offset = NVM_82580_LAN_FUNC_OFFSET(j); 2593 ret_val = e1000_validate_nvm_checksum_with_offset(hw, 2594 nvm_offset); 2595 if (ret_val != E1000_SUCCESS) 2596 goto out; 2597 } 2598 2599 out: 2600 return ret_val; 2601 } 2602 2603 /** 2604 * e1000_update_nvm_checksum_82580 - Update EEPROM checksum 2605 * @hw: pointer to the HW structure 2606 * 2607 * Updates the EEPROM section checksums for all 4 ports by reading/adding 2608 * each word of the EEPROM up to the checksum. Then calculates the EEPROM 2609 * checksum and writes the value to the EEPROM. 2610 **/ 2611 static s32 e1000_update_nvm_checksum_82580(struct e1000_hw *hw) 2612 { 2613 s32 ret_val; 2614 u16 j, nvm_data; 2615 u16 nvm_offset; 2616 2617 DEBUGFUNC("e1000_update_nvm_checksum_82580"); 2618 2619 ret_val = hw->nvm.ops.read(hw, NVM_COMPATIBILITY_REG_3, 1, &nvm_data); 2620 if (ret_val) { 2621 DEBUGOUT("NVM Read Error while updating checksum compatibility bit.\n"); 2622 goto out; 2623 } 2624 2625 if (!(nvm_data & NVM_COMPATIBILITY_BIT_MASK)) { 2626 /* set compatibility bit to validate checksums appropriately */ 2627 nvm_data = nvm_data | NVM_COMPATIBILITY_BIT_MASK; 2628 ret_val = hw->nvm.ops.write(hw, NVM_COMPATIBILITY_REG_3, 1, 2629 &nvm_data); 2630 if (ret_val) { 2631 DEBUGOUT("NVM Write Error while updating checksum compatibility bit.\n"); 2632 goto out; 2633 } 2634 } 2635 2636 for (j = 0; j < 4; j++) { 2637 nvm_offset = NVM_82580_LAN_FUNC_OFFSET(j); 2638 ret_val = e1000_update_nvm_checksum_with_offset(hw, nvm_offset); 2639 if (ret_val) 2640 goto out; 2641 } 2642 2643 out: 2644 return ret_val; 2645 } 2646 2647 /** 2648 * e1000_validate_nvm_checksum_i350 - Validate EEPROM checksum 2649 * @hw: pointer to the HW structure 2650 * 2651 * Calculates the EEPROM section checksum by reading/adding each word of 2652 * the EEPROM and then verifies that the sum of the EEPROM is 2653 * equal to 0xBABA. 2654 **/ 2655 static s32 e1000_validate_nvm_checksum_i350(struct e1000_hw *hw) 2656 { 2657 s32 ret_val = E1000_SUCCESS; 2658 u16 j; 2659 u16 nvm_offset; 2660 2661 DEBUGFUNC("e1000_validate_nvm_checksum_i350"); 2662 2663 for (j = 0; j < 4; j++) { 2664 nvm_offset = NVM_82580_LAN_FUNC_OFFSET(j); 2665 ret_val = e1000_validate_nvm_checksum_with_offset(hw, 2666 nvm_offset); 2667 if (ret_val != E1000_SUCCESS) 2668 goto out; 2669 } 2670 2671 out: 2672 return ret_val; 2673 } 2674 2675 /** 2676 * e1000_update_nvm_checksum_i350 - Update EEPROM checksum 2677 * @hw: pointer to the HW structure 2678 * 2679 * Updates the EEPROM section checksums for all 4 ports by reading/adding 2680 * each word of the EEPROM up to the checksum. Then calculates the EEPROM 2681 * checksum and writes the value to the EEPROM. 2682 **/ 2683 static s32 e1000_update_nvm_checksum_i350(struct e1000_hw *hw) 2684 { 2685 s32 ret_val = E1000_SUCCESS; 2686 u16 j; 2687 u16 nvm_offset; 2688 2689 DEBUGFUNC("e1000_update_nvm_checksum_i350"); 2690 2691 for (j = 0; j < 4; j++) { 2692 nvm_offset = NVM_82580_LAN_FUNC_OFFSET(j); 2693 ret_val = e1000_update_nvm_checksum_with_offset(hw, nvm_offset); 2694 if (ret_val != E1000_SUCCESS) 2695 goto out; 2696 } 2697 2698 out: 2699 return ret_val; 2700 } 2701 2702 /** 2703 * __e1000_access_emi_reg - Read/write EMI register 2704 * @hw: pointer to the HW structure 2705 * @addr: EMI address to program 2706 * @data: pointer to value to read/write from/to the EMI address 2707 * @read: boolean flag to indicate read or write 2708 **/ 2709 static s32 __e1000_access_emi_reg(struct e1000_hw *hw, u16 address, 2710 u16 *data, bool read) 2711 { 2712 s32 ret_val; 2713 2714 DEBUGFUNC("__e1000_access_emi_reg"); 2715 2716 ret_val = hw->phy.ops.write_reg(hw, E1000_EMIADD, address); 2717 if (ret_val) 2718 return ret_val; 2719 2720 if (read) 2721 ret_val = hw->phy.ops.read_reg(hw, E1000_EMIDATA, data); 2722 else 2723 ret_val = hw->phy.ops.write_reg(hw, E1000_EMIDATA, *data); 2724 2725 return ret_val; 2726 } 2727 2728 /** 2729 * e1000_read_emi_reg - Read Extended Management Interface register 2730 * @hw: pointer to the HW structure 2731 * @addr: EMI address to program 2732 * @data: value to be read from the EMI address 2733 **/ 2734 s32 e1000_read_emi_reg(struct e1000_hw *hw, u16 addr, u16 *data) 2735 { 2736 DEBUGFUNC("e1000_read_emi_reg"); 2737 2738 return __e1000_access_emi_reg(hw, addr, data, TRUE); 2739 } 2740 2741 /** 2742 * e1000_initialize_M88E1512_phy - Initialize M88E1512 PHY 2743 * @hw: pointer to the HW structure 2744 * 2745 * Initialize Marvell 1512 to work correctly with Avoton. 2746 **/ 2747 s32 e1000_initialize_M88E1512_phy(struct e1000_hw *hw) 2748 { 2749 struct e1000_phy_info *phy = &hw->phy; 2750 s32 ret_val = E1000_SUCCESS; 2751 2752 DEBUGFUNC("e1000_initialize_M88E1512_phy"); 2753 2754 /* Check if this is correct PHY. */ 2755 if (phy->id != M88E1512_E_PHY_ID) 2756 goto out; 2757 2758 /* Switch to PHY page 0xFF. */ 2759 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x00FF); 2760 if (ret_val) 2761 goto out; 2762 2763 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0x214B); 2764 if (ret_val) 2765 goto out; 2766 2767 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2144); 2768 if (ret_val) 2769 goto out; 2770 2771 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0x0C28); 2772 if (ret_val) 2773 goto out; 2774 2775 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2146); 2776 if (ret_val) 2777 goto out; 2778 2779 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0xB233); 2780 if (ret_val) 2781 goto out; 2782 2783 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x214D); 2784 if (ret_val) 2785 goto out; 2786 2787 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0xCC0C); 2788 if (ret_val) 2789 goto out; 2790 2791 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2159); 2792 if (ret_val) 2793 goto out; 2794 2795 /* Switch to PHY page 0xFB. */ 2796 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x00FB); 2797 if (ret_val) 2798 goto out; 2799 2800 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_3, 0x000D); 2801 if (ret_val) 2802 goto out; 2803 2804 /* Switch to PHY page 0x12. */ 2805 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x12); 2806 if (ret_val) 2807 goto out; 2808 2809 /* Change mode to SGMII-to-Copper */ 2810 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_MODE, 0x8001); 2811 if (ret_val) 2812 goto out; 2813 2814 /* Return the PHY to page 0. */ 2815 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0); 2816 if (ret_val) 2817 goto out; 2818 2819 ret_val = phy->ops.commit(hw); 2820 if (ret_val) { 2821 DEBUGOUT("Error committing the PHY changes\n"); 2822 return ret_val; 2823 } 2824 2825 msec_delay(1000); 2826 out: 2827 return ret_val; 2828 } 2829 2830 /** 2831 * e1000_initialize_M88E1543_phy - Initialize M88E1543 PHY 2832 * @hw: pointer to the HW structure 2833 * 2834 * Initialize Marvell 1543 to work correctly with Avoton. 2835 **/ 2836 s32 e1000_initialize_M88E1543_phy(struct e1000_hw *hw) 2837 { 2838 struct e1000_phy_info *phy = &hw->phy; 2839 s32 ret_val = E1000_SUCCESS; 2840 2841 DEBUGFUNC("e1000_initialize_M88E1543_phy"); 2842 2843 /* Check if this is correct PHY. */ 2844 if (phy->id != M88E1543_E_PHY_ID) 2845 goto out; 2846 2847 /* Switch to PHY page 0xFF. */ 2848 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x00FF); 2849 if (ret_val) 2850 goto out; 2851 2852 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0x214B); 2853 if (ret_val) 2854 goto out; 2855 2856 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2144); 2857 if (ret_val) 2858 goto out; 2859 2860 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0x0C28); 2861 if (ret_val) 2862 goto out; 2863 2864 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2146); 2865 if (ret_val) 2866 goto out; 2867 2868 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0xB233); 2869 if (ret_val) 2870 goto out; 2871 2872 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x214D); 2873 if (ret_val) 2874 goto out; 2875 2876 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_2, 0xDC0C); 2877 if (ret_val) 2878 goto out; 2879 2880 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_1, 0x2159); 2881 if (ret_val) 2882 goto out; 2883 2884 /* Switch to PHY page 0xFB. */ 2885 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x00FB); 2886 if (ret_val) 2887 goto out; 2888 2889 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_CFG_REG_3, 0xC00D); 2890 if (ret_val) 2891 goto out; 2892 2893 /* Switch to PHY page 0x12. */ 2894 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x12); 2895 if (ret_val) 2896 goto out; 2897 2898 /* Change mode to SGMII-to-Copper */ 2899 ret_val = phy->ops.write_reg(hw, E1000_M88E1512_MODE, 0x8001); 2900 if (ret_val) 2901 goto out; 2902 2903 /* Switch to PHY page 1. */ 2904 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0x1); 2905 if (ret_val) 2906 goto out; 2907 2908 /* Change mode to 1000BASE-X/SGMII and autoneg enable; reset */ 2909 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_FIBER_CTRL, 0x9140); 2910 if (ret_val) 2911 goto out; 2912 2913 /* Return the PHY to page 0. */ 2914 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0); 2915 if (ret_val) 2916 goto out; 2917 2918 ret_val = phy->ops.commit(hw); 2919 if (ret_val) { 2920 DEBUGOUT("Error committing the PHY changes\n"); 2921 return ret_val; 2922 } 2923 2924 msec_delay(1000); 2925 out: 2926 return ret_val; 2927 } 2928 2929 /** 2930 * e1000_set_eee_i350 - Enable/disable EEE support 2931 * @hw: pointer to the HW structure 2932 * @adv1g: boolean flag enabling 1G EEE advertisement 2933 * @adv100m: boolean flag enabling 100M EEE advertisement 2934 * 2935 * Enable/disable EEE based on setting in dev_spec structure. 2936 * 2937 **/ 2938 s32 e1000_set_eee_i350(struct e1000_hw *hw, bool adv1G, bool adv100M) 2939 { 2940 u32 ipcnfg, eeer; 2941 2942 DEBUGFUNC("e1000_set_eee_i350"); 2943 2944 if ((hw->mac.type < e1000_i350) || 2945 (hw->phy.media_type != e1000_media_type_copper)) 2946 goto out; 2947 ipcnfg = E1000_READ_REG(hw, E1000_IPCNFG); 2948 eeer = E1000_READ_REG(hw, E1000_EEER); 2949 2950 /* enable or disable per user setting */ 2951 if (!(hw->dev_spec._82575.eee_disable)) { 2952 u32 eee_su = E1000_READ_REG(hw, E1000_EEE_SU); 2953 2954 if (adv100M) 2955 ipcnfg |= E1000_IPCNFG_EEE_100M_AN; 2956 else 2957 ipcnfg &= ~E1000_IPCNFG_EEE_100M_AN; 2958 2959 if (adv1G) 2960 ipcnfg |= E1000_IPCNFG_EEE_1G_AN; 2961 else 2962 ipcnfg &= ~E1000_IPCNFG_EEE_1G_AN; 2963 2964 eeer |= (E1000_EEER_TX_LPI_EN | E1000_EEER_RX_LPI_EN | 2965 E1000_EEER_LPI_FC); 2966 2967 /* This bit should not be set in normal operation. */ 2968 if (eee_su & E1000_EEE_SU_LPI_CLK_STP) 2969 DEBUGOUT("LPI Clock Stop Bit should not be set!\n"); 2970 } else { 2971 ipcnfg &= ~(E1000_IPCNFG_EEE_1G_AN | E1000_IPCNFG_EEE_100M_AN); 2972 eeer &= ~(E1000_EEER_TX_LPI_EN | E1000_EEER_RX_LPI_EN | 2973 E1000_EEER_LPI_FC); 2974 } 2975 E1000_WRITE_REG(hw, E1000_IPCNFG, ipcnfg); 2976 E1000_WRITE_REG(hw, E1000_EEER, eeer); 2977 E1000_READ_REG(hw, E1000_IPCNFG); 2978 E1000_READ_REG(hw, E1000_EEER); 2979 out: 2980 2981 return E1000_SUCCESS; 2982 } 2983 2984 /** 2985 * e1000_set_eee_i354 - Enable/disable EEE support 2986 * @hw: pointer to the HW structure 2987 * @adv1g: boolean flag enabling 1G EEE advertisement 2988 * @adv100m: boolean flag enabling 100M EEE advertisement 2989 * 2990 * Enable/disable EEE legacy mode based on setting in dev_spec structure. 2991 * 2992 **/ 2993 s32 e1000_set_eee_i354(struct e1000_hw *hw, bool adv1G, bool adv100M) 2994 { 2995 struct e1000_phy_info *phy = &hw->phy; 2996 s32 ret_val = E1000_SUCCESS; 2997 u16 phy_data; 2998 2999 DEBUGFUNC("e1000_set_eee_i354"); 3000 3001 if ((hw->phy.media_type != e1000_media_type_copper) || 3002 ((phy->id != M88E1543_E_PHY_ID) && 3003 (phy->id != M88E1512_E_PHY_ID))) 3004 goto out; 3005 3006 if (!hw->dev_spec._82575.eee_disable) { 3007 /* Switch to PHY page 18. */ 3008 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 18); 3009 if (ret_val) 3010 goto out; 3011 3012 ret_val = phy->ops.read_reg(hw, E1000_M88E1543_EEE_CTRL_1, 3013 &phy_data); 3014 if (ret_val) 3015 goto out; 3016 3017 phy_data |= E1000_M88E1543_EEE_CTRL_1_MS; 3018 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_EEE_CTRL_1, 3019 phy_data); 3020 if (ret_val) 3021 goto out; 3022 3023 /* Return the PHY to page 0. */ 3024 ret_val = phy->ops.write_reg(hw, E1000_M88E1543_PAGE_ADDR, 0); 3025 if (ret_val) 3026 goto out; 3027 3028 /* Turn on EEE advertisement. */ 3029 ret_val = e1000_read_xmdio_reg(hw, E1000_EEE_ADV_ADDR_I354, 3030 E1000_EEE_ADV_DEV_I354, 3031 &phy_data); 3032 if (ret_val) 3033 goto out; 3034 3035 if (adv100M) 3036 phy_data |= E1000_EEE_ADV_100_SUPPORTED; 3037 else 3038 phy_data &= ~E1000_EEE_ADV_100_SUPPORTED; 3039 3040 if (adv1G) 3041 phy_data |= E1000_EEE_ADV_1000_SUPPORTED; 3042 else 3043 phy_data &= ~E1000_EEE_ADV_1000_SUPPORTED; 3044 3045 ret_val = e1000_write_xmdio_reg(hw, E1000_EEE_ADV_ADDR_I354, 3046 E1000_EEE_ADV_DEV_I354, 3047 phy_data); 3048 } else { 3049 /* Turn off EEE advertisement. */ 3050 ret_val = e1000_read_xmdio_reg(hw, E1000_EEE_ADV_ADDR_I354, 3051 E1000_EEE_ADV_DEV_I354, 3052 &phy_data); 3053 if (ret_val) 3054 goto out; 3055 3056 phy_data &= ~(E1000_EEE_ADV_100_SUPPORTED | 3057 E1000_EEE_ADV_1000_SUPPORTED); 3058 ret_val = e1000_write_xmdio_reg(hw, E1000_EEE_ADV_ADDR_I354, 3059 E1000_EEE_ADV_DEV_I354, 3060 phy_data); 3061 } 3062 3063 out: 3064 return ret_val; 3065 } 3066 3067 /** 3068 * e1000_get_eee_status_i354 - Get EEE status 3069 * @hw: pointer to the HW structure 3070 * @status: EEE status 3071 * 3072 * Get EEE status by guessing based on whether Tx or Rx LPI indications have 3073 * been received. 3074 **/ 3075 s32 e1000_get_eee_status_i354(struct e1000_hw *hw, bool *status) 3076 { 3077 struct e1000_phy_info *phy = &hw->phy; 3078 s32 ret_val = E1000_SUCCESS; 3079 u16 phy_data; 3080 3081 DEBUGFUNC("e1000_get_eee_status_i354"); 3082 3083 /* Check if EEE is supported on this device. */ 3084 if ((hw->phy.media_type != e1000_media_type_copper) || 3085 ((phy->id != M88E1543_E_PHY_ID) && 3086 (phy->id != M88E1512_E_PHY_ID))) 3087 goto out; 3088 3089 ret_val = e1000_read_xmdio_reg(hw, E1000_PCS_STATUS_ADDR_I354, 3090 E1000_PCS_STATUS_DEV_I354, 3091 &phy_data); 3092 if (ret_val) 3093 goto out; 3094 3095 *status = phy_data & (E1000_PCS_STATUS_TX_LPI_RCVD | 3096 E1000_PCS_STATUS_RX_LPI_RCVD) ? TRUE : FALSE; 3097 3098 out: 3099 return ret_val; 3100 } 3101 3102 /* Due to a hw errata, if the host tries to configure the VFTA register 3103 * while performing queries from the BMC or DMA, then the VFTA in some 3104 * cases won't be written. 3105 */ 3106 3107 /** 3108 * e1000_clear_vfta_i350 - Clear VLAN filter table 3109 * @hw: pointer to the HW structure 3110 * 3111 * Clears the register array which contains the VLAN filter table by 3112 * setting all the values to 0. 3113 **/ 3114 void e1000_clear_vfta_i350(struct e1000_hw *hw) 3115 { 3116 u32 offset; 3117 int i; 3118 3119 DEBUGFUNC("e1000_clear_vfta_350"); 3120 3121 for (offset = 0; offset < E1000_VLAN_FILTER_TBL_SIZE; offset++) { 3122 for (i = 0; i < 10; i++) 3123 E1000_WRITE_REG_ARRAY(hw, E1000_VFTA, offset, 0); 3124 3125 E1000_WRITE_FLUSH(hw); 3126 } 3127 } 3128 3129 /** 3130 * e1000_write_vfta_i350 - Write value to VLAN filter table 3131 * @hw: pointer to the HW structure 3132 * @offset: register offset in VLAN filter table 3133 * @value: register value written to VLAN filter table 3134 * 3135 * Writes value at the given offset in the register array which stores 3136 * the VLAN filter table. 3137 **/ 3138 void e1000_write_vfta_i350(struct e1000_hw *hw, u32 offset, u32 value) 3139 { 3140 int i; 3141 3142 DEBUGFUNC("e1000_write_vfta_350"); 3143 3144 for (i = 0; i < 10; i++) 3145 E1000_WRITE_REG_ARRAY(hw, E1000_VFTA, offset, value); 3146 3147 E1000_WRITE_FLUSH(hw); 3148 } 3149 3150 3151 /** 3152 * e1000_set_i2c_bb - Enable I2C bit-bang 3153 * @hw: pointer to the HW structure 3154 * 3155 * Enable I2C bit-bang interface 3156 * 3157 **/ 3158 s32 e1000_set_i2c_bb(struct e1000_hw *hw) 3159 { 3160 s32 ret_val = E1000_SUCCESS; 3161 u32 ctrl_ext, i2cparams; 3162 3163 DEBUGFUNC("e1000_set_i2c_bb"); 3164 3165 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT); 3166 ctrl_ext |= E1000_CTRL_I2C_ENA; 3167 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext); 3168 E1000_WRITE_FLUSH(hw); 3169 3170 i2cparams = E1000_READ_REG(hw, E1000_I2CPARAMS); 3171 i2cparams |= E1000_I2CBB_EN; 3172 i2cparams |= E1000_I2C_DATA_OE_N; 3173 i2cparams |= E1000_I2C_CLK_OE_N; 3174 E1000_WRITE_REG(hw, E1000_I2CPARAMS, i2cparams); 3175 E1000_WRITE_FLUSH(hw); 3176 3177 return ret_val; 3178 } 3179 3180 /** 3181 * e1000_read_i2c_byte_generic - Reads 8 bit word over I2C 3182 * @hw: pointer to hardware structure 3183 * @byte_offset: byte offset to read 3184 * @dev_addr: device address 3185 * @data: value read 3186 * 3187 * Performs byte read operation over I2C interface at 3188 * a specified device address. 3189 **/ 3190 s32 e1000_read_i2c_byte_generic(struct e1000_hw *hw, u8 byte_offset, 3191 u8 dev_addr, u8 *data) 3192 { 3193 s32 status = E1000_SUCCESS; 3194 u32 max_retry = 10; 3195 u32 retry = 1; 3196 u16 swfw_mask = 0; 3197 3198 bool nack = TRUE; 3199 3200 DEBUGFUNC("e1000_read_i2c_byte_generic"); 3201 3202 swfw_mask = E1000_SWFW_PHY0_SM; 3203 3204 do { 3205 if (hw->mac.ops.acquire_swfw_sync(hw, swfw_mask) 3206 != E1000_SUCCESS) { 3207 status = E1000_ERR_SWFW_SYNC; 3208 goto read_byte_out; 3209 } 3210 3211 e1000_i2c_start(hw); 3212 3213 /* Device Address and write indication */ 3214 status = e1000_clock_out_i2c_byte(hw, dev_addr); 3215 if (status != E1000_SUCCESS) 3216 goto fail; 3217 3218 status = e1000_get_i2c_ack(hw); 3219 if (status != E1000_SUCCESS) 3220 goto fail; 3221 3222 status = e1000_clock_out_i2c_byte(hw, byte_offset); 3223 if (status != E1000_SUCCESS) 3224 goto fail; 3225 3226 status = e1000_get_i2c_ack(hw); 3227 if (status != E1000_SUCCESS) 3228 goto fail; 3229 3230 e1000_i2c_start(hw); 3231 3232 /* Device Address and read indication */ 3233 status = e1000_clock_out_i2c_byte(hw, (dev_addr | 0x1)); 3234 if (status != E1000_SUCCESS) 3235 goto fail; 3236 3237 status = e1000_get_i2c_ack(hw); 3238 if (status != E1000_SUCCESS) 3239 goto fail; 3240 3241 status = e1000_clock_in_i2c_byte(hw, data); 3242 if (status != E1000_SUCCESS) 3243 goto fail; 3244 3245 status = e1000_clock_out_i2c_bit(hw, nack); 3246 if (status != E1000_SUCCESS) 3247 goto fail; 3248 3249 e1000_i2c_stop(hw); 3250 break; 3251 3252 fail: 3253 hw->mac.ops.release_swfw_sync(hw, swfw_mask); 3254 msec_delay(100); 3255 e1000_i2c_bus_clear(hw); 3256 retry++; 3257 if (retry < max_retry) 3258 DEBUGOUT("I2C byte read error - Retrying.\n"); 3259 else 3260 DEBUGOUT("I2C byte read error.\n"); 3261 3262 } while (retry < max_retry); 3263 3264 hw->mac.ops.release_swfw_sync(hw, swfw_mask); 3265 3266 read_byte_out: 3267 3268 return status; 3269 } 3270 3271 /** 3272 * e1000_write_i2c_byte_generic - Writes 8 bit word over I2C 3273 * @hw: pointer to hardware structure 3274 * @byte_offset: byte offset to write 3275 * @dev_addr: device address 3276 * @data: value to write 3277 * 3278 * Performs byte write operation over I2C interface at 3279 * a specified device address. 3280 **/ 3281 s32 e1000_write_i2c_byte_generic(struct e1000_hw *hw, u8 byte_offset, 3282 u8 dev_addr, u8 data) 3283 { 3284 s32 status = E1000_SUCCESS; 3285 u32 max_retry = 1; 3286 u32 retry = 0; 3287 u16 swfw_mask = 0; 3288 3289 DEBUGFUNC("e1000_write_i2c_byte_generic"); 3290 3291 swfw_mask = E1000_SWFW_PHY0_SM; 3292 3293 if (hw->mac.ops.acquire_swfw_sync(hw, swfw_mask) != E1000_SUCCESS) { 3294 status = E1000_ERR_SWFW_SYNC; 3295 goto write_byte_out; 3296 } 3297 3298 do { 3299 e1000_i2c_start(hw); 3300 3301 status = e1000_clock_out_i2c_byte(hw, dev_addr); 3302 if (status != E1000_SUCCESS) 3303 goto fail; 3304 3305 status = e1000_get_i2c_ack(hw); 3306 if (status != E1000_SUCCESS) 3307 goto fail; 3308 3309 status = e1000_clock_out_i2c_byte(hw, byte_offset); 3310 if (status != E1000_SUCCESS) 3311 goto fail; 3312 3313 status = e1000_get_i2c_ack(hw); 3314 if (status != E1000_SUCCESS) 3315 goto fail; 3316 3317 status = e1000_clock_out_i2c_byte(hw, data); 3318 if (status != E1000_SUCCESS) 3319 goto fail; 3320 3321 status = e1000_get_i2c_ack(hw); 3322 if (status != E1000_SUCCESS) 3323 goto fail; 3324 3325 e1000_i2c_stop(hw); 3326 break; 3327 3328 fail: 3329 e1000_i2c_bus_clear(hw); 3330 retry++; 3331 if (retry < max_retry) 3332 DEBUGOUT("I2C byte write error - Retrying.\n"); 3333 else 3334 DEBUGOUT("I2C byte write error.\n"); 3335 } while (retry < max_retry); 3336 3337 hw->mac.ops.release_swfw_sync(hw, swfw_mask); 3338 3339 write_byte_out: 3340 3341 return status; 3342 } 3343 3344 /** 3345 * e1000_i2c_start - Sets I2C start condition 3346 * @hw: pointer to hardware structure 3347 * 3348 * Sets I2C start condition (High -> Low on SDA while SCL is High) 3349 **/ 3350 static void e1000_i2c_start(struct e1000_hw *hw) 3351 { 3352 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3353 3354 DEBUGFUNC("e1000_i2c_start"); 3355 3356 /* Start condition must begin with data and clock high */ 3357 e1000_set_i2c_data(hw, &i2cctl, 1); 3358 e1000_raise_i2c_clk(hw, &i2cctl); 3359 3360 /* Setup time for start condition (4.7us) */ 3361 usec_delay(E1000_I2C_T_SU_STA); 3362 3363 e1000_set_i2c_data(hw, &i2cctl, 0); 3364 3365 /* Hold time for start condition (4us) */ 3366 usec_delay(E1000_I2C_T_HD_STA); 3367 3368 e1000_lower_i2c_clk(hw, &i2cctl); 3369 3370 /* Minimum low period of clock is 4.7 us */ 3371 usec_delay(E1000_I2C_T_LOW); 3372 3373 } 3374 3375 /** 3376 * e1000_i2c_stop - Sets I2C stop condition 3377 * @hw: pointer to hardware structure 3378 * 3379 * Sets I2C stop condition (Low -> High on SDA while SCL is High) 3380 **/ 3381 static void e1000_i2c_stop(struct e1000_hw *hw) 3382 { 3383 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3384 3385 DEBUGFUNC("e1000_i2c_stop"); 3386 3387 /* Stop condition must begin with data low and clock high */ 3388 e1000_set_i2c_data(hw, &i2cctl, 0); 3389 e1000_raise_i2c_clk(hw, &i2cctl); 3390 3391 /* Setup time for stop condition (4us) */ 3392 usec_delay(E1000_I2C_T_SU_STO); 3393 3394 e1000_set_i2c_data(hw, &i2cctl, 1); 3395 3396 /* bus free time between stop and start (4.7us)*/ 3397 usec_delay(E1000_I2C_T_BUF); 3398 } 3399 3400 /** 3401 * e1000_clock_in_i2c_byte - Clocks in one byte via I2C 3402 * @hw: pointer to hardware structure 3403 * @data: data byte to clock in 3404 * 3405 * Clocks in one byte data via I2C data/clock 3406 **/ 3407 static s32 e1000_clock_in_i2c_byte(struct e1000_hw *hw, u8 *data) 3408 { 3409 s32 i; 3410 bool bit = 0; 3411 3412 DEBUGFUNC("e1000_clock_in_i2c_byte"); 3413 3414 *data = 0; 3415 for (i = 7; i >= 0; i--) { 3416 e1000_clock_in_i2c_bit(hw, &bit); 3417 *data |= bit << i; 3418 } 3419 3420 return E1000_SUCCESS; 3421 } 3422 3423 /** 3424 * e1000_clock_out_i2c_byte - Clocks out one byte via I2C 3425 * @hw: pointer to hardware structure 3426 * @data: data byte clocked out 3427 * 3428 * Clocks out one byte data via I2C data/clock 3429 **/ 3430 static s32 e1000_clock_out_i2c_byte(struct e1000_hw *hw, u8 data) 3431 { 3432 s32 status = E1000_SUCCESS; 3433 s32 i; 3434 u32 i2cctl; 3435 bool bit = 0; 3436 3437 DEBUGFUNC("e1000_clock_out_i2c_byte"); 3438 3439 for (i = 7; i >= 0; i--) { 3440 bit = (data >> i) & 0x1; 3441 status = e1000_clock_out_i2c_bit(hw, bit); 3442 3443 if (status != E1000_SUCCESS) 3444 break; 3445 } 3446 3447 /* Release SDA line (set high) */ 3448 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3449 3450 i2cctl |= E1000_I2C_DATA_OE_N; 3451 E1000_WRITE_REG(hw, E1000_I2CPARAMS, i2cctl); 3452 E1000_WRITE_FLUSH(hw); 3453 3454 return status; 3455 } 3456 3457 /** 3458 * e1000_get_i2c_ack - Polls for I2C ACK 3459 * @hw: pointer to hardware structure 3460 * 3461 * Clocks in/out one bit via I2C data/clock 3462 **/ 3463 static s32 e1000_get_i2c_ack(struct e1000_hw *hw) 3464 { 3465 s32 status = E1000_SUCCESS; 3466 u32 i = 0; 3467 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3468 u32 timeout = 10; 3469 bool ack = TRUE; 3470 3471 DEBUGFUNC("e1000_get_i2c_ack"); 3472 3473 e1000_raise_i2c_clk(hw, &i2cctl); 3474 3475 /* Minimum high period of clock is 4us */ 3476 usec_delay(E1000_I2C_T_HIGH); 3477 3478 /* Wait until SCL returns high */ 3479 for (i = 0; i < timeout; i++) { 3480 usec_delay(1); 3481 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3482 if (i2cctl & E1000_I2C_CLK_IN) 3483 break; 3484 } 3485 if (!(i2cctl & E1000_I2C_CLK_IN)) 3486 return E1000_ERR_I2C; 3487 3488 ack = e1000_get_i2c_data(&i2cctl); 3489 if (ack) { 3490 DEBUGOUT("I2C ack was not received.\n"); 3491 status = E1000_ERR_I2C; 3492 } 3493 3494 e1000_lower_i2c_clk(hw, &i2cctl); 3495 3496 /* Minimum low period of clock is 4.7 us */ 3497 usec_delay(E1000_I2C_T_LOW); 3498 3499 return status; 3500 } 3501 3502 /** 3503 * e1000_clock_in_i2c_bit - Clocks in one bit via I2C data/clock 3504 * @hw: pointer to hardware structure 3505 * @data: read data value 3506 * 3507 * Clocks in one bit via I2C data/clock 3508 **/ 3509 static s32 e1000_clock_in_i2c_bit(struct e1000_hw *hw, bool *data) 3510 { 3511 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3512 3513 DEBUGFUNC("e1000_clock_in_i2c_bit"); 3514 3515 e1000_raise_i2c_clk(hw, &i2cctl); 3516 3517 /* Minimum high period of clock is 4us */ 3518 usec_delay(E1000_I2C_T_HIGH); 3519 3520 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3521 *data = e1000_get_i2c_data(&i2cctl); 3522 3523 e1000_lower_i2c_clk(hw, &i2cctl); 3524 3525 /* Minimum low period of clock is 4.7 us */ 3526 usec_delay(E1000_I2C_T_LOW); 3527 3528 return E1000_SUCCESS; 3529 } 3530 3531 /** 3532 * e1000_clock_out_i2c_bit - Clocks in/out one bit via I2C data/clock 3533 * @hw: pointer to hardware structure 3534 * @data: data value to write 3535 * 3536 * Clocks out one bit via I2C data/clock 3537 **/ 3538 static s32 e1000_clock_out_i2c_bit(struct e1000_hw *hw, bool data) 3539 { 3540 s32 status; 3541 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3542 3543 DEBUGFUNC("e1000_clock_out_i2c_bit"); 3544 3545 status = e1000_set_i2c_data(hw, &i2cctl, data); 3546 if (status == E1000_SUCCESS) { 3547 e1000_raise_i2c_clk(hw, &i2cctl); 3548 3549 /* Minimum high period of clock is 4us */ 3550 usec_delay(E1000_I2C_T_HIGH); 3551 3552 e1000_lower_i2c_clk(hw, &i2cctl); 3553 3554 /* Minimum low period of clock is 4.7 us. 3555 * This also takes care of the data hold time. 3556 */ 3557 usec_delay(E1000_I2C_T_LOW); 3558 } else { 3559 status = E1000_ERR_I2C; 3560 DEBUGOUT1("I2C data was not set to %X\n", data); 3561 } 3562 3563 return status; 3564 } 3565 /** 3566 * e1000_raise_i2c_clk - Raises the I2C SCL clock 3567 * @hw: pointer to hardware structure 3568 * @i2cctl: Current value of I2CCTL register 3569 * 3570 * Raises the I2C clock line '0'->'1' 3571 **/ 3572 static void e1000_raise_i2c_clk(struct e1000_hw *hw, u32 *i2cctl) 3573 { 3574 DEBUGFUNC("e1000_raise_i2c_clk"); 3575 3576 *i2cctl |= E1000_I2C_CLK_OUT; 3577 *i2cctl &= ~E1000_I2C_CLK_OE_N; 3578 E1000_WRITE_REG(hw, E1000_I2CPARAMS, *i2cctl); 3579 E1000_WRITE_FLUSH(hw); 3580 3581 /* SCL rise time (1000ns) */ 3582 usec_delay(E1000_I2C_T_RISE); 3583 } 3584 3585 /** 3586 * e1000_lower_i2c_clk - Lowers the I2C SCL clock 3587 * @hw: pointer to hardware structure 3588 * @i2cctl: Current value of I2CCTL register 3589 * 3590 * Lowers the I2C clock line '1'->'0' 3591 **/ 3592 static void e1000_lower_i2c_clk(struct e1000_hw *hw, u32 *i2cctl) 3593 { 3594 3595 DEBUGFUNC("e1000_lower_i2c_clk"); 3596 3597 *i2cctl &= ~E1000_I2C_CLK_OUT; 3598 *i2cctl &= ~E1000_I2C_CLK_OE_N; 3599 E1000_WRITE_REG(hw, E1000_I2CPARAMS, *i2cctl); 3600 E1000_WRITE_FLUSH(hw); 3601 3602 /* SCL fall time (300ns) */ 3603 usec_delay(E1000_I2C_T_FALL); 3604 } 3605 3606 /** 3607 * e1000_set_i2c_data - Sets the I2C data bit 3608 * @hw: pointer to hardware structure 3609 * @i2cctl: Current value of I2CCTL register 3610 * @data: I2C data value (0 or 1) to set 3611 * 3612 * Sets the I2C data bit 3613 **/ 3614 static s32 e1000_set_i2c_data(struct e1000_hw *hw, u32 *i2cctl, bool data) 3615 { 3616 s32 status = E1000_SUCCESS; 3617 3618 DEBUGFUNC("e1000_set_i2c_data"); 3619 3620 if (data) 3621 *i2cctl |= E1000_I2C_DATA_OUT; 3622 else 3623 *i2cctl &= ~E1000_I2C_DATA_OUT; 3624 3625 *i2cctl &= ~E1000_I2C_DATA_OE_N; 3626 *i2cctl |= E1000_I2C_CLK_OE_N; 3627 E1000_WRITE_REG(hw, E1000_I2CPARAMS, *i2cctl); 3628 E1000_WRITE_FLUSH(hw); 3629 3630 /* Data rise/fall (1000ns/300ns) and set-up time (250ns) */ 3631 usec_delay(E1000_I2C_T_RISE + E1000_I2C_T_FALL + E1000_I2C_T_SU_DATA); 3632 3633 *i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3634 if (data != e1000_get_i2c_data(i2cctl)) { 3635 status = E1000_ERR_I2C; 3636 DEBUGOUT1("Error - I2C data was not set to %X.\n", data); 3637 } 3638 3639 return status; 3640 } 3641 3642 /** 3643 * e1000_get_i2c_data - Reads the I2C SDA data bit 3644 * @hw: pointer to hardware structure 3645 * @i2cctl: Current value of I2CCTL register 3646 * 3647 * Returns the I2C data bit value 3648 **/ 3649 static bool e1000_get_i2c_data(u32 *i2cctl) 3650 { 3651 bool data; 3652 3653 DEBUGFUNC("e1000_get_i2c_data"); 3654 3655 if (*i2cctl & E1000_I2C_DATA_IN) 3656 data = 1; 3657 else 3658 data = 0; 3659 3660 return data; 3661 } 3662 3663 /** 3664 * e1000_i2c_bus_clear - Clears the I2C bus 3665 * @hw: pointer to hardware structure 3666 * 3667 * Clears the I2C bus by sending nine clock pulses. 3668 * Used when data line is stuck low. 3669 **/ 3670 void e1000_i2c_bus_clear(struct e1000_hw *hw) 3671 { 3672 u32 i2cctl = E1000_READ_REG(hw, E1000_I2CPARAMS); 3673 u32 i; 3674 3675 DEBUGFUNC("e1000_i2c_bus_clear"); 3676 3677 e1000_i2c_start(hw); 3678 3679 e1000_set_i2c_data(hw, &i2cctl, 1); 3680 3681 for (i = 0; i < 9; i++) { 3682 e1000_raise_i2c_clk(hw, &i2cctl); 3683 3684 /* Min high period of clock is 4us */ 3685 usec_delay(E1000_I2C_T_HIGH); 3686 3687 e1000_lower_i2c_clk(hw, &i2cctl); 3688 3689 /* Min low period of clock is 4.7us*/ 3690 usec_delay(E1000_I2C_T_LOW); 3691 } 3692 3693 e1000_i2c_start(hw); 3694 3695 /* Put the i2c bus back to default state */ 3696 e1000_i2c_stop(hw); 3697 } 3698 3699