xref: /freebsd/sys/dev/e1000/e1000_82541.h (revision 71625ec9ad2a9bc8c09784fbd23b759830e0ee5f)
18cfa0ad2SJack F Vogel /******************************************************************************
27282444bSPedro F. Giffuni   SPDX-License-Identifier: BSD-3-Clause
38cfa0ad2SJack F Vogel 
4*702cac6cSKevin Bowling   Copyright (c) 2001-2020, Intel Corporation
58cfa0ad2SJack F Vogel   All rights reserved.
68cfa0ad2SJack F Vogel 
78cfa0ad2SJack F Vogel   Redistribution and use in source and binary forms, with or without
88cfa0ad2SJack F Vogel   modification, are permitted provided that the following conditions are met:
98cfa0ad2SJack F Vogel 
108cfa0ad2SJack F Vogel    1. Redistributions of source code must retain the above copyright notice,
118cfa0ad2SJack F Vogel       this list of conditions and the following disclaimer.
128cfa0ad2SJack F Vogel 
138cfa0ad2SJack F Vogel    2. Redistributions in binary form must reproduce the above copyright
148cfa0ad2SJack F Vogel       notice, this list of conditions and the following disclaimer in the
158cfa0ad2SJack F Vogel       documentation and/or other materials provided with the distribution.
168cfa0ad2SJack F Vogel 
178cfa0ad2SJack F Vogel    3. Neither the name of the Intel Corporation nor the names of its
188cfa0ad2SJack F Vogel       contributors may be used to endorse or promote products derived from
198cfa0ad2SJack F Vogel       this software without specific prior written permission.
208cfa0ad2SJack F Vogel 
218cfa0ad2SJack F Vogel   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
228cfa0ad2SJack F Vogel   AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
238cfa0ad2SJack F Vogel   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
248cfa0ad2SJack F Vogel   ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
258cfa0ad2SJack F Vogel   LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
268cfa0ad2SJack F Vogel   CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
278cfa0ad2SJack F Vogel   SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
288cfa0ad2SJack F Vogel   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
298cfa0ad2SJack F Vogel   CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
308cfa0ad2SJack F Vogel   ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
318cfa0ad2SJack F Vogel   POSSIBILITY OF SUCH DAMAGE.
328cfa0ad2SJack F Vogel 
338cfa0ad2SJack F Vogel ******************************************************************************/
348cfa0ad2SJack F Vogel 
358cfa0ad2SJack F Vogel #ifndef _E1000_82541_H_
368cfa0ad2SJack F Vogel #define _E1000_82541_H_
378cfa0ad2SJack F Vogel 
388cfa0ad2SJack F Vogel #define NVM_WORD_SIZE_BASE_SHIFT_82541 (NVM_WORD_SIZE_BASE_SHIFT + 1)
398cfa0ad2SJack F Vogel 
408cfa0ad2SJack F Vogel #define IGP01E1000_PHY_CHANNEL_NUM		4
418cfa0ad2SJack F Vogel 
428cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_A			0x1172
438cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_B			0x1272
448cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_C			0x1472
458cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_D			0x1872
468cfa0ad2SJack F Vogel 
478cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_PARAM_A		0x1171
488cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_PARAM_B		0x1271
498cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_PARAM_C		0x1471
508cfa0ad2SJack F Vogel #define IGP01E1000_PHY_AGC_PARAM_D		0x1871
518cfa0ad2SJack F Vogel 
528cfa0ad2SJack F Vogel #define IGP01E1000_PHY_EDAC_MU_INDEX		0xC000
538cfa0ad2SJack F Vogel #define IGP01E1000_PHY_EDAC_SIGN_EXT_9_BITS	0x8000
548cfa0ad2SJack F Vogel 
558cfa0ad2SJack F Vogel #define IGP01E1000_PHY_DSP_RESET		0x1F33
568cfa0ad2SJack F Vogel 
578cfa0ad2SJack F Vogel #define IGP01E1000_PHY_DSP_FFE			0x1F35
588cfa0ad2SJack F Vogel #define IGP01E1000_PHY_DSP_FFE_CM_CP		0x0069
598cfa0ad2SJack F Vogel #define IGP01E1000_PHY_DSP_FFE_DEFAULT		0x002A
608cfa0ad2SJack F Vogel 
618cfa0ad2SJack F Vogel #define IGP01E1000_IEEE_FORCE_GIG		0x0140
628cfa0ad2SJack F Vogel #define IGP01E1000_IEEE_RESTART_AUTONEG		0x3300
638cfa0ad2SJack F Vogel 
648cfa0ad2SJack F Vogel #define IGP01E1000_AGC_LENGTH_SHIFT		7
658cfa0ad2SJack F Vogel #define IGP01E1000_AGC_RANGE			10
668cfa0ad2SJack F Vogel 
678cfa0ad2SJack F Vogel #define FFE_IDLE_ERR_COUNT_TIMEOUT_20		20
688cfa0ad2SJack F Vogel #define FFE_IDLE_ERR_COUNT_TIMEOUT_100		100
698cfa0ad2SJack F Vogel 
708cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_STATUS		0x20D0
718cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_SPARE_FUSE_STATUS	0x20D1
728cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_CONTROL		0x20DC
738cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_BYPASS		0x20DE
748cfa0ad2SJack F Vogel 
758cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_SPARE_FUSE_ENABLED	0x0100
768cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_FINE_MASK	0x0F80
778cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_COARSE_MASK	0x0070
788cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_COARSE_THRESH	0x0040
798cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_COARSE_10	0x0010
808cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_FINE_1		0x0080
818cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_FINE_10		0x0500
828cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_POLY_MASK	0xF000
838cfa0ad2SJack F Vogel #define IGP01E1000_ANALOG_FUSE_ENABLE_SW_CONTROL 0x0002
848cfa0ad2SJack F Vogel 
858cfa0ad2SJack F Vogel #define IGP01E1000_MSE_CHANNEL_D		0x000F
868cfa0ad2SJack F Vogel #define IGP01E1000_MSE_CHANNEL_C		0x00F0
878cfa0ad2SJack F Vogel #define IGP01E1000_MSE_CHANNEL_B		0x0F00
888cfa0ad2SJack F Vogel #define IGP01E1000_MSE_CHANNEL_A		0xF000
898cfa0ad2SJack F Vogel 
908cfa0ad2SJack F Vogel 
918cfa0ad2SJack F Vogel void e1000_init_script_state_82541(struct e1000_hw *hw, bool state);
928cfa0ad2SJack F Vogel #endif
93