1 /******************************************************************************
2 SPDX-License-Identifier: BSD-3-Clause
3
4 Copyright (c) 2001-2020, 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
35 #include "e1000_api.h"
36
37
38 static s32 e1000_acquire_nvm_i210(struct e1000_hw *hw);
39 static void e1000_release_nvm_i210(struct e1000_hw *hw);
40 static s32 e1000_write_nvm_srwr(struct e1000_hw *hw, u16 offset, u16 words,
41 u16 *data);
42 static s32 e1000_pool_flash_update_done_i210(struct e1000_hw *hw);
43 static s32 e1000_valid_led_default_i210(struct e1000_hw *hw, u16 *data);
44
45 /**
46 * e1000_acquire_nvm_i210 - Request for access to EEPROM
47 * @hw: pointer to the HW structure
48 *
49 * Acquire the necessary semaphores for exclusive access to the EEPROM.
50 * Set the EEPROM access request bit and wait for EEPROM access grant bit.
51 * Return successful if access grant bit set, else clear the request for
52 * EEPROM access and return -E1000_ERR_NVM (-1).
53 **/
e1000_acquire_nvm_i210(struct e1000_hw * hw)54 static s32 e1000_acquire_nvm_i210(struct e1000_hw *hw)
55 {
56 s32 ret_val;
57
58 DEBUGFUNC("e1000_acquire_nvm_i210");
59
60 ret_val = e1000_acquire_swfw_sync(hw, E1000_SWFW_EEP_SM);
61
62 return ret_val;
63 }
64
65 /**
66 * e1000_release_nvm_i210 - Release exclusive access to EEPROM
67 * @hw: pointer to the HW structure
68 *
69 * Stop any current commands to the EEPROM and clear the EEPROM request bit,
70 * then release the semaphores acquired.
71 **/
e1000_release_nvm_i210(struct e1000_hw * hw)72 static void e1000_release_nvm_i210(struct e1000_hw *hw)
73 {
74 DEBUGFUNC("e1000_release_nvm_i210");
75
76 e1000_release_swfw_sync(hw, E1000_SWFW_EEP_SM);
77 }
78
79 /**
80 * e1000_read_nvm_srrd_i210 - Reads Shadow Ram using EERD register
81 * @hw: pointer to the HW structure
82 * @offset: offset of word in the Shadow Ram to read
83 * @words: number of words to read
84 * @data: word read from the Shadow Ram
85 *
86 * Reads a 16 bit word from the Shadow Ram using the EERD register.
87 * Uses necessary synchronization semaphores.
88 **/
e1000_read_nvm_srrd_i210(struct e1000_hw * hw,u16 offset,u16 words,u16 * data)89 s32 e1000_read_nvm_srrd_i210(struct e1000_hw *hw, u16 offset, u16 words,
90 u16 *data)
91 {
92 s32 status = E1000_SUCCESS;
93 u16 i, count;
94
95 DEBUGFUNC("e1000_read_nvm_srrd_i210");
96
97 /* We cannot hold synchronization semaphores for too long,
98 * because of forceful takeover procedure. However it is more efficient
99 * to read in bursts than synchronizing access for each word. */
100 for (i = 0; i < words; i += E1000_EERD_EEWR_MAX_COUNT) {
101 count = (words - i) / E1000_EERD_EEWR_MAX_COUNT > 0 ?
102 E1000_EERD_EEWR_MAX_COUNT : (words - i);
103 if (hw->nvm.ops.acquire(hw) == E1000_SUCCESS) {
104 status = e1000_read_nvm_eerd(hw, offset, count,
105 data + i);
106 hw->nvm.ops.release(hw);
107 } else {
108 status = E1000_ERR_SWFW_SYNC;
109 }
110
111 if (status != E1000_SUCCESS)
112 break;
113 }
114
115 return status;
116 }
117
118 /**
119 * e1000_write_nvm_srwr_i210 - Write to Shadow RAM using EEWR
120 * @hw: pointer to the HW structure
121 * @offset: offset within the Shadow RAM to be written to
122 * @words: number of words to write
123 * @data: 16 bit word(s) to be written to the Shadow RAM
124 *
125 * Writes data to Shadow RAM at offset using EEWR register.
126 *
127 * If e1000_update_nvm_checksum is not called after this function , the
128 * data will not be committed to FLASH and also Shadow RAM will most likely
129 * contain an invalid checksum.
130 *
131 * If error code is returned, data and Shadow RAM may be inconsistent - buffer
132 * partially written.
133 **/
e1000_write_nvm_srwr_i210(struct e1000_hw * hw,u16 offset,u16 words,u16 * data)134 s32 e1000_write_nvm_srwr_i210(struct e1000_hw *hw, u16 offset, u16 words,
135 u16 *data)
136 {
137 s32 status = E1000_SUCCESS;
138 u16 i, count;
139
140 DEBUGFUNC("e1000_write_nvm_srwr_i210");
141
142 /* We cannot hold synchronization semaphores for too long,
143 * because of forceful takeover procedure. However it is more efficient
144 * to write in bursts than synchronizing access for each word. */
145 for (i = 0; i < words; i += E1000_EERD_EEWR_MAX_COUNT) {
146 count = (words - i) / E1000_EERD_EEWR_MAX_COUNT > 0 ?
147 E1000_EERD_EEWR_MAX_COUNT : (words - i);
148 if (hw->nvm.ops.acquire(hw) == E1000_SUCCESS) {
149 status = e1000_write_nvm_srwr(hw, offset, count,
150 data + i);
151 hw->nvm.ops.release(hw);
152 } else {
153 status = E1000_ERR_SWFW_SYNC;
154 }
155
156 if (status != E1000_SUCCESS)
157 break;
158 }
159
160 return status;
161 }
162
163 /**
164 * e1000_write_nvm_srwr - Write to Shadow Ram using EEWR
165 * @hw: pointer to the HW structure
166 * @offset: offset within the Shadow Ram to be written to
167 * @words: number of words to write
168 * @data: 16 bit word(s) to be written to the Shadow Ram
169 *
170 * Writes data to Shadow Ram at offset using EEWR register.
171 *
172 * If e1000_update_nvm_checksum is not called after this function , the
173 * Shadow Ram will most likely contain an invalid checksum.
174 **/
e1000_write_nvm_srwr(struct e1000_hw * hw,u16 offset,u16 words,u16 * data)175 static s32 e1000_write_nvm_srwr(struct e1000_hw *hw, u16 offset, u16 words,
176 u16 *data)
177 {
178 struct e1000_nvm_info *nvm = &hw->nvm;
179 u32 i, k, eewr = 0;
180 u32 attempts = 100000;
181 s32 ret_val = E1000_SUCCESS;
182
183 DEBUGFUNC("e1000_write_nvm_srwr");
184
185 /*
186 * A check for invalid values: offset too large, too many words,
187 * too many words for the offset, and not enough words.
188 */
189 if ((offset >= nvm->word_size) || (words > (nvm->word_size - offset)) ||
190 (words == 0)) {
191 DEBUGOUT("nvm parameter(s) out of bounds\n");
192 ret_val = -E1000_ERR_NVM;
193 goto out;
194 }
195
196 for (i = 0; i < words; i++) {
197 ret_val = -E1000_ERR_NVM;
198
199 eewr = ((offset + i) << E1000_NVM_RW_ADDR_SHIFT) |
200 (data[i] << E1000_NVM_RW_REG_DATA) |
201 E1000_NVM_RW_REG_START;
202
203 E1000_WRITE_REG(hw, E1000_SRWR, eewr);
204
205 for (k = 0; k < attempts; k++) {
206 if (E1000_NVM_RW_REG_DONE &
207 E1000_READ_REG(hw, E1000_SRWR)) {
208 ret_val = E1000_SUCCESS;
209 break;
210 }
211 usec_delay(5);
212 }
213
214 if (ret_val != E1000_SUCCESS) {
215 DEBUGOUT("Shadow RAM write EEWR timed out\n");
216 break;
217 }
218 }
219
220 out:
221 return ret_val;
222 }
223
224 /** e1000_read_invm_word_i210 - Reads OTP
225 * @hw: pointer to the HW structure
226 * @address: the word address (aka eeprom offset) to read
227 * @data: pointer to the data read
228 *
229 * Reads 16-bit words from the OTP. Return error when the word is not
230 * stored in OTP.
231 **/
e1000_read_invm_word_i210(struct e1000_hw * hw,u8 address,u16 * data)232 static s32 e1000_read_invm_word_i210(struct e1000_hw *hw, u8 address, u16 *data)
233 {
234 s32 status = -E1000_ERR_INVM_VALUE_NOT_FOUND;
235 u32 invm_dword;
236 u16 i;
237 u8 record_type, word_address;
238
239 DEBUGFUNC("e1000_read_invm_word_i210");
240
241 for (i = 0; i < E1000_INVM_SIZE; i++) {
242 invm_dword = E1000_READ_REG(hw, E1000_INVM_DATA_REG(i));
243 /* Get record type */
244 record_type = INVM_DWORD_TO_RECORD_TYPE(invm_dword);
245 if (record_type == E1000_INVM_UNINITIALIZED_STRUCTURE)
246 break;
247 if (record_type == E1000_INVM_CSR_AUTOLOAD_STRUCTURE)
248 i += E1000_INVM_CSR_AUTOLOAD_DATA_SIZE_IN_DWORDS;
249 if (record_type == E1000_INVM_RSA_KEY_SHA256_STRUCTURE)
250 i += E1000_INVM_RSA_KEY_SHA256_DATA_SIZE_IN_DWORDS;
251 if (record_type == E1000_INVM_WORD_AUTOLOAD_STRUCTURE) {
252 word_address = INVM_DWORD_TO_WORD_ADDRESS(invm_dword);
253 if (word_address == address) {
254 *data = INVM_DWORD_TO_WORD_DATA(invm_dword);
255 DEBUGOUT2("Read INVM Word 0x%02x = %x",
256 address, *data);
257 status = E1000_SUCCESS;
258 break;
259 }
260 }
261 }
262 if (status != E1000_SUCCESS)
263 DEBUGOUT1("Requested word 0x%02x not found in OTP\n", address);
264 return status;
265 }
266
267 /** e1000_read_invm_i210 - Read invm wrapper function for I210/I211
268 * @hw: pointer to the HW structure
269 * @address: the word address (aka eeprom offset) to read
270 * @data: pointer to the data read
271 *
272 * Wrapper function to return data formerly found in the NVM.
273 **/
e1000_read_invm_i210(struct e1000_hw * hw,u16 offset,u16 E1000_UNUSEDARG words,u16 * data)274 static s32 e1000_read_invm_i210(struct e1000_hw *hw, u16 offset,
275 u16 E1000_UNUSEDARG words, u16 *data)
276 {
277 s32 ret_val = E1000_SUCCESS;
278
279 DEBUGFUNC("e1000_read_invm_i210");
280
281 /* Only the MAC addr is required to be present in the iNVM */
282 switch (offset) {
283 case NVM_MAC_ADDR:
284 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, &data[0]);
285 ret_val |= e1000_read_invm_word_i210(hw, (u8)offset + 1,
286 &data[1]);
287 ret_val |= e1000_read_invm_word_i210(hw, (u8)offset + 2,
288 &data[2]);
289 if (ret_val != E1000_SUCCESS)
290 DEBUGOUT("MAC Addr not found in iNVM\n");
291 break;
292 case NVM_INIT_CTRL_2:
293 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, data);
294 if (ret_val != E1000_SUCCESS) {
295 *data = NVM_INIT_CTRL_2_DEFAULT_I211;
296 ret_val = E1000_SUCCESS;
297 }
298 break;
299 case NVM_INIT_CTRL_4:
300 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, data);
301 if (ret_val != E1000_SUCCESS) {
302 *data = NVM_INIT_CTRL_4_DEFAULT_I211;
303 ret_val = E1000_SUCCESS;
304 }
305 break;
306 case NVM_LED_1_CFG:
307 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, data);
308 if (ret_val != E1000_SUCCESS) {
309 *data = NVM_LED_1_CFG_DEFAULT_I211;
310 ret_val = E1000_SUCCESS;
311 }
312 break;
313 case NVM_LED_0_2_CFG:
314 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, data);
315 if (ret_val != E1000_SUCCESS) {
316 *data = NVM_LED_0_2_CFG_DEFAULT_I211;
317 ret_val = E1000_SUCCESS;
318 }
319 break;
320 case NVM_ID_LED_SETTINGS:
321 ret_val = e1000_read_invm_word_i210(hw, (u8)offset, data);
322 if (ret_val != E1000_SUCCESS) {
323 *data = ID_LED_RESERVED_FFFF;
324 ret_val = E1000_SUCCESS;
325 }
326 break;
327 case NVM_SUB_DEV_ID:
328 *data = hw->subsystem_device_id;
329 break;
330 case NVM_SUB_VEN_ID:
331 *data = hw->subsystem_vendor_id;
332 break;
333 case NVM_DEV_ID:
334 *data = hw->device_id;
335 break;
336 case NVM_VEN_ID:
337 *data = hw->vendor_id;
338 break;
339 default:
340 DEBUGOUT1("NVM word 0x%02x is not mapped.\n", offset);
341 *data = NVM_RESERVED_WORD;
342 break;
343 }
344 return ret_val;
345 }
346
347 /**
348 * e1000_read_invm_version - Reads iNVM version and image type
349 * @hw: pointer to the HW structure
350 * @invm_ver: version structure for the version read
351 *
352 * Reads iNVM version and image type.
353 **/
e1000_read_invm_version(struct e1000_hw * hw,struct e1000_fw_version * invm_ver)354 s32 e1000_read_invm_version(struct e1000_hw *hw,
355 struct e1000_fw_version *invm_ver)
356 {
357 u32 *record = NULL;
358 u32 *next_record = NULL;
359 u32 i = 0;
360 u32 invm_dword = 0;
361 u32 invm_blocks = E1000_INVM_SIZE - (E1000_INVM_ULT_BYTES_SIZE /
362 E1000_INVM_RECORD_SIZE_IN_BYTES);
363 u32 buffer[E1000_INVM_SIZE];
364 s32 status = -E1000_ERR_INVM_VALUE_NOT_FOUND;
365 u16 version = 0;
366
367 DEBUGFUNC("e1000_read_invm_version");
368
369 /* Read iNVM memory */
370 for (i = 0; i < E1000_INVM_SIZE; i++) {
371 invm_dword = E1000_READ_REG(hw, E1000_INVM_DATA_REG(i));
372 buffer[i] = invm_dword;
373 }
374
375 /* Read version number */
376 for (i = 1; i < invm_blocks; i++) {
377 record = &buffer[invm_blocks - i];
378 next_record = &buffer[invm_blocks - i + 1];
379
380 /* Check if we have first version location used */
381 if ((i == 1) && ((*record & E1000_INVM_VER_FIELD_ONE) == 0)) {
382 version = 0;
383 status = E1000_SUCCESS;
384 break;
385 }
386 /* Check if we have second version location used */
387 else if ((i == 1) &&
388 ((*record & E1000_INVM_VER_FIELD_TWO) == 0)) {
389 version = (*record & E1000_INVM_VER_FIELD_ONE) >> 3;
390 status = E1000_SUCCESS;
391 break;
392 }
393 /*
394 * Check if we have odd version location
395 * used and it is the last one used
396 */
397 else if ((((*record & E1000_INVM_VER_FIELD_ONE) == 0) &&
398 ((*record & 0x3) == 0)) || (((*record & 0x3) != 0) &&
399 (i != 1))) {
400 version = (*next_record & E1000_INVM_VER_FIELD_TWO)
401 >> 13;
402 status = E1000_SUCCESS;
403 break;
404 }
405 /*
406 * Check if we have even version location
407 * used and it is the last one used
408 */
409 else if (((*record & E1000_INVM_VER_FIELD_TWO) == 0) &&
410 ((*record & 0x3) == 0)) {
411 version = (*record & E1000_INVM_VER_FIELD_ONE) >> 3;
412 status = E1000_SUCCESS;
413 break;
414 }
415 }
416
417 if (status == E1000_SUCCESS) {
418 invm_ver->invm_major = (version & E1000_INVM_MAJOR_MASK)
419 >> E1000_INVM_MAJOR_SHIFT;
420 invm_ver->invm_minor = version & E1000_INVM_MINOR_MASK;
421 }
422 /* Read Image Type */
423 for (i = 1; i < invm_blocks; i++) {
424 record = &buffer[invm_blocks - i];
425 next_record = &buffer[invm_blocks - i + 1];
426
427 /* Check if we have image type in first location used */
428 if ((i == 1) && ((*record & E1000_INVM_IMGTYPE_FIELD) == 0)) {
429 invm_ver->invm_img_type = 0;
430 status = E1000_SUCCESS;
431 break;
432 }
433 /* Check if we have image type in first location used */
434 else if ((((*record & 0x3) == 0) &&
435 ((*record & E1000_INVM_IMGTYPE_FIELD) == 0)) ||
436 ((((*record & 0x3) != 0) && (i != 1)))) {
437 invm_ver->invm_img_type =
438 (*next_record & E1000_INVM_IMGTYPE_FIELD) >> 23;
439 status = E1000_SUCCESS;
440 break;
441 }
442 }
443 return status;
444 }
445
446 /**
447 * e1000_validate_nvm_checksum_i210 - Validate EEPROM checksum
448 * @hw: pointer to the HW structure
449 *
450 * Calculates the EEPROM checksum by reading/adding each word of the EEPROM
451 * and then verifies that the sum of the EEPROM is equal to 0xBABA.
452 **/
e1000_validate_nvm_checksum_i210(struct e1000_hw * hw)453 s32 e1000_validate_nvm_checksum_i210(struct e1000_hw *hw)
454 {
455 s32 status = E1000_SUCCESS;
456 s32 (*read_op_ptr)(struct e1000_hw *, u16, u16, u16 *);
457
458 DEBUGFUNC("e1000_validate_nvm_checksum_i210");
459
460 if (hw->nvm.ops.acquire(hw) == E1000_SUCCESS) {
461
462 /*
463 * Replace the read function with semaphore grabbing with
464 * the one that skips this for a while.
465 * We have semaphore taken already here.
466 */
467 read_op_ptr = hw->nvm.ops.read;
468 hw->nvm.ops.read = e1000_read_nvm_eerd;
469
470 status = e1000_validate_nvm_checksum_generic(hw);
471
472 /* Revert original read operation. */
473 hw->nvm.ops.read = read_op_ptr;
474
475 hw->nvm.ops.release(hw);
476 } else {
477 status = E1000_ERR_SWFW_SYNC;
478 }
479
480 return status;
481 }
482
483
484 /**
485 * e1000_update_nvm_checksum_i210 - Update EEPROM checksum
486 * @hw: pointer to the HW structure
487 *
488 * Updates the EEPROM checksum by reading/adding each word of the EEPROM
489 * up to the checksum. Then calculates the EEPROM checksum and writes the
490 * value to the EEPROM. Next commit EEPROM data onto the Flash.
491 **/
e1000_update_nvm_checksum_i210(struct e1000_hw * hw)492 s32 e1000_update_nvm_checksum_i210(struct e1000_hw *hw)
493 {
494 s32 ret_val;
495 u16 checksum = 0;
496 u16 i, nvm_data;
497
498 DEBUGFUNC("e1000_update_nvm_checksum_i210");
499
500 /*
501 * Read the first word from the EEPROM. If this times out or fails, do
502 * not continue or we could be in for a very long wait while every
503 * EEPROM read fails
504 */
505 ret_val = e1000_read_nvm_eerd(hw, 0, 1, &nvm_data);
506 if (ret_val != E1000_SUCCESS) {
507 DEBUGOUT("EEPROM read failed\n");
508 goto out;
509 }
510
511 if (hw->nvm.ops.acquire(hw) == E1000_SUCCESS) {
512 /*
513 * Do not use hw->nvm.ops.write, hw->nvm.ops.read
514 * because we do not want to take the synchronization
515 * semaphores twice here.
516 */
517
518 for (i = 0; i < NVM_CHECKSUM_REG; i++) {
519 ret_val = e1000_read_nvm_eerd(hw, i, 1, &nvm_data);
520 if (ret_val) {
521 hw->nvm.ops.release(hw);
522 DEBUGOUT("NVM Read Error while updating checksum.\n");
523 goto out;
524 }
525 checksum += nvm_data;
526 }
527 checksum = (u16) NVM_SUM - checksum;
528 ret_val = e1000_write_nvm_srwr(hw, NVM_CHECKSUM_REG, 1,
529 &checksum);
530 if (ret_val != E1000_SUCCESS) {
531 hw->nvm.ops.release(hw);
532 DEBUGOUT("NVM Write Error while updating checksum.\n");
533 goto out;
534 }
535
536 hw->nvm.ops.release(hw);
537
538 ret_val = e1000_update_flash_i210(hw);
539 } else {
540 ret_val = E1000_ERR_SWFW_SYNC;
541 }
542 out:
543 return ret_val;
544 }
545
546 /**
547 * e1000_get_flash_presence_i210 - Check if flash device is detected.
548 * @hw: pointer to the HW structure
549 *
550 **/
e1000_get_flash_presence_i210(struct e1000_hw * hw)551 bool e1000_get_flash_presence_i210(struct e1000_hw *hw)
552 {
553 u32 eec = 0;
554 bool ret_val = false;
555
556 DEBUGFUNC("e1000_get_flash_presence_i210");
557
558 eec = E1000_READ_REG(hw, E1000_EECD);
559
560 if (eec & E1000_EECD_FLASH_DETECTED_I210)
561 ret_val = true;
562
563 return ret_val;
564 }
565
566 /**
567 * e1000_update_flash_i210 - Commit EEPROM to the flash
568 * @hw: pointer to the HW structure
569 *
570 **/
e1000_update_flash_i210(struct e1000_hw * hw)571 s32 e1000_update_flash_i210(struct e1000_hw *hw)
572 {
573 s32 ret_val;
574 u32 flup;
575
576 DEBUGFUNC("e1000_update_flash_i210");
577
578 ret_val = e1000_pool_flash_update_done_i210(hw);
579 if (ret_val == -E1000_ERR_NVM) {
580 DEBUGOUT("Flash update time out\n");
581 goto out;
582 }
583
584 flup = E1000_READ_REG(hw, E1000_EECD) | E1000_EECD_FLUPD_I210;
585 E1000_WRITE_REG(hw, E1000_EECD, flup);
586
587 ret_val = e1000_pool_flash_update_done_i210(hw);
588 if (ret_val == E1000_SUCCESS)
589 DEBUGOUT("Flash update complete\n");
590 else
591 DEBUGOUT("Flash update time out\n");
592
593 out:
594 return ret_val;
595 }
596
597 /**
598 * e1000_pool_flash_update_done_i210 - Pool FLUDONE status.
599 * @hw: pointer to the HW structure
600 *
601 **/
e1000_pool_flash_update_done_i210(struct e1000_hw * hw)602 s32 e1000_pool_flash_update_done_i210(struct e1000_hw *hw)
603 {
604 s32 ret_val = -E1000_ERR_NVM;
605 u32 i, reg;
606
607 DEBUGFUNC("e1000_pool_flash_update_done_i210");
608
609 for (i = 0; i < E1000_FLUDONE_ATTEMPTS; i++) {
610 reg = E1000_READ_REG(hw, E1000_EECD);
611 if (reg & E1000_EECD_FLUDONE_I210) {
612 ret_val = E1000_SUCCESS;
613 break;
614 }
615 usec_delay(5);
616 }
617
618 return ret_val;
619 }
620
621 /**
622 * e1000_init_nvm_params_i210 - Initialize i210 NVM function pointers
623 * @hw: pointer to the HW structure
624 *
625 * Initialize the i210/i211 NVM parameters and function pointers.
626 **/
e1000_init_nvm_params_i210(struct e1000_hw * hw)627 static s32 e1000_init_nvm_params_i210(struct e1000_hw *hw)
628 {
629 s32 ret_val;
630 struct e1000_nvm_info *nvm = &hw->nvm;
631
632 DEBUGFUNC("e1000_init_nvm_params_i210");
633
634 ret_val = e1000_init_nvm_params_82575(hw);
635 nvm->ops.acquire = e1000_acquire_nvm_i210;
636 nvm->ops.release = e1000_release_nvm_i210;
637 nvm->ops.valid_led_default = e1000_valid_led_default_i210;
638 if (e1000_get_flash_presence_i210(hw)) {
639 hw->nvm.type = e1000_nvm_flash_hw;
640 nvm->ops.read = e1000_read_nvm_srrd_i210;
641 nvm->ops.write = e1000_write_nvm_srwr_i210;
642 nvm->ops.validate = e1000_validate_nvm_checksum_i210;
643 nvm->ops.update = e1000_update_nvm_checksum_i210;
644 } else {
645 hw->nvm.type = e1000_nvm_invm;
646 nvm->ops.read = e1000_read_invm_i210;
647 nvm->ops.write = e1000_null_write_nvm;
648 nvm->ops.validate = e1000_null_ops_generic;
649 nvm->ops.update = e1000_null_ops_generic;
650 }
651 return ret_val;
652 }
653
654 /**
655 * e1000_init_function_pointers_i210 - Init func ptrs.
656 * @hw: pointer to the HW structure
657 *
658 * Called to initialize all function pointers and parameters.
659 **/
e1000_init_function_pointers_i210(struct e1000_hw * hw)660 void e1000_init_function_pointers_i210(struct e1000_hw *hw)
661 {
662 e1000_init_function_pointers_82575(hw);
663 hw->nvm.ops.init_params = e1000_init_nvm_params_i210;
664 }
665
666 /**
667 * e1000_valid_led_default_i210 - Verify a valid default LED config
668 * @hw: pointer to the HW structure
669 * @data: pointer to the NVM (EEPROM)
670 *
671 * Read the EEPROM for the current default LED configuration. If the
672 * LED configuration is not valid, set to a valid LED configuration.
673 **/
e1000_valid_led_default_i210(struct e1000_hw * hw,u16 * data)674 static s32 e1000_valid_led_default_i210(struct e1000_hw *hw, u16 *data)
675 {
676 s32 ret_val;
677
678 DEBUGFUNC("e1000_valid_led_default_i210");
679
680 ret_val = hw->nvm.ops.read(hw, NVM_ID_LED_SETTINGS, 1, data);
681 if (ret_val) {
682 DEBUGOUT("NVM Read Error\n");
683 goto out;
684 }
685
686 if (*data == ID_LED_RESERVED_0000 || *data == ID_LED_RESERVED_FFFF) {
687 switch (hw->phy.media_type) {
688 case e1000_media_type_internal_serdes:
689 *data = ID_LED_DEFAULT_I210_SERDES;
690 break;
691 case e1000_media_type_copper:
692 default:
693 *data = ID_LED_DEFAULT_I210;
694 break;
695 }
696 }
697 out:
698 return ret_val;
699 }
700
701 /**
702 * e1000_pll_workaround_i210
703 * @hw: pointer to the HW structure
704 *
705 * Works around an errata in the PLL circuit where it occasionally
706 * provides the wrong clock frequency after power up.
707 **/
e1000_pll_workaround_i210(struct e1000_hw * hw)708 static s32 e1000_pll_workaround_i210(struct e1000_hw *hw)
709 {
710 s32 ret_val;
711 u32 wuc, mdicnfg, ctrl, ctrl_ext, reg_val;
712 u16 nvm_word, phy_word, pci_word, tmp_nvm;
713 int i;
714
715 /* Get PHY semaphore */
716 hw->phy.ops.acquire(hw);
717 /* Get and set needed register values */
718 wuc = E1000_READ_REG(hw, E1000_WUC);
719 mdicnfg = E1000_READ_REG(hw, E1000_MDICNFG);
720 reg_val = mdicnfg & ~E1000_MDICNFG_EXT_MDIO;
721 E1000_WRITE_REG(hw, E1000_MDICNFG, reg_val);
722
723 /* Get data from NVM, or set default */
724 ret_val = e1000_read_invm_word_i210(hw, E1000_INVM_AUTOLOAD,
725 &nvm_word);
726 if (ret_val != E1000_SUCCESS)
727 nvm_word = E1000_INVM_DEFAULT_AL;
728 tmp_nvm = nvm_word | E1000_INVM_PLL_WO_VAL;
729 phy_word = E1000_PHY_PLL_UNCONF;
730 for (i = 0; i < E1000_MAX_PLL_TRIES; i++) {
731 /* check current state directly from internal PHY */
732 e1000_write_phy_reg_mdic(hw, GS40G_PAGE_SELECT, 0xFC);
733 usec_delay(20);
734 e1000_read_phy_reg_mdic(hw, E1000_PHY_PLL_FREQ_REG, &phy_word);
735 usec_delay(20);
736 e1000_write_phy_reg_mdic(hw, GS40G_PAGE_SELECT, 0);
737 if ((phy_word & E1000_PHY_PLL_UNCONF)
738 != E1000_PHY_PLL_UNCONF) {
739 ret_val = E1000_SUCCESS;
740 break;
741 } else {
742 ret_val = -E1000_ERR_PHY;
743 }
744 /* directly reset the internal PHY */
745 ctrl = E1000_READ_REG(hw, E1000_CTRL);
746 E1000_WRITE_REG(hw, E1000_CTRL, ctrl|E1000_CTRL_PHY_RST);
747
748 ctrl_ext = E1000_READ_REG(hw, E1000_CTRL_EXT);
749 ctrl_ext |= (E1000_CTRL_EXT_PHYPDEN | E1000_CTRL_EXT_SDLPE);
750 E1000_WRITE_REG(hw, E1000_CTRL_EXT, ctrl_ext);
751
752 E1000_WRITE_REG(hw, E1000_WUC, 0);
753 reg_val = (E1000_INVM_AUTOLOAD << 4) | (tmp_nvm << 16);
754 E1000_WRITE_REG(hw, E1000_EEARBC_I210, reg_val);
755
756 e1000_read_pci_cfg(hw, E1000_PCI_PMCSR, &pci_word);
757 pci_word |= E1000_PCI_PMCSR_D3;
758 e1000_write_pci_cfg(hw, E1000_PCI_PMCSR, &pci_word);
759 msec_delay(1);
760 pci_word &= ~E1000_PCI_PMCSR_D3;
761 e1000_write_pci_cfg(hw, E1000_PCI_PMCSR, &pci_word);
762 reg_val = (E1000_INVM_AUTOLOAD << 4) | (nvm_word << 16);
763 E1000_WRITE_REG(hw, E1000_EEARBC_I210, reg_val);
764
765 /* restore WUC register */
766 E1000_WRITE_REG(hw, E1000_WUC, wuc);
767 }
768 /* restore MDICNFG setting */
769 E1000_WRITE_REG(hw, E1000_MDICNFG, mdicnfg);
770 /* Release PHY semaphore */
771 hw->phy.ops.release(hw);
772 return ret_val;
773 }
774
775 /**
776 * e1000_get_cfg_done_i210 - Read config done bit
777 * @hw: pointer to the HW structure
778 *
779 * Read the management control register for the config done bit for
780 * completion status. NOTE: silicon which is EEPROM-less will fail trying
781 * to read the config done bit, so an error is *ONLY* logged and returns
782 * E1000_SUCCESS. If we were to return with error, EEPROM-less silicon
783 * would not be able to be reset or change link.
784 **/
e1000_get_cfg_done_i210(struct e1000_hw * hw)785 static s32 e1000_get_cfg_done_i210(struct e1000_hw *hw)
786 {
787 s32 timeout = PHY_CFG_TIMEOUT;
788 u32 mask = E1000_NVM_CFG_DONE_PORT_0;
789
790 DEBUGFUNC("e1000_get_cfg_done_i210");
791
792 while (timeout) {
793 if (E1000_READ_REG(hw, E1000_EEMNGCTL_I210) & mask)
794 break;
795 msec_delay(1);
796 timeout--;
797 }
798 if (!timeout)
799 DEBUGOUT("MNG configuration cycle has not completed.\n");
800
801 return E1000_SUCCESS;
802 }
803
804 /**
805 * e1000_init_hw_i210 - Init hw for I210/I211
806 * @hw: pointer to the HW structure
807 *
808 * Called to initialize hw for i210 hw family.
809 **/
e1000_init_hw_i210(struct e1000_hw * hw)810 s32 e1000_init_hw_i210(struct e1000_hw *hw)
811 {
812 struct e1000_mac_info *mac = &hw->mac;
813 s32 ret_val;
814
815 DEBUGFUNC("e1000_init_hw_i210");
816 if ((hw->mac.type >= e1000_i210) &&
817 !(e1000_get_flash_presence_i210(hw))) {
818 ret_val = e1000_pll_workaround_i210(hw);
819 if (ret_val != E1000_SUCCESS)
820 return ret_val;
821 }
822 hw->phy.ops.get_cfg_done = e1000_get_cfg_done_i210;
823
824 /* Initialize identification LED */
825 mac->ops.id_led_init(hw);
826
827 ret_val = e1000_init_hw_base(hw);
828 return ret_val;
829 }
830