1238148Sjfv/****************************************************************************** 2238148Sjfv 3269196Sjfv Copyright (c) 2001-2014, Intel Corporation 4238148Sjfv All rights reserved. 5238148Sjfv 6238148Sjfv Redistribution and use in source and binary forms, with or without 7238148Sjfv modification, are permitted provided that the following conditions are met: 8238148Sjfv 9238148Sjfv 1. Redistributions of source code must retain the above copyright notice, 10238148Sjfv this list of conditions and the following disclaimer. 11238148Sjfv 12238148Sjfv 2. Redistributions in binary form must reproduce the above copyright 13238148Sjfv notice, this list of conditions and the following disclaimer in the 14238148Sjfv documentation and/or other materials provided with the distribution. 15238148Sjfv 16238148Sjfv 3. Neither the name of the Intel Corporation nor the names of its 17238148Sjfv contributors may be used to endorse or promote products derived from 18238148Sjfv this software without specific prior written permission. 19238148Sjfv 20238148Sjfv THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 21238148Sjfv AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22238148Sjfv IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23238148Sjfv ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 24238148Sjfv LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 25238148Sjfv CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 26238148Sjfv SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27238148Sjfv INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28238148Sjfv CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 29238148Sjfv ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 30238148Sjfv POSSIBILITY OF SUCH DAMAGE. 31238148Sjfv 32238148Sjfv******************************************************************************/ 33238148Sjfv/*$FreeBSD: releng/10.2/sys/dev/e1000/e1000_i210.h 269196 2014-07-28 21:11:18Z jfv $*/ 34238148Sjfv 35238148Sjfv#ifndef _E1000_I210_H_ 36238148Sjfv#define _E1000_I210_H_ 37238148Sjfv 38256200Sjfvbool e1000_get_flash_presence_i210(struct e1000_hw *hw); 39238148Sjfvs32 e1000_update_flash_i210(struct e1000_hw *hw); 40238148Sjfvs32 e1000_update_nvm_checksum_i210(struct e1000_hw *hw); 41238148Sjfvs32 e1000_validate_nvm_checksum_i210(struct e1000_hw *hw); 42238148Sjfvs32 e1000_write_nvm_srwr_i210(struct e1000_hw *hw, u16 offset, 43238148Sjfv u16 words, u16 *data); 44238148Sjfvs32 e1000_read_nvm_srrd_i210(struct e1000_hw *hw, u16 offset, 45238148Sjfv u16 words, u16 *data); 46238148Sjfvs32 e1000_acquire_swfw_sync_i210(struct e1000_hw *hw, u16 mask); 47238148Sjfvvoid e1000_release_swfw_sync_i210(struct e1000_hw *hw, u16 mask); 48256200Sjfvs32 e1000_read_xmdio_reg(struct e1000_hw *hw, u16 addr, u8 dev_addr, 49256200Sjfv u16 *data); 50256200Sjfvs32 e1000_write_xmdio_reg(struct e1000_hw *hw, u16 addr, u8 dev_addr, 51256200Sjfv u16 data); 52269196Sjfvs32 e1000_init_hw_i210(struct e1000_hw *hw); 53238148Sjfv 54238148Sjfv#define E1000_STM_OPCODE 0xDB00 55238148Sjfv#define E1000_EEPROM_FLASH_SIZE_WORD 0x11 56238148Sjfv 57238148Sjfv#define INVM_DWORD_TO_RECORD_TYPE(invm_dword) \ 58238148Sjfv (u8)((invm_dword) & 0x7) 59238148Sjfv#define INVM_DWORD_TO_WORD_ADDRESS(invm_dword) \ 60238148Sjfv (u8)(((invm_dword) & 0x0000FE00) >> 9) 61238148Sjfv#define INVM_DWORD_TO_WORD_DATA(invm_dword) \ 62238148Sjfv (u16)(((invm_dword) & 0xFFFF0000) >> 16) 63238148Sjfv 64238148Sjfvenum E1000_INVM_STRUCTURE_TYPE { 65238148Sjfv E1000_INVM_UNINITIALIZED_STRUCTURE = 0x00, 66238148Sjfv E1000_INVM_WORD_AUTOLOAD_STRUCTURE = 0x01, 67238148Sjfv E1000_INVM_CSR_AUTOLOAD_STRUCTURE = 0x02, 68238148Sjfv E1000_INVM_PHY_REGISTER_AUTOLOAD_STRUCTURE = 0x03, 69238148Sjfv E1000_INVM_RSA_KEY_SHA256_STRUCTURE = 0x04, 70238148Sjfv E1000_INVM_INVALIDATED_STRUCTURE = 0x0F, 71238148Sjfv}; 72238148Sjfv 73238148Sjfv#define E1000_INVM_RSA_KEY_SHA256_DATA_SIZE_IN_DWORDS 8 74238148Sjfv#define E1000_INVM_CSR_AUTOLOAD_DATA_SIZE_IN_DWORDS 1 75247064Sjfv#define E1000_INVM_ULT_BYTES_SIZE 8 76247064Sjfv#define E1000_INVM_RECORD_SIZE_IN_BYTES 4 77247064Sjfv#define E1000_INVM_VER_FIELD_ONE 0x1FF8 78247064Sjfv#define E1000_INVM_VER_FIELD_TWO 0x7FE000 79247064Sjfv#define E1000_INVM_IMGTYPE_FIELD 0x1F800000 80238148Sjfv 81247064Sjfv#define E1000_INVM_MAJOR_MASK 0x3F0 82247064Sjfv#define E1000_INVM_MINOR_MASK 0xF 83247064Sjfv#define E1000_INVM_MAJOR_SHIFT 4 84247064Sjfv 85238148Sjfv#define ID_LED_DEFAULT_I210 ((ID_LED_OFF1_ON2 << 8) | \ 86238148Sjfv (ID_LED_DEF1_DEF2 << 4) | \ 87238148Sjfv (ID_LED_OFF1_OFF2)) 88238148Sjfv#define ID_LED_DEFAULT_I210_SERDES ((ID_LED_DEF1_DEF2 << 8) | \ 89238148Sjfv (ID_LED_DEF1_DEF2 << 4) | \ 90256200Sjfv (ID_LED_OFF1_ON2)) 91238148Sjfv 92247064Sjfv/* NVM offset defaults for I211 devices */ 93247064Sjfv#define NVM_INIT_CTRL_2_DEFAULT_I211 0X7243 94247064Sjfv#define NVM_INIT_CTRL_4_DEFAULT_I211 0x00C1 95247064Sjfv#define NVM_LED_1_CFG_DEFAULT_I211 0x0184 96247064Sjfv#define NVM_LED_0_2_CFG_DEFAULT_I211 0x200C 97269196Sjfv 98269196Sjfv/* PLL Defines */ 99269196Sjfv#define E1000_PCI_PMCSR 0x44 100269196Sjfv#define E1000_PCI_PMCSR_D3 0x03 101269196Sjfv#define E1000_MAX_PLL_TRIES 5 102269196Sjfv#define E1000_PHY_PLL_UNCONF 0xFF 103269196Sjfv#define E1000_PHY_PLL_FREQ_PAGE 0xFC0000 104269196Sjfv#define E1000_PHY_PLL_FREQ_REG 0x000E 105269196Sjfv#define E1000_INVM_DEFAULT_AL 0x202F 106269196Sjfv#define E1000_INVM_AUTOLOAD 0x0A 107269196Sjfv#define E1000_INVM_PLL_WO_VAL 0x0010 108269196Sjfv 109238148Sjfv#endif 110