xref: /openbmc/qemu/hw/net/e1000x_regs.h (revision b55e4b9c0525560577384adfc6d30eb0daa8d7be)
1c9653b77SAkihiko Odaki /*******************************************************************************
2c9653b77SAkihiko Odaki 
3c9653b77SAkihiko Odaki   Intel PRO/1000 Linux driver
4c9653b77SAkihiko Odaki   Copyright(c) 1999 - 2006 Intel Corporation.
5c9653b77SAkihiko Odaki 
6c9653b77SAkihiko Odaki   This program is free software; you can redistribute it and/or modify it
7c9653b77SAkihiko Odaki   under the terms and conditions of the GNU General Public License,
8c9653b77SAkihiko Odaki   version 2, as published by the Free Software Foundation.
9c9653b77SAkihiko Odaki 
10c9653b77SAkihiko Odaki   This program is distributed in the hope it will be useful, but WITHOUT
11c9653b77SAkihiko Odaki   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12c9653b77SAkihiko Odaki   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
13c9653b77SAkihiko Odaki   more details.
14c9653b77SAkihiko Odaki 
15c9653b77SAkihiko Odaki   You should have received a copy of the GNU General Public License along with
16c9653b77SAkihiko Odaki   this program; if not, see <http://www.gnu.org/licenses/>.
17c9653b77SAkihiko Odaki 
18c9653b77SAkihiko Odaki   The full GNU General Public License is included in this distribution in
19c9653b77SAkihiko Odaki   the file called "COPYING".
20c9653b77SAkihiko Odaki 
21c9653b77SAkihiko Odaki   Contact Information:
22c9653b77SAkihiko Odaki   Linux NICS <linux.nics@intel.com>
23c9653b77SAkihiko Odaki   e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>
24c9653b77SAkihiko Odaki   Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
25c9653b77SAkihiko Odaki 
26c9653b77SAkihiko Odaki *******************************************************************************/
27c9653b77SAkihiko Odaki 
28c9653b77SAkihiko Odaki /* e1000_hw.h
29c9653b77SAkihiko Odaki  * Structures, enums, and macros for the MAC
30c9653b77SAkihiko Odaki  */
31c9653b77SAkihiko Odaki 
32c9653b77SAkihiko Odaki #ifndef HW_E1000X_REGS_H
33c9653b77SAkihiko Odaki #define HW_E1000X_REGS_H
34c9653b77SAkihiko Odaki 
35c9653b77SAkihiko Odaki /* PCI Device IDs */
36c9653b77SAkihiko Odaki #define E1000_DEV_ID_82542               0x1000
37c9653b77SAkihiko Odaki #define E1000_DEV_ID_82543GC_FIBER       0x1001
38c9653b77SAkihiko Odaki #define E1000_DEV_ID_82543GC_COPPER      0x1004
39c9653b77SAkihiko Odaki #define E1000_DEV_ID_82544EI_COPPER      0x1008
40c9653b77SAkihiko Odaki #define E1000_DEV_ID_82544EI_FIBER       0x1009
41c9653b77SAkihiko Odaki #define E1000_DEV_ID_82544GC_COPPER      0x100C
42c9653b77SAkihiko Odaki #define E1000_DEV_ID_82544GC_LOM         0x100D
43c9653b77SAkihiko Odaki #define E1000_DEV_ID_82540EM             0x100E
44c9653b77SAkihiko Odaki #define E1000_DEV_ID_82540EM_LOM         0x1015
45c9653b77SAkihiko Odaki #define E1000_DEV_ID_82540EP_LOM         0x1016
46c9653b77SAkihiko Odaki #define E1000_DEV_ID_82540EP             0x1017
47c9653b77SAkihiko Odaki #define E1000_DEV_ID_82540EP_LP          0x101E
48c9653b77SAkihiko Odaki #define E1000_DEV_ID_82545EM_COPPER      0x100F
49c9653b77SAkihiko Odaki #define E1000_DEV_ID_82545EM_FIBER       0x1011
50c9653b77SAkihiko Odaki #define E1000_DEV_ID_82545GM_COPPER      0x1026
51c9653b77SAkihiko Odaki #define E1000_DEV_ID_82545GM_FIBER       0x1027
52c9653b77SAkihiko Odaki #define E1000_DEV_ID_82545GM_SERDES      0x1028
53c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546EB_COPPER      0x1010
54c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546EB_FIBER       0x1012
55c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546EB_QUAD_COPPER 0x101D
56c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541EI             0x1013
57c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541EI_MOBILE      0x1018
58c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541ER_LOM         0x1014
59c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541ER             0x1078
60c9653b77SAkihiko Odaki #define E1000_DEV_ID_82547GI             0x1075
61c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541GI             0x1076
62c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541GI_MOBILE      0x1077
63c9653b77SAkihiko Odaki #define E1000_DEV_ID_82541GI_LF          0x107C
64c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_COPPER      0x1079
65c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_FIBER       0x107A
66c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_SERDES      0x107B
67c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_PCIE        0x108A
68c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_QUAD_COPPER 0x1099
69c9653b77SAkihiko Odaki #define E1000_DEV_ID_82547EI             0x1019
70c9653b77SAkihiko Odaki #define E1000_DEV_ID_82547EI_MOBILE      0x101A
71c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_COPPER      0x105E
72c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_FIBER       0x105F
73c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_SERDES      0x1060
74c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_QUAD_COPPER 0x10A4
75c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571PT_QUAD_COPPER 0x10D5
76c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_QUAD_FIBER  0x10A5
77c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_QUAD_COPPER_LOWPROFILE  0x10BC
78c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_SERDES_DUAL 0x10D9
79c9653b77SAkihiko Odaki #define E1000_DEV_ID_82571EB_SERDES_QUAD 0x10DA
80c9653b77SAkihiko Odaki #define E1000_DEV_ID_82572EI_COPPER      0x107D
81c9653b77SAkihiko Odaki #define E1000_DEV_ID_82572EI_FIBER       0x107E
82c9653b77SAkihiko Odaki #define E1000_DEV_ID_82572EI_SERDES      0x107F
83c9653b77SAkihiko Odaki #define E1000_DEV_ID_82572EI             0x10B9
84c9653b77SAkihiko Odaki #define E1000_DEV_ID_82573E              0x108B
85c9653b77SAkihiko Odaki #define E1000_DEV_ID_82573E_IAMT         0x108C
86c9653b77SAkihiko Odaki #define E1000_DEV_ID_82573L              0x109A
87c9653b77SAkihiko Odaki #define E1000_DEV_ID_82574L              0x10D3
88c9653b77SAkihiko Odaki #define E1000_DEV_ID_82546GB_QUAD_COPPER_KSP3 0x10B5
89c9653b77SAkihiko Odaki #define E1000_DEV_ID_80003ES2LAN_COPPER_DPT     0x1096
90c9653b77SAkihiko Odaki #define E1000_DEV_ID_80003ES2LAN_SERDES_DPT     0x1098
91c9653b77SAkihiko Odaki #define E1000_DEV_ID_80003ES2LAN_COPPER_SPT     0x10BA
92c9653b77SAkihiko Odaki #define E1000_DEV_ID_80003ES2LAN_SERDES_SPT     0x10BB
93c9653b77SAkihiko Odaki 
94c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IGP_M_AMT      0x1049
95c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IGP_AMT        0x104A
96c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IGP_C          0x104B
97c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IFE            0x104C
98c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IFE_GT         0x10C4
99c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IFE_G          0x10C5
100c9653b77SAkihiko Odaki #define E1000_DEV_ID_ICH8_IGP_M          0x104D
101c9653b77SAkihiko Odaki 
102c9653b77SAkihiko Odaki /* Device Specific Register Defaults */
103c9653b77SAkihiko Odaki #define E1000_PHY_ID2_82541x 0x380
104c9653b77SAkihiko Odaki #define E1000_PHY_ID2_82544x 0xC30
105c9653b77SAkihiko Odaki #define E1000_PHY_ID2_8254xx_DEFAULT 0xC20 /* 82540x, 82545x, and 82546x */
106c9653b77SAkihiko Odaki #define E1000_PHY_ID2_82573x 0xCC0
107c9653b77SAkihiko Odaki #define E1000_PHY_ID2_82574x 0xCB1
108c9653b77SAkihiko Odaki 
109c9653b77SAkihiko Odaki /* Register Set. (82543, 82544)
110c9653b77SAkihiko Odaki  *
111c9653b77SAkihiko Odaki  * Registers are defined to be 32 bits and  should be accessed as 32 bit values.
112c9653b77SAkihiko Odaki  * These registers are physically located on the NIC, but are mapped into the
113c9653b77SAkihiko Odaki  * host memory address space.
114c9653b77SAkihiko Odaki  *
115c9653b77SAkihiko Odaki  * RW - register is both readable and writable
116c9653b77SAkihiko Odaki  * RO - register is read only
117c9653b77SAkihiko Odaki  * WO - register is write only
118c9653b77SAkihiko Odaki  * R/clr - register is read only and is cleared when read
119c9653b77SAkihiko Odaki  * A - register array
120c9653b77SAkihiko Odaki  */
121c9653b77SAkihiko Odaki #define E1000_CTRL     0x00000  /* Device Control - RW */
122c9653b77SAkihiko Odaki #define E1000_CTRL_DUP 0x00004  /* Device Control Duplicate (Shadow) - RW */
123c9653b77SAkihiko Odaki #define E1000_STATUS   0x00008  /* Device Status - RO */
124c9653b77SAkihiko Odaki #define E1000_EECD     0x00010  /* EEPROM/Flash Control - RW */
125c9653b77SAkihiko Odaki #define E1000_EERD     0x00014  /* EEPROM Read - RW */
126c9653b77SAkihiko Odaki #define E1000_CTRL_EXT 0x00018  /* Extended Device Control - RW */
127c9653b77SAkihiko Odaki #define E1000_FLA      0x0001C  /* Flash Access - RW */
128c9653b77SAkihiko Odaki #define E1000_MDIC     0x00020  /* MDI Control - RW */
129c9653b77SAkihiko Odaki #define E1000_SCTL     0x00024  /* SerDes Control - RW */
130c9653b77SAkihiko Odaki #define E1000_FCAL     0x00028  /* Flow Control Address Low - RW */
131c9653b77SAkihiko Odaki #define E1000_FCAH     0x0002C  /* Flow Control Address High -RW */
132c9653b77SAkihiko Odaki #define E1000_FCT      0x00030  /* Flow Control Type - RW */
133c9653b77SAkihiko Odaki #define E1000_VET      0x00038  /* VLAN Ether Type - RW */
134c9653b77SAkihiko Odaki #define E1000_ICR      0x000C0  /* Interrupt Cause Read - R/clr */
135c9653b77SAkihiko Odaki #define E1000_ICS      0x000C8  /* Interrupt Cause Set - WO */
136c9653b77SAkihiko Odaki #define E1000_IMS      0x000D0  /* Interrupt Mask Set - RW */
137c9653b77SAkihiko Odaki #define E1000_IMC      0x000D8  /* Interrupt Mask Clear - WO */
138c9653b77SAkihiko Odaki #define E1000_IAM      0x000E0  /* Interrupt Acknowledge Auto Mask */
139c9653b77SAkihiko Odaki #define E1000_RCTL     0x00100  /* RX Control - RW */
140c9653b77SAkihiko Odaki #define E1000_FCTTV    0x00170  /* Flow Control Transmit Timer Value - RW */
141c9653b77SAkihiko Odaki #define E1000_TCTL     0x00400  /* TX Control - RW */
142c9653b77SAkihiko Odaki #define E1000_TCTL_EXT 0x00404  /* Extended TX Control - RW */
143c9653b77SAkihiko Odaki #define E1000_TIPG     0x00410  /* TX Inter-packet gap -RW */
144c9653b77SAkihiko Odaki #define E1000_LEDCTL   0x00E00  /* LED Control - RW */
145c9653b77SAkihiko Odaki #define E1000_EEMNGCTL 0x01010  /* MNG EEprom Control */
146c9653b77SAkihiko Odaki #define E1000_EEMNGDATA    0x01014 /* MNG EEPROM Read/Write data */
147c9653b77SAkihiko Odaki #define E1000_FLMNGCTL     0x01018 /* MNG Flash Control */
148c9653b77SAkihiko Odaki #define E1000_FLMNGDATA    0x0101C /* MNG FLASH Read data */
149c9653b77SAkihiko Odaki #define E1000_FLMNGCNT     0x01020 /* MNG FLASH Read Counter */
150c9653b77SAkihiko Odaki #define E1000_EEARBC   0x01024  /* EEPROM Auto Read Bus Control */
151c9653b77SAkihiko Odaki #define E1000_FLOP     0x0103C  /* FLASH Opcode Register */
152c9653b77SAkihiko Odaki #define E1000_FCRTL    0x02160  /* Flow Control Receive Threshold Low - RW */
153c9653b77SAkihiko Odaki #define E1000_FCRTL_A  0x00168  /* Alias to FCRTL */
154c9653b77SAkihiko Odaki #define E1000_FCRTH    0x02168  /* Flow Control Receive Threshold High - RW */
155c9653b77SAkihiko Odaki #define E1000_RDFH     0x02410  /* Receive Data FIFO Head Register - RW */
156c9653b77SAkihiko Odaki #define E1000_RDFH_A   0x08000  /* Alias to RDFH */
157c9653b77SAkihiko Odaki #define E1000_RDFT     0x02418  /* Receive Data FIFO Tail Register - RW */
158c9653b77SAkihiko Odaki #define E1000_RDFT_A   0x08008  /* Alias to RDFT */
159c9653b77SAkihiko Odaki #define E1000_RDFHS    0x02420  /* Receive Data FIFO Head Saved Register - RW */
160c9653b77SAkihiko Odaki #define E1000_RDFTS    0x02428  /* Receive Data FIFO Tail Saved Register - RW */
161c9653b77SAkihiko Odaki #define E1000_RDFPC    0x02430  /* Receive Data FIFO Packet Count - RW */
162c9653b77SAkihiko Odaki #define E1000_TDFH     0x03410  /* TX Data FIFO Head - RW */
163c9653b77SAkihiko Odaki #define E1000_TDFH_A   0x08010  /* Alias to TDFH */
164c9653b77SAkihiko Odaki #define E1000_TDFT     0x03418  /* TX Data FIFO Tail - RW */
165c9653b77SAkihiko Odaki #define E1000_TDFT_A   0x08018  /* Alias to TDFT */
166c9653b77SAkihiko Odaki #define E1000_TDFHS    0x03420  /* TX Data FIFO Head Saved - RW */
167c9653b77SAkihiko Odaki #define E1000_TDFTS    0x03428  /* TX Data FIFO Tail Saved - RW */
168c9653b77SAkihiko Odaki #define E1000_TDFPC    0x03430  /* TX Data FIFO Packet Count - RW */
169c9653b77SAkihiko Odaki #define E1000_CRCERRS  0x04000  /* CRC Error Count - R/clr */
170c9653b77SAkihiko Odaki #define E1000_ALGNERRC 0x04004  /* Alignment Error Count - R/clr */
171c9653b77SAkihiko Odaki #define E1000_SYMERRS  0x04008  /* Symbol Error Count - R/clr */
172c9653b77SAkihiko Odaki #define E1000_RXERRC   0x0400C  /* Receive Error Count - R/clr */
173c9653b77SAkihiko Odaki #define E1000_MPC      0x04010  /* Missed Packet Count - R/clr */
174c9653b77SAkihiko Odaki #define E1000_SCC      0x04014  /* Single Collision Count - R/clr */
175c9653b77SAkihiko Odaki #define E1000_ECOL     0x04018  /* Excessive Collision Count - R/clr */
176c9653b77SAkihiko Odaki #define E1000_MCC      0x0401C  /* Multiple Collision Count - R/clr */
177c9653b77SAkihiko Odaki #define E1000_LATECOL  0x04020  /* Late Collision Count - R/clr */
178c9653b77SAkihiko Odaki #define E1000_COLC     0x04028  /* Collision Count - R/clr */
179c9653b77SAkihiko Odaki #define E1000_DC       0x04030  /* Defer Count - R/clr */
180c9653b77SAkihiko Odaki #define E1000_TNCRS    0x04034  /* TX-No CRS - R/clr */
181c9653b77SAkihiko Odaki #define E1000_RLEC     0x04040  /* Receive Length Error Count - R/clr */
182c9653b77SAkihiko Odaki #define E1000_XONRXC   0x04048  /* XON RX Count - R/clr */
183c9653b77SAkihiko Odaki #define E1000_XONTXC   0x0404C  /* XON TX Count - R/clr */
184c9653b77SAkihiko Odaki #define E1000_XOFFRXC  0x04050  /* XOFF RX Count - R/clr */
185c9653b77SAkihiko Odaki #define E1000_XOFFTXC  0x04054  /* XOFF TX Count - R/clr */
186c9653b77SAkihiko Odaki #define E1000_FCRUC    0x04058  /* Flow Control RX Unsupported Count- R/clr */
187c9653b77SAkihiko Odaki #define E1000_PRC64    0x0405C  /* Packets RX (64 bytes) - R/clr */
188c9653b77SAkihiko Odaki #define E1000_PRC127   0x04060  /* Packets RX (65-127 bytes) - R/clr */
189c9653b77SAkihiko Odaki #define E1000_PRC255   0x04064  /* Packets RX (128-255 bytes) - R/clr */
190c9653b77SAkihiko Odaki #define E1000_PRC511   0x04068  /* Packets RX (255-511 bytes) - R/clr */
191c9653b77SAkihiko Odaki #define E1000_PRC1023  0x0406C  /* Packets RX (512-1023 bytes) - R/clr */
192c9653b77SAkihiko Odaki #define E1000_PRC1522  0x04070  /* Packets RX (1024-1522 bytes) - R/clr */
193c9653b77SAkihiko Odaki #define E1000_GPRC     0x04074  /* Good Packets RX Count - R/clr */
194c9653b77SAkihiko Odaki #define E1000_BPRC     0x04078  /* Broadcast Packets RX Count - R/clr */
195c9653b77SAkihiko Odaki #define E1000_MPRC     0x0407C  /* Multicast Packets RX Count - R/clr */
196c9653b77SAkihiko Odaki #define E1000_GPTC     0x04080  /* Good Packets TX Count - R/clr */
197c9653b77SAkihiko Odaki #define E1000_GORCL    0x04088  /* Good Octets RX Count Low - R/clr */
198c9653b77SAkihiko Odaki #define E1000_GORCH    0x0408C  /* Good Octets RX Count High - R/clr */
199c9653b77SAkihiko Odaki #define E1000_GOTCL    0x04090  /* Good Octets TX Count Low - R/clr */
200c9653b77SAkihiko Odaki #define E1000_GOTCH    0x04094  /* Good Octets TX Count High - R/clr */
201c9653b77SAkihiko Odaki #define E1000_RNBC     0x040A0  /* RX No Buffers Count - R/clr */
202c9653b77SAkihiko Odaki #define E1000_RUC      0x040A4  /* RX Undersize Count - R/clr */
203c9653b77SAkihiko Odaki #define E1000_RFC      0x040A8  /* RX Fragment Count - R/clr */
204c9653b77SAkihiko Odaki #define E1000_ROC      0x040AC  /* RX Oversize Count - R/clr */
205c9653b77SAkihiko Odaki #define E1000_RJC      0x040B0  /* RX Jabber Count - R/clr */
206c9653b77SAkihiko Odaki #define E1000_MGTPRC   0x040B4  /* Management Packets RX Count - R/clr */
207c9653b77SAkihiko Odaki #define E1000_MGTPDC   0x040B8  /* Management Packets Dropped Count - R/clr */
208c9653b77SAkihiko Odaki #define E1000_MGTPTC   0x040BC  /* Management Packets TX Count - R/clr */
209c9653b77SAkihiko Odaki #define E1000_TORL     0x040C0  /* Total Octets RX Low - R/clr */
210c9653b77SAkihiko Odaki #define E1000_TORH     0x040C4  /* Total Octets RX High - R/clr */
211c9653b77SAkihiko Odaki #define E1000_TOTL     0x040C8  /* Total Octets TX Low - R/clr */
212c9653b77SAkihiko Odaki #define E1000_TOTH     0x040CC  /* Total Octets TX High - R/clr */
213c9653b77SAkihiko Odaki #define E1000_TPR      0x040D0  /* Total Packets RX - R/clr */
214c9653b77SAkihiko Odaki #define E1000_TPT      0x040D4  /* Total Packets TX - R/clr */
215c9653b77SAkihiko Odaki #define E1000_PTC64    0x040D8  /* Packets TX (64 bytes) - R/clr */
216c9653b77SAkihiko Odaki #define E1000_PTC127   0x040DC  /* Packets TX (65-127 bytes) - R/clr */
217c9653b77SAkihiko Odaki #define E1000_PTC255   0x040E0  /* Packets TX (128-255 bytes) - R/clr */
218c9653b77SAkihiko Odaki #define E1000_PTC511   0x040E4  /* Packets TX (256-511 bytes) - R/clr */
219c9653b77SAkihiko Odaki #define E1000_PTC1023  0x040E8  /* Packets TX (512-1023 bytes) - R/clr */
220c9653b77SAkihiko Odaki #define E1000_PTC1522  0x040EC  /* Packets TX (1024-1522 Bytes) - R/clr */
221c9653b77SAkihiko Odaki #define E1000_MPTC     0x040F0  /* Multicast Packets TX Count - R/clr */
222c9653b77SAkihiko Odaki #define E1000_BPTC     0x040F4  /* Broadcast Packets TX Count - R/clr */
223c9653b77SAkihiko Odaki #define E1000_TSCTC    0x040F8  /* TCP Segmentation Context TX - R/clr */
224c9653b77SAkihiko Odaki #define E1000_IAC      0x04100  /* Interrupt Assertion Count */
225c9653b77SAkihiko Odaki #define E1000_ICRXPTC  0x04104  /* Interrupt Cause Rx Packet Timer Expire Count */
226c9653b77SAkihiko Odaki #define E1000_ICRXDMTC 0x04120  /* Interrupt Cause Rx Descriptor Minimum Threshold Count */
227c9653b77SAkihiko Odaki #define E1000_RXCSUM   0x05000  /* RX Checksum Control - RW */
228c9653b77SAkihiko Odaki #define E1000_RFCTL    0x05008  /* Receive Filter Control*/
229c9653b77SAkihiko Odaki #define E1000_MAVTV0   0x05010  /* Management VLAN TAG Value 0 */
230c9653b77SAkihiko Odaki #define E1000_MAVTV1   0x05014  /* Management VLAN TAG Value 1 */
231c9653b77SAkihiko Odaki #define E1000_MAVTV2   0x05018  /* Management VLAN TAG Value 2 */
232c9653b77SAkihiko Odaki #define E1000_MAVTV3   0x0501c  /* Management VLAN TAG Value 3 */
233c9653b77SAkihiko Odaki #define E1000_MTA      0x05200  /* Multicast Table Array - RW Array */
234c9653b77SAkihiko Odaki #define E1000_RA       0x05400  /* Receive Address - RW Array */
235c9653b77SAkihiko Odaki #define E1000_RA_A     0x00040  /* Alias to RA */
236c9653b77SAkihiko Odaki #define E1000_VFTA     0x05600  /* VLAN Filter Table Array - RW Array */
237c9653b77SAkihiko Odaki #define E1000_VFTA_A   0x00600  /* Alias to VFTA */
238c9653b77SAkihiko Odaki #define E1000_WUC      0x05800  /* Wakeup Control - RW */
239c9653b77SAkihiko Odaki #define E1000_WUFC     0x05808  /* Wakeup Filter Control - RW */
240c9653b77SAkihiko Odaki #define E1000_WUS      0x05810  /* Wakeup Status - RO */
241c9653b77SAkihiko Odaki #define E1000_MANC     0x05820  /* Management Control - RW */
242c9653b77SAkihiko Odaki #define E1000_IPAV     0x05838  /* IP Address Valid - RW */
243c9653b77SAkihiko Odaki #define E1000_IP4AT    0x05840  /* IPv4 Address Table - RW Array */
244c9653b77SAkihiko Odaki #define E1000_IP6AT    0x05880  /* IPv6 Address Table - RW Array */
245c9653b77SAkihiko Odaki #define E1000_WUPL     0x05900  /* Wakeup Packet Length - RW */
246c9653b77SAkihiko Odaki #define E1000_WUPM     0x05A00  /* Wakeup Packet Memory - RO A */
247c9653b77SAkihiko Odaki #define E1000_MFVAL    0x05824  /* Manageability Filters Valid - RW */
248c9653b77SAkihiko Odaki #define E1000_MDEF     0x05890  /* Manageability Decision Filters - RW Array */
249c9653b77SAkihiko Odaki #define E1000_FFMT     0x09000  /* Flexible Filter Mask Table - RW Array */
250c9653b77SAkihiko Odaki #define E1000_FTFT     0x09400  /* Flexible TCO Filter Table - RW Array */
251c9653b77SAkihiko Odaki 
252c9653b77SAkihiko Odaki #define E1000_MANC2H     0x05860 /* Management Control To Host - RW */
253c9653b77SAkihiko Odaki #define E1000_SW_FW_SYNC 0x05B5C /* Software-Firmware Synchronization - RW */
254c9653b77SAkihiko Odaki 
255c9653b77SAkihiko Odaki #define E1000_GCR       0x05B00 /* PCI-Ex Control */
256c9653b77SAkihiko Odaki #define E1000_FUNCTAG   0x05B08 /* Function-Tag Register */
257c9653b77SAkihiko Odaki #define E1000_GSCL_1    0x05B10 /* PCI-Ex Statistic Control #1 */
258c9653b77SAkihiko Odaki #define E1000_GSCL_2    0x05B14 /* PCI-Ex Statistic Control #2 */
259c9653b77SAkihiko Odaki #define E1000_GSCL_3    0x05B18 /* PCI-Ex Statistic Control #3 */
260c9653b77SAkihiko Odaki #define E1000_GSCL_4    0x05B1C /* PCI-Ex Statistic Control #4 */
261c9653b77SAkihiko Odaki #define E1000_GSCN_0    0x05B20 /* 3GIO Statistic Counter Register #0 */
262c9653b77SAkihiko Odaki #define E1000_GSCN_1    0x05B24 /* 3GIO Statistic Counter Register #1 */
263c9653b77SAkihiko Odaki #define E1000_GSCN_2    0x05B28 /* 3GIO Statistic Counter Register #2 */
264c9653b77SAkihiko Odaki #define E1000_GSCN_3    0x05B2C /* 3GIO Statistic Counter Register #3 */
265c9653b77SAkihiko Odaki #define E1000_FACTPS    0x05B30 /* Function Active and Power State to MNG */
266c9653b77SAkihiko Odaki #define E1000_SWSM      0x05B50 /* SW Semaphore */
267c9653b77SAkihiko Odaki #define E1000_FWSM      0x05B54 /* FW Semaphore */
268c9653b77SAkihiko Odaki #define E1000_PBACLR    0x05B68 /* MSI-X PBA Clear */
269c9653b77SAkihiko Odaki 
270c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL 0x0B620 /* Rx Time Sync Control register - RW */
271c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL 0x0B614 /* Tx Time Sync Control register - RW */
272c9653b77SAkihiko Odaki #define E1000_TIMINCA    0x0B608 /* Increment attributes register - RW */
273c9653b77SAkihiko Odaki #define E1000_RXSTMPL    0x0B624 /* Rx timestamp Low - RO */
274c9653b77SAkihiko Odaki #define E1000_RXSTMPH    0x0B628 /* Rx timestamp High - RO */
275c9653b77SAkihiko Odaki #define E1000_TXSTMPL    0x0B618 /* Tx timestamp value Low - RO */
276c9653b77SAkihiko Odaki #define E1000_TXSTMPH    0x0B61C /* Tx timestamp value High - RO */
277c9653b77SAkihiko Odaki #define E1000_SYSTIML    0x0B600 /* System time register Low - RO */
278c9653b77SAkihiko Odaki #define E1000_SYSTIMH    0x0B604 /* System time register High - RO */
279c9653b77SAkihiko Odaki #define E1000_TIMINCA    0x0B608 /* Increment attributes register - RW */
280c9653b77SAkihiko Odaki #define E1000_RXSATRL    0x0B62C /* Rx timestamp attribute low - RO */
281c9653b77SAkihiko Odaki #define E1000_RXSATRH    0x0B630 /* Rx timestamp attribute high - RO */
282c9653b77SAkihiko Odaki #define E1000_TIMADJL    0x0B60C /* Time Adjustment Offset register Low - RW */
283c9653b77SAkihiko Odaki #define E1000_TIMADJH    0x0B610 /* Time Adjustment Offset register High - RW */
284c9653b77SAkihiko Odaki 
285c9653b77SAkihiko Odaki /* RSS registers */
286c9653b77SAkihiko Odaki #define E1000_MRQC      0x05818 /* Multiple Receive Control - RW */
287c9653b77SAkihiko Odaki #define E1000_RETA      0x05C00 /* Redirection Table - RW Array */
288c9653b77SAkihiko Odaki #define E1000_RSSRK     0x05C80 /* RSS Random Key - RW Array */
289c9653b77SAkihiko Odaki 
290c9653b77SAkihiko Odaki #define E1000_RETA_IDX(hash)        ((hash) & (BIT(7) - 1))
291c9653b77SAkihiko Odaki #define E1000_RETA_VAL(reta, hash)  (((uint8_t *)(reta))[E1000_RETA_IDX(hash)])
292c9653b77SAkihiko Odaki 
293c9653b77SAkihiko Odaki #define E1000_MRQC_EN_TCPIPV4(mrqc)   ((mrqc) & BIT(16))
294c9653b77SAkihiko Odaki #define E1000_MRQC_EN_IPV4(mrqc)      ((mrqc) & BIT(17))
2955052fc9eSAkihiko Odaki #define E1000_MRQC_EN_TCPIPV6EX(mrqc) ((mrqc) & BIT(18))
296c9653b77SAkihiko Odaki #define E1000_MRQC_EN_IPV6EX(mrqc)    ((mrqc) & BIT(19))
297c9653b77SAkihiko Odaki #define E1000_MRQC_EN_IPV6(mrqc)      ((mrqc) & BIT(20))
298c9653b77SAkihiko Odaki 
299c9653b77SAkihiko Odaki #define E1000_MRQ_RSS_TYPE_NONE       (0)
300c9653b77SAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV4TCP    (1)
301c9653b77SAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV4       (2)
3025052fc9eSAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV6TCPEX  (3)
303c9653b77SAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV6EX     (4)
304c9653b77SAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV6       (5)
305c9653b77SAkihiko Odaki 
306c9653b77SAkihiko Odaki #define E1000_ICR_ASSERTED BIT(31)
307c9653b77SAkihiko Odaki #define E1000_EIAC_MASK    0x01F00000
308c9653b77SAkihiko Odaki 
309c9653b77SAkihiko Odaki /* RFCTL register bits */
310c9653b77SAkihiko Odaki #define E1000_RFCTL_ISCSI_DIS           0x00000001
311c9653b77SAkihiko Odaki #define E1000_RFCTL_NFSW_DIS            0x00000040
312c9653b77SAkihiko Odaki #define E1000_RFCTL_NFSR_DIS            0x00000080
313c9653b77SAkihiko Odaki #define E1000_RFCTL_IPV6_DIS            0x00000400
314c9653b77SAkihiko Odaki #define E1000_RFCTL_IPV6_XSUM_DIS       0x00000800
315c9653b77SAkihiko Odaki #define E1000_RFCTL_IPFRSP_DIS          0x00004000
316c9653b77SAkihiko Odaki #define E1000_RFCTL_EXTEN               0x00008000
317c9653b77SAkihiko Odaki #define E1000_RFCTL_IPV6_EX_DIS         0x00010000
318c9653b77SAkihiko Odaki #define E1000_RFCTL_NEW_IPV6_EXT_DIS    0x00020000
319c9653b77SAkihiko Odaki 
320c9653b77SAkihiko Odaki /* TARC* parsing */
321c9653b77SAkihiko Odaki #define E1000_TARC_ENABLE BIT(10)
322c9653b77SAkihiko Odaki 
323c9653b77SAkihiko Odaki /* SW Semaphore Register */
324c9653b77SAkihiko Odaki #define E1000_SWSM_SMBI         0x00000001 /* Driver Semaphore bit */
325c9653b77SAkihiko Odaki #define E1000_SWSM_SWESMBI      0x00000002 /* FW Semaphore bit */
326c9653b77SAkihiko Odaki #define E1000_SWSM_DRV_LOAD     0x00000008 /* Driver Loaded Bit */
327c9653b77SAkihiko Odaki 
328c9653b77SAkihiko Odaki #define E1000_SWSM2_LOCK        0x00000002 /* Secondary driver semaphore bit */
329c9653b77SAkihiko Odaki 
330c9653b77SAkihiko Odaki /* Interrupt Cause Read */
331c9653b77SAkihiko Odaki #define E1000_ICR_TXDW          0x00000001 /* Transmit desc written back */
332c9653b77SAkihiko Odaki #define E1000_ICR_TXQE          0x00000002 /* Transmit Queue empty */
333c9653b77SAkihiko Odaki #define E1000_ICR_LSC           0x00000004 /* Link Status Change */
334c9653b77SAkihiko Odaki #define E1000_ICR_RXSEQ         0x00000008 /* rx sequence error */
335c9653b77SAkihiko Odaki #define E1000_ICR_RXDMT0        0x00000010 /* rx desc min. threshold (0) */
336c9653b77SAkihiko Odaki #define E1000_ICR_RXO           0x00000040 /* rx overrun */
337c9653b77SAkihiko Odaki #define E1000_ICR_RXT0          0x00000080 /* rx timer intr (ring 0) */
3381c1e6497SSriram Yagnaraman #define E1000_ICR_RXDW          0x00000080 /* rx desc written back */
339c9653b77SAkihiko Odaki #define E1000_ICR_MDAC          0x00000200 /* MDIO access complete */
340c9653b77SAkihiko Odaki #define E1000_ICR_RXCFG         0x00000400 /* RX /c/ ordered set */
341c9653b77SAkihiko Odaki #define E1000_ICR_GPI_EN0       0x00000800 /* GP Int 0 */
342c9653b77SAkihiko Odaki #define E1000_ICR_GPI_EN1       0x00001000 /* GP Int 1 */
343c9653b77SAkihiko Odaki #define E1000_ICR_GPI_EN2       0x00002000 /* GP Int 2 */
344c9653b77SAkihiko Odaki #define E1000_ICR_GPI_EN3       0x00004000 /* GP Int 3 */
345c9653b77SAkihiko Odaki #define E1000_ICR_TXD_LOW       0x00008000
346c9653b77SAkihiko Odaki #define E1000_ICR_SRPD          0x00010000
347c9653b77SAkihiko Odaki #define E1000_ICR_ACK           0x00020000 /* Receive Ack frame */
348c9653b77SAkihiko Odaki #define E1000_ICR_MNG           0x00040000 /* Manageability event */
349c9653b77SAkihiko Odaki #define E1000_ICR_DOCK          0x00080000 /* Dock/Undock */
350c9653b77SAkihiko Odaki #define E1000_ICR_INT_ASSERTED  0x80000000 /* If this bit asserted, the driver should claim the interrupt */
351c9653b77SAkihiko Odaki #define E1000_ICR_RXD_FIFO_PAR0 0x00100000 /* queue 0 Rx descriptor FIFO parity error */
352c9653b77SAkihiko Odaki #define E1000_ICR_TXD_FIFO_PAR0 0x00200000 /* queue 0 Tx descriptor FIFO parity error */
353c9653b77SAkihiko Odaki #define E1000_ICR_HOST_ARB_PAR  0x00400000 /* host arb read buffer parity error */
354c9653b77SAkihiko Odaki #define E1000_ICR_PB_PAR        0x00800000 /* packet buffer parity error */
355c9653b77SAkihiko Odaki #define E1000_ICR_RXD_FIFO_PAR1 0x01000000 /* queue 1 Rx descriptor FIFO parity error */
356c9653b77SAkihiko Odaki #define E1000_ICR_TXD_FIFO_PAR1 0x02000000 /* queue 1 Tx descriptor FIFO parity error */
357c9653b77SAkihiko Odaki #define E1000_ICR_ALL_PARITY    0x03F00000 /* all parity error bits */
358c9653b77SAkihiko Odaki #define E1000_ICR_DSW           0x00000020 /* FW changed the status of DISSW bit in the FWSM */
359c9653b77SAkihiko Odaki #define E1000_ICR_PHYINT        0x00001000 /* LAN connected device generates an interrupt */
360c9653b77SAkihiko Odaki #define E1000_ICR_EPRST         0x00100000 /* ME handware reset occurs */
361c9653b77SAkihiko Odaki #define E1000_ICR_RXQ0          0x00100000 /* Rx Queue 0 Interrupt */
362c9653b77SAkihiko Odaki #define E1000_ICR_RXQ1          0x00200000 /* Rx Queue 1 Interrupt */
363c9653b77SAkihiko Odaki #define E1000_ICR_TXQ0          0x00400000 /* Tx Queue 0 Interrupt */
364c9653b77SAkihiko Odaki #define E1000_ICR_TXQ1          0x00800000 /* Tx Queue 1 Interrupt */
365c9653b77SAkihiko Odaki #define E1000_ICR_OTHER         0x01000000 /* Other Interrupts */
366c9653b77SAkihiko Odaki 
367c9653b77SAkihiko Odaki #define E1000_ICR_OTHER_CAUSES (E1000_ICR_LSC  | \
368c9653b77SAkihiko Odaki                                 E1000_ICR_RXO  | \
369c9653b77SAkihiko Odaki                                 E1000_ICR_MDAC | \
370c9653b77SAkihiko Odaki                                 E1000_ICR_SRPD | \
371c9653b77SAkihiko Odaki                                 E1000_ICR_ACK  | \
372c9653b77SAkihiko Odaki                                 E1000_ICR_MNG)
373c9653b77SAkihiko Odaki 
374c9653b77SAkihiko Odaki /* Interrupt Cause Set */
375c9653b77SAkihiko Odaki #define E1000_ICS_TXDW      E1000_ICR_TXDW      /* Transmit desc written back */
376c9653b77SAkihiko Odaki #define E1000_ICS_TXQE      E1000_ICR_TXQE      /* Transmit Queue empty */
377c9653b77SAkihiko Odaki #define E1000_ICS_LSC       E1000_ICR_LSC       /* Link Status Change */
378c9653b77SAkihiko Odaki #define E1000_ICS_RXSEQ     E1000_ICR_RXSEQ     /* rx sequence error */
379c9653b77SAkihiko Odaki #define E1000_ICS_RXDMT0    E1000_ICR_RXDMT0    /* rx desc min. threshold */
380c9653b77SAkihiko Odaki #define E1000_ICS_RXO       E1000_ICR_RXO       /* rx overrun */
381c9653b77SAkihiko Odaki #define E1000_ICS_RXT0      E1000_ICR_RXT0      /* rx timer intr */
3821c1e6497SSriram Yagnaraman #define E1000_ICS_RXDW      E1000_ICR_RXDW      /* rx desc written back */
383c9653b77SAkihiko Odaki #define E1000_ICS_MDAC      E1000_ICR_MDAC      /* MDIO access complete */
384c9653b77SAkihiko Odaki #define E1000_ICS_RXCFG     E1000_ICR_RXCFG     /* RX /c/ ordered set */
385c9653b77SAkihiko Odaki #define E1000_ICS_GPI_EN0   E1000_ICR_GPI_EN0   /* GP Int 0 */
386c9653b77SAkihiko Odaki #define E1000_ICS_GPI_EN1   E1000_ICR_GPI_EN1   /* GP Int 1 */
387c9653b77SAkihiko Odaki #define E1000_ICS_GPI_EN2   E1000_ICR_GPI_EN2   /* GP Int 2 */
388c9653b77SAkihiko Odaki #define E1000_ICS_GPI_EN3   E1000_ICR_GPI_EN3   /* GP Int 3 */
389c9653b77SAkihiko Odaki #define E1000_ICS_TXD_LOW   E1000_ICR_TXD_LOW
390c9653b77SAkihiko Odaki #define E1000_ICS_SRPD      E1000_ICR_SRPD
391c9653b77SAkihiko Odaki #define E1000_ICS_ACK       E1000_ICR_ACK       /* Receive Ack frame */
392c9653b77SAkihiko Odaki #define E1000_ICS_MNG       E1000_ICR_MNG       /* Manageability event */
393c9653b77SAkihiko Odaki #define E1000_ICS_DOCK      E1000_ICR_DOCK      /* Dock/Undock */
394c9653b77SAkihiko Odaki #define E1000_ICS_RXD_FIFO_PAR0 E1000_ICR_RXD_FIFO_PAR0 /* queue 0 Rx descriptor FIFO parity error */
395c9653b77SAkihiko Odaki #define E1000_ICS_TXD_FIFO_PAR0 E1000_ICR_TXD_FIFO_PAR0 /* queue 0 Tx descriptor FIFO parity error */
396c9653b77SAkihiko Odaki #define E1000_ICS_HOST_ARB_PAR  E1000_ICR_HOST_ARB_PAR  /* host arb read buffer parity error */
397c9653b77SAkihiko Odaki #define E1000_ICS_PB_PAR        E1000_ICR_PB_PAR        /* packet buffer parity error */
398c9653b77SAkihiko Odaki #define E1000_ICS_RXD_FIFO_PAR1 E1000_ICR_RXD_FIFO_PAR1 /* queue 1 Rx descriptor FIFO parity error */
399c9653b77SAkihiko Odaki #define E1000_ICS_TXD_FIFO_PAR1 E1000_ICR_TXD_FIFO_PAR1 /* queue 1 Tx descriptor FIFO parity error */
400c9653b77SAkihiko Odaki #define E1000_ICS_DSW       E1000_ICR_DSW
401c9653b77SAkihiko Odaki #define E1000_ICS_PHYINT    E1000_ICR_PHYINT
402c9653b77SAkihiko Odaki #define E1000_ICS_EPRST     E1000_ICR_EPRST
403c9653b77SAkihiko Odaki 
404c9653b77SAkihiko Odaki /* Interrupt Mask Set */
405c9653b77SAkihiko Odaki #define E1000_IMS_TXDW      E1000_ICR_TXDW      /* Transmit desc written back */
406c9653b77SAkihiko Odaki #define E1000_IMS_TXQE      E1000_ICR_TXQE      /* Transmit Queue empty */
407c9653b77SAkihiko Odaki #define E1000_IMS_LSC       E1000_ICR_LSC       /* Link Status Change */
408c9653b77SAkihiko Odaki #define E1000_IMS_RXSEQ     E1000_ICR_RXSEQ     /* rx sequence error */
409c9653b77SAkihiko Odaki #define E1000_IMS_RXDMT0    E1000_ICR_RXDMT0    /* rx desc min. threshold */
410c9653b77SAkihiko Odaki #define E1000_IMS_RXO       E1000_ICR_RXO       /* rx overrun */
411c9653b77SAkihiko Odaki #define E1000_IMS_RXT0      E1000_ICR_RXT0      /* rx timer intr */
4121c1e6497SSriram Yagnaraman #define E1000_IMS_RXDW      E1000_ICR_RXDW      /* rx desc written back */
413c9653b77SAkihiko Odaki #define E1000_IMS_MDAC      E1000_ICR_MDAC      /* MDIO access complete */
414c9653b77SAkihiko Odaki #define E1000_IMS_RXCFG     E1000_ICR_RXCFG     /* RX /c/ ordered set */
415c9653b77SAkihiko Odaki #define E1000_IMS_GPI_EN0   E1000_ICR_GPI_EN0   /* GP Int 0 */
416c9653b77SAkihiko Odaki #define E1000_IMS_GPI_EN1   E1000_ICR_GPI_EN1   /* GP Int 1 */
417c9653b77SAkihiko Odaki #define E1000_IMS_GPI_EN2   E1000_ICR_GPI_EN2   /* GP Int 2 */
418c9653b77SAkihiko Odaki #define E1000_IMS_GPI_EN3   E1000_ICR_GPI_EN3   /* GP Int 3 */
419c9653b77SAkihiko Odaki #define E1000_IMS_TXD_LOW   E1000_ICR_TXD_LOW
420c9653b77SAkihiko Odaki #define E1000_IMS_SRPD      E1000_ICR_SRPD
421c9653b77SAkihiko Odaki #define E1000_IMS_ACK       E1000_ICR_ACK       /* Receive Ack frame */
422c9653b77SAkihiko Odaki #define E1000_IMS_MNG       E1000_ICR_MNG       /* Manageability event */
423c9653b77SAkihiko Odaki #define E1000_IMS_RXQ0      E1000_ICR_RXQ0
424c9653b77SAkihiko Odaki #define E1000_IMS_RXQ1      E1000_ICR_RXQ1
425c9653b77SAkihiko Odaki #define E1000_IMS_TXQ0      E1000_ICR_TXQ0
426c9653b77SAkihiko Odaki #define E1000_IMS_TXQ1      E1000_ICR_TXQ1
427c9653b77SAkihiko Odaki #define E1000_IMS_OTHER     E1000_ICR_OTHER
428c9653b77SAkihiko Odaki #define E1000_IMS_DOCK      E1000_ICR_DOCK      /* Dock/Undock */
429c9653b77SAkihiko Odaki #define E1000_IMS_RXD_FIFO_PAR0 E1000_ICR_RXD_FIFO_PAR0 /* queue 0 Rx descriptor FIFO parity error */
430c9653b77SAkihiko Odaki #define E1000_IMS_TXD_FIFO_PAR0 E1000_ICR_TXD_FIFO_PAR0 /* queue 0 Tx descriptor FIFO parity error */
431c9653b77SAkihiko Odaki #define E1000_IMS_HOST_ARB_PAR  E1000_ICR_HOST_ARB_PAR  /* host arb read buffer parity error */
432c9653b77SAkihiko Odaki #define E1000_IMS_PB_PAR        E1000_ICR_PB_PAR        /* packet buffer parity error */
433c9653b77SAkihiko Odaki #define E1000_IMS_RXD_FIFO_PAR1 E1000_ICR_RXD_FIFO_PAR1 /* queue 1 Rx descriptor FIFO parity error */
434c9653b77SAkihiko Odaki #define E1000_IMS_TXD_FIFO_PAR1 E1000_ICR_TXD_FIFO_PAR1 /* queue 1 Tx descriptor FIFO parity error */
435c9653b77SAkihiko Odaki #define E1000_IMS_DSW       E1000_ICR_DSW
436c9653b77SAkihiko Odaki #define E1000_IMS_PHYINT    E1000_ICR_PHYINT
437c9653b77SAkihiko Odaki #define E1000_IMS_EPRST     E1000_ICR_EPRST
438c9653b77SAkihiko Odaki 
439c9653b77SAkihiko Odaki /* Interrupt Mask Clear */
440c9653b77SAkihiko Odaki #define E1000_IMC_TXDW      E1000_ICR_TXDW      /* Transmit desc written back */
441c9653b77SAkihiko Odaki #define E1000_IMC_TXQE      E1000_ICR_TXQE      /* Transmit Queue empty */
442c9653b77SAkihiko Odaki #define E1000_IMC_LSC       E1000_ICR_LSC       /* Link Status Change */
443c9653b77SAkihiko Odaki #define E1000_IMC_RXSEQ     E1000_ICR_RXSEQ     /* rx sequence error */
444c9653b77SAkihiko Odaki #define E1000_IMC_RXDMT0    E1000_ICR_RXDMT0    /* rx desc min. threshold */
445c9653b77SAkihiko Odaki #define E1000_IMC_RXO       E1000_ICR_RXO       /* rx overrun */
446c9653b77SAkihiko Odaki #define E1000_IMC_RXT0      E1000_ICR_RXT0      /* rx timer intr */
4471c1e6497SSriram Yagnaraman #define E1000_IMC_RXDW      E1000_ICR_RXDW      /* rx desc written back */
448c9653b77SAkihiko Odaki #define E1000_IMC_MDAC      E1000_ICR_MDAC      /* MDIO access complete */
449c9653b77SAkihiko Odaki #define E1000_IMC_RXCFG     E1000_ICR_RXCFG     /* RX /c/ ordered set */
450c9653b77SAkihiko Odaki #define E1000_IMC_GPI_EN0   E1000_ICR_GPI_EN0   /* GP Int 0 */
451c9653b77SAkihiko Odaki #define E1000_IMC_GPI_EN1   E1000_ICR_GPI_EN1   /* GP Int 1 */
452c9653b77SAkihiko Odaki #define E1000_IMC_GPI_EN2   E1000_ICR_GPI_EN2   /* GP Int 2 */
453c9653b77SAkihiko Odaki #define E1000_IMC_GPI_EN3   E1000_ICR_GPI_EN3   /* GP Int 3 */
454c9653b77SAkihiko Odaki #define E1000_IMC_TXD_LOW   E1000_ICR_TXD_LOW
455c9653b77SAkihiko Odaki #define E1000_IMC_SRPD      E1000_ICR_SRPD
456c9653b77SAkihiko Odaki #define E1000_IMC_ACK       E1000_ICR_ACK       /* Receive Ack frame */
457c9653b77SAkihiko Odaki #define E1000_IMC_MNG       E1000_ICR_MNG       /* Manageability event */
458c9653b77SAkihiko Odaki #define E1000_IMC_DOCK      E1000_ICR_DOCK      /* Dock/Undock */
459c9653b77SAkihiko Odaki #define E1000_IMC_RXD_FIFO_PAR0 E1000_ICR_RXD_FIFO_PAR0 /* queue 0 Rx descriptor FIFO parity error */
460c9653b77SAkihiko Odaki #define E1000_IMC_TXD_FIFO_PAR0 E1000_ICR_TXD_FIFO_PAR0 /* queue 0 Tx descriptor FIFO parity error */
461c9653b77SAkihiko Odaki #define E1000_IMC_HOST_ARB_PAR  E1000_ICR_HOST_ARB_PAR  /* host arb read buffer parity error */
462c9653b77SAkihiko Odaki #define E1000_IMC_PB_PAR        E1000_ICR_PB_PAR        /* packet buffer parity error */
463c9653b77SAkihiko Odaki #define E1000_IMC_RXD_FIFO_PAR1 E1000_ICR_RXD_FIFO_PAR1 /* queue 1 Rx descriptor FIFO parity error */
464c9653b77SAkihiko Odaki #define E1000_IMC_TXD_FIFO_PAR1 E1000_ICR_TXD_FIFO_PAR1 /* queue 1 Tx descriptor FIFO parity error */
465c9653b77SAkihiko Odaki #define E1000_IMC_DSW       E1000_ICR_DSW
466c9653b77SAkihiko Odaki #define E1000_IMC_PHYINT    E1000_ICR_PHYINT
467c9653b77SAkihiko Odaki #define E1000_IMC_EPRST     E1000_ICR_EPRST
468c9653b77SAkihiko Odaki 
469c9653b77SAkihiko Odaki /* Receive Control */
470c9653b77SAkihiko Odaki #define E1000_RCTL_RST            0x00000001    /* Software reset */
471c9653b77SAkihiko Odaki #define E1000_RCTL_EN             0x00000002    /* enable */
472c9653b77SAkihiko Odaki #define E1000_RCTL_SBP            0x00000004    /* store bad packet */
473c9653b77SAkihiko Odaki #define E1000_RCTL_UPE            0x00000008    /* unicast promiscuous enable */
474c9653b77SAkihiko Odaki #define E1000_RCTL_MPE            0x00000010    /* multicast promiscuous enab */
475c9653b77SAkihiko Odaki #define E1000_RCTL_LPE            0x00000020    /* long packet enable */
476c9653b77SAkihiko Odaki #define E1000_RCTL_LBM_NO         0x00000000    /* no loopback mode */
477c9653b77SAkihiko Odaki #define E1000_RCTL_LBM_MAC        0x00000040    /* MAC loopback mode */
478c9653b77SAkihiko Odaki #define E1000_RCTL_LBM_SLP        0x00000080    /* serial link loopback mode */
479c9653b77SAkihiko Odaki #define E1000_RCTL_LBM_TCVR       0x000000C0    /* tcvr loopback mode */
480c9653b77SAkihiko Odaki #define E1000_RCTL_DTYP_MASK      0x00000C00    /* Descriptor type mask */
481c9653b77SAkihiko Odaki #define E1000_RCTL_DTYP_PS        0x00000400    /* Packet Split descriptor */
482c9653b77SAkihiko Odaki #define E1000_RCTL_RDMTS_HALF     0x00000000    /* rx desc min threshold size */
483c9653b77SAkihiko Odaki #define E1000_RCTL_RDMTS_QUAT     0x00000100    /* rx desc min threshold size */
484c9653b77SAkihiko Odaki #define E1000_RCTL_RDMTS_EIGTH    0x00000200    /* rx desc min threshold size */
485c9653b77SAkihiko Odaki #define E1000_RCTL_MO_SHIFT       12            /* multicast offset shift */
486c9653b77SAkihiko Odaki #define E1000_RCTL_MO_0           0x00000000    /* multicast offset 11:0 */
487c9653b77SAkihiko Odaki #define E1000_RCTL_MO_1           0x00001000    /* multicast offset 12:1 */
488c9653b77SAkihiko Odaki #define E1000_RCTL_MO_2           0x00002000    /* multicast offset 13:2 */
489c9653b77SAkihiko Odaki #define E1000_RCTL_MO_3           0x00003000    /* multicast offset 15:4 */
490c9653b77SAkihiko Odaki #define E1000_RCTL_MDR            0x00004000    /* multicast desc ring 0 */
491c9653b77SAkihiko Odaki #define E1000_RCTL_BAM            0x00008000    /* broadcast enable */
492c9653b77SAkihiko Odaki /* these buffer sizes are valid if E1000_RCTL_BSEX is 0 */
493c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_2048        0x00000000    /* rx buffer size 2048 */
494c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_1024        0x00010000    /* rx buffer size 1024 */
495c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_512         0x00020000    /* rx buffer size 512 */
496c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_256         0x00030000    /* rx buffer size 256 */
497c9653b77SAkihiko Odaki /* these buffer sizes are valid if E1000_RCTL_BSEX is 1 */
498c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_16384       0x00010000    /* rx buffer size 16384 */
499c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_8192        0x00020000    /* rx buffer size 8192 */
500c9653b77SAkihiko Odaki #define E1000_RCTL_SZ_4096        0x00030000    /* rx buffer size 4096 */
501c9653b77SAkihiko Odaki #define E1000_RCTL_VFE            0x00040000    /* vlan filter enable */
502c9653b77SAkihiko Odaki #define E1000_RCTL_CFIEN          0x00080000    /* canonical form enable */
503c9653b77SAkihiko Odaki #define E1000_RCTL_CFI            0x00100000    /* canonical form indicator */
504c9653b77SAkihiko Odaki #define E1000_RCTL_DPF            0x00400000    /* discard pause frames */
505c9653b77SAkihiko Odaki #define E1000_RCTL_PMCF           0x00800000    /* pass MAC control frames */
506c9653b77SAkihiko Odaki #define E1000_RCTL_BSEX           0x02000000    /* Buffer size extension */
507c9653b77SAkihiko Odaki #define E1000_RCTL_SECRC          0x04000000    /* Strip Ethernet CRC */
508c9653b77SAkihiko Odaki #define E1000_RCTL_FLXBUF_MASK    0x78000000    /* Flexible buffer size */
509c9653b77SAkihiko Odaki #define E1000_RCTL_FLXBUF_SHIFT   27            /* Flexible buffer shift */
510c9653b77SAkihiko Odaki 
511c9653b77SAkihiko Odaki 
512c9653b77SAkihiko Odaki #define E1000_EEPROM_SWDPIN0   0x0001   /* SWDPIN 0 EEPROM Value */
513c9653b77SAkihiko Odaki #define E1000_EEPROM_LED_LOGIC 0x0020   /* Led Logic Word */
514c9653b77SAkihiko Odaki #define E1000_EEPROM_RW_REG_DATA   16   /* Offset to data in EEPROM read/write registers */
515c9653b77SAkihiko Odaki #define E1000_EEPROM_RW_REG_DONE   0x10 /* Offset to READ/WRITE done bit */
516c9653b77SAkihiko Odaki #define E1000_EEPROM_RW_REG_START  1    /* First bit for telling part to start operation */
517c9653b77SAkihiko Odaki #define E1000_EEPROM_RW_ADDR_SHIFT 8    /* Shift to the address bits */
518c9653b77SAkihiko Odaki #define E1000_EEPROM_POLL_WRITE    1    /* Flag for polling for write complete */
519c9653b77SAkihiko Odaki #define E1000_EEPROM_POLL_READ     0    /* Flag for polling for read complete */
520c9653b77SAkihiko Odaki 
521c9653b77SAkihiko Odaki /* 82574 EERD/EEWR registers layout */
522c9653b77SAkihiko Odaki #define E1000_EERW_START        BIT(0)
523c9653b77SAkihiko Odaki #define E1000_EERW_DONE         BIT(1)
524c9653b77SAkihiko Odaki #define E1000_EERW_ADDR_SHIFT   2
525c9653b77SAkihiko Odaki #define E1000_EERW_ADDR_MASK    ((1L << 14) - 1)
526c9653b77SAkihiko Odaki #define E1000_EERW_DATA_SHIFT   16
527c9653b77SAkihiko Odaki #define E1000_EERW_DATA_MASK   ((1L << 16) - 1)
528c9653b77SAkihiko Odaki 
529c9653b77SAkihiko Odaki /* Register Bit Masks */
530c9653b77SAkihiko Odaki /* Device Control */
531c9653b77SAkihiko Odaki #define E1000_CTRL_FD       0x00000001  /* Full duplex.0=half; 1=full */
532c9653b77SAkihiko Odaki #define E1000_CTRL_BEM      0x00000002  /* Endian Mode.0=little,1=big */
533c9653b77SAkihiko Odaki #define E1000_CTRL_PRIOR    0x00000004  /* Priority on PCI. 0=rx,1=fair */
534c9653b77SAkihiko Odaki #define E1000_CTRL_GIO_MASTER_DISABLE 0x00000004 /*Blocks new Master requests */
535c9653b77SAkihiko Odaki #define E1000_CTRL_LRST     0x00000008  /* Link reset. 0=normal,1=reset */
536c9653b77SAkihiko Odaki #define E1000_CTRL_TME      0x00000010  /* Test mode. 0=normal,1=test */
537c9653b77SAkihiko Odaki #define E1000_CTRL_SLE      0x00000020  /* Serial Link on 0=dis,1=en */
538c9653b77SAkihiko Odaki #define E1000_CTRL_ASDE     0x00000020  /* Auto-speed detect enable */
539c9653b77SAkihiko Odaki #define E1000_CTRL_SLU      0x00000040  /* Set link up (Force Link) */
540c9653b77SAkihiko Odaki #define E1000_CTRL_ILOS     0x00000080  /* Invert Loss-Of Signal */
541c9653b77SAkihiko Odaki #define E1000_CTRL_SPD_SEL  0x00000300  /* Speed Select Mask */
542c9653b77SAkihiko Odaki #define E1000_CTRL_SPD_10   0x00000000  /* Force 10Mb */
543c9653b77SAkihiko Odaki #define E1000_CTRL_SPD_100  0x00000100  /* Force 100Mb */
544c9653b77SAkihiko Odaki #define E1000_CTRL_SPD_1000 0x00000200  /* Force 1Gb */
545c9653b77SAkihiko Odaki #define E1000_CTRL_BEM32    0x00000400  /* Big Endian 32 mode */
546c9653b77SAkihiko Odaki #define E1000_CTRL_FRCSPD   0x00000800  /* Force Speed */
547c9653b77SAkihiko Odaki #define E1000_CTRL_FRCDPX   0x00001000  /* Force Duplex */
548c9653b77SAkihiko Odaki #define E1000_CTRL_D_UD_EN  0x00002000  /* Dock/Undock enable */
549c9653b77SAkihiko Odaki #define E1000_CTRL_D_UD_POLARITY 0x00004000 /* Defined polarity of Dock/Undock indication in SDP[0] */
550c9653b77SAkihiko Odaki #define E1000_CTRL_FORCE_PHY_RESET 0x00008000 /* Reset both PHY ports, through PHYRST_N pin */
551c9653b77SAkihiko Odaki #define E1000_CTRL_SPD_SHIFT 8          /* Speed Select Shift */
552c9653b77SAkihiko Odaki 
553c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_ASDCHK  0x00001000 /* auto speed detection check */
554c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_EE_RST  0x00002000 /* EEPROM reset */
555c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_LINK_EN 0x00010000 /* enable link status from external LINK_0 and LINK_1 pins */
556c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_DRV_LOAD 0x10000000 /* Driver loaded bit for FW */
557c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_EIAME   0x01000000
558c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_IAME    0x08000000 /* Int ACK Auto-mask */
559c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_PBA_CLR 0x80000000 /* PBA Clear */
560c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_INT_TIMERS_CLEAR_ENA 0x20000000
561c9653b77SAkihiko Odaki #define E1000_CTRL_EXT_SPD_BYPS  0x00008000 /* Speed Select Bypass */
562c9653b77SAkihiko Odaki 
563c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIN0  0x00040000  /* SWDPIN 0 value */
564c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIN1  0x00080000  /* SWDPIN 1 value */
565c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIN2  0x00100000  /* SWDPIN 2 value */
566c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIN3  0x00200000  /* SWDPIN 3 value */
567c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIO0  0x00400000  /* SWDPIN 0 Input or output */
568c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIO1  0x00800000  /* SWDPIN 1 input or output */
569c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIO2  0x01000000  /* SWDPIN 2 input or output */
570c9653b77SAkihiko Odaki #define E1000_CTRL_SWDPIO3  0x02000000  /* SWDPIN 3 input or output */
571c9653b77SAkihiko Odaki #define E1000_CTRL_ADVD3WUC 0x00100000  /* D3 WUC */
572c9653b77SAkihiko Odaki #define E1000_CTRL_RST      0x04000000  /* Global reset */
573c9653b77SAkihiko Odaki #define E1000_CTRL_RFCE     0x08000000  /* Receive Flow Control enable */
574c9653b77SAkihiko Odaki #define E1000_CTRL_TFCE     0x10000000  /* Transmit flow control enable */
575c9653b77SAkihiko Odaki #define E1000_CTRL_RTE      0x20000000  /* Routing tag enable */
576c9653b77SAkihiko Odaki #define E1000_CTRL_VME      0x40000000  /* IEEE VLAN mode enable */
577c9653b77SAkihiko Odaki #define E1000_CTRL_PHY_RST  0x80000000  /* PHY Reset */
578c9653b77SAkihiko Odaki #define E1000_CTRL_SW2FW_INT 0x02000000  /* Initiate an interrupt to manageability engine */
579c9653b77SAkihiko Odaki 
580c9653b77SAkihiko Odaki /* Device Status */
581c9653b77SAkihiko Odaki #define E1000_STATUS_FD                 0x00000001 /* Full duplex.0=half,1=full */
582c9653b77SAkihiko Odaki #define E1000_STATUS_LU                 0x00000002 /* Link up.0=no,1=link */
583c9653b77SAkihiko Odaki #define E1000_STATUS_SPEED_10           0x00000000 /* Speed 10Mb/s */
584c9653b77SAkihiko Odaki #define E1000_STATUS_SPEED_100          0x00000040 /* Speed 100Mb/s */
585c9653b77SAkihiko Odaki #define E1000_STATUS_SPEED_1000         0x00000080 /* Speed 1000Mb/s */
586c9653b77SAkihiko Odaki #define E1000_STATUS_PHYRA              0x00000400 /* PHY Reset Asserted */
587c9653b77SAkihiko Odaki #define E1000_STATUS_GIO_MASTER_ENABLE  0x00080000
588c9653b77SAkihiko Odaki 
589c9653b77SAkihiko Odaki /* EEPROM/Flash Control */
590c9653b77SAkihiko Odaki #define E1000_EECD_SK        0x00000001 /* EEPROM Clock */
591c9653b77SAkihiko Odaki #define E1000_EECD_CS        0x00000002 /* EEPROM Chip Select */
592c9653b77SAkihiko Odaki #define E1000_EECD_DI        0x00000004 /* EEPROM Data In */
593c9653b77SAkihiko Odaki #define E1000_EECD_DO        0x00000008 /* EEPROM Data Out */
594c9653b77SAkihiko Odaki #define E1000_EECD_FWE_MASK  0x00000030
595c9653b77SAkihiko Odaki #define E1000_EECD_FWE_DIS   0x00000010 /* Disable FLASH writes */
596c9653b77SAkihiko Odaki #define E1000_EECD_FWE_EN    0x00000020 /* Enable FLASH writes */
597c9653b77SAkihiko Odaki #define E1000_EECD_FWE_SHIFT 4
598c9653b77SAkihiko Odaki #define E1000_EECD_REQ       0x00000040 /* EEPROM Access Request */
599c9653b77SAkihiko Odaki #define E1000_EECD_GNT       0x00000080 /* EEPROM Access Grant */
600c9653b77SAkihiko Odaki #define E1000_EECD_PRES      0x00000100 /* EEPROM Present */
601c9653b77SAkihiko Odaki #define E1000_EECD_SIZE      0x00000200 /* EEPROM Size (0=64 word 1=256 word) */
602c9653b77SAkihiko Odaki #define E1000_EECD_ADDR_BITS 0x00000400 /* EEPROM Addressing bits based on type
603c9653b77SAkihiko Odaki                                          * (0-small, 1-large) */
604c9653b77SAkihiko Odaki #define E1000_EECD_TYPE      0x00002000 /* EEPROM Type (1-SPI, 0-Microwire) */
605c9653b77SAkihiko Odaki #ifndef E1000_EEPROM_GRANT_ATTEMPTS
606c9653b77SAkihiko Odaki #define E1000_EEPROM_GRANT_ATTEMPTS 1000 /* EEPROM # attempts to gain grant */
607c9653b77SAkihiko Odaki #endif
608c9653b77SAkihiko Odaki #define E1000_EECD_AUTO_RD          0x00000200  /* EEPROM Auto Read done */
609c9653b77SAkihiko Odaki #define E1000_EECD_SIZE_EX_MASK     0x00007800  /* EEprom Size */
610c9653b77SAkihiko Odaki #define E1000_EECD_SIZE_EX_SHIFT    11
611c9653b77SAkihiko Odaki #define E1000_EECD_NVADDS    0x00018000 /* NVM Address Size */
612c9653b77SAkihiko Odaki #define E1000_EECD_SELSHAD   0x00020000 /* Select Shadow RAM */
613c9653b77SAkihiko Odaki #define E1000_EECD_INITSRAM  0x00040000 /* Initialize Shadow RAM */
614c9653b77SAkihiko Odaki #define E1000_EECD_FLUPD     0x00080000 /* Update FLASH */
615c9653b77SAkihiko Odaki #define E1000_EECD_AUPDEN    0x00100000 /* Enable Autonomous FLASH update */
616c9653b77SAkihiko Odaki #define E1000_EECD_SHADV     0x00200000 /* Shadow RAM Data Valid */
617c9653b77SAkihiko Odaki #define E1000_EECD_SEC1VAL   0x00400000 /* Sector One Valid */
618c9653b77SAkihiko Odaki 
619c9653b77SAkihiko Odaki 
620c9653b77SAkihiko Odaki #define E1000_EECD_SECVAL_SHIFT      22
621c9653b77SAkihiko Odaki #define E1000_STM_OPCODE     0xDB00
622c9653b77SAkihiko Odaki #define E1000_HICR_FW_RESET  0xC0
623c9653b77SAkihiko Odaki 
624c9653b77SAkihiko Odaki #define E1000_SHADOW_RAM_WORDS     2048
625c9653b77SAkihiko Odaki #define E1000_ICH_NVM_SIG_WORD     0x13
626c9653b77SAkihiko Odaki #define E1000_ICH_NVM_SIG_MASK     0xC0
627c9653b77SAkihiko Odaki 
628c9653b77SAkihiko Odaki /* MDI Control */
629c9653b77SAkihiko Odaki #define E1000_MDIC_DATA_MASK 0x0000FFFF
630c9653b77SAkihiko Odaki #define E1000_MDIC_REG_MASK  0x001F0000
631c9653b77SAkihiko Odaki #define E1000_MDIC_REG_SHIFT 16
632c9653b77SAkihiko Odaki #define E1000_MDIC_PHY_MASK  0x03E00000
633c9653b77SAkihiko Odaki #define E1000_MDIC_PHY_SHIFT 21
634c9653b77SAkihiko Odaki #define E1000_MDIC_OP_WRITE  0x04000000
635c9653b77SAkihiko Odaki #define E1000_MDIC_OP_READ   0x08000000
636c9653b77SAkihiko Odaki #define E1000_MDIC_READY     0x10000000
637c9653b77SAkihiko Odaki #define E1000_MDIC_INT_EN    0x20000000
638c9653b77SAkihiko Odaki #define E1000_MDIC_ERROR     0x40000000
639c9653b77SAkihiko Odaki 
640c9653b77SAkihiko Odaki /* Rx Interrupt Delay Timer */
641c9653b77SAkihiko Odaki #define E1000_RDTR_FPD       BIT(31)
642c9653b77SAkihiko Odaki 
643c9653b77SAkihiko Odaki /* Tx Interrupt Delay Timer */
644c9653b77SAkihiko Odaki #define E1000_TIDV_FPD       BIT(31)
645c9653b77SAkihiko Odaki 
646c9653b77SAkihiko Odaki /* Delay increments in nanoseconds for delayed interrupts registers */
647c9653b77SAkihiko Odaki #define E1000_INTR_DELAY_NS_RES (1024)
648c9653b77SAkihiko Odaki 
649c9653b77SAkihiko Odaki /* Delay increments in nanoseconds for interrupt throttling registers */
650c9653b77SAkihiko Odaki #define E1000_INTR_THROTTLING_NS_RES (256)
651c9653b77SAkihiko Odaki 
652c9653b77SAkihiko Odaki /* EEPROM Commands - Microwire */
653c9653b77SAkihiko Odaki #define EEPROM_READ_OPCODE_MICROWIRE  0x6  /* EEPROM read opcode */
654c9653b77SAkihiko Odaki #define EEPROM_WRITE_OPCODE_MICROWIRE 0x5  /* EEPROM write opcode */
655c9653b77SAkihiko Odaki #define EEPROM_ERASE_OPCODE_MICROWIRE 0x7  /* EEPROM erase opcode */
656c9653b77SAkihiko Odaki #define EEPROM_EWEN_OPCODE_MICROWIRE  0x13 /* EEPROM erase/write enable */
657c9653b77SAkihiko Odaki #define EEPROM_EWDS_OPCODE_MICROWIRE  0x10 /* EEPROM erast/write disable */
658c9653b77SAkihiko Odaki 
659c9653b77SAkihiko Odaki /* EEPROM Word Offsets */
660c9653b77SAkihiko Odaki #define EEPROM_COMPAT                 0x0003
661c9653b77SAkihiko Odaki #define EEPROM_ID_LED_SETTINGS        0x0004
662c9653b77SAkihiko Odaki #define EEPROM_VERSION                0x0005
663c9653b77SAkihiko Odaki #define EEPROM_SERDES_AMPLITUDE       0x0006 /* For SERDES output amplitude adjustment. */
664c9653b77SAkihiko Odaki #define EEPROM_PHY_CLASS_WORD         0x0007
665c9653b77SAkihiko Odaki #define EEPROM_INIT_CONTROL1_REG      0x000A
666c9653b77SAkihiko Odaki #define EEPROM_INIT_CONTROL2_REG      0x000F
667c9653b77SAkihiko Odaki #define EEPROM_SWDEF_PINS_CTRL_PORT_1 0x0010
668c9653b77SAkihiko Odaki #define EEPROM_INIT_CONTROL3_PORT_B   0x0014
669c9653b77SAkihiko Odaki #define EEPROM_INIT_3GIO_3            0x001A
670c9653b77SAkihiko Odaki #define EEPROM_SWDEF_PINS_CTRL_PORT_0 0x0020
671c9653b77SAkihiko Odaki #define EEPROM_INIT_CONTROL3_PORT_A   0x0024
672c9653b77SAkihiko Odaki #define EEPROM_CFG                    0x0012
673c9653b77SAkihiko Odaki #define EEPROM_FLASH_VERSION          0x0032
674c9653b77SAkihiko Odaki #define EEPROM_CHECKSUM_REG           0x003F
675c9653b77SAkihiko Odaki 
676c9653b77SAkihiko Odaki #define E1000_EEPROM_CFG_DONE         0x00040000   /* MNG config cycle done */
677c9653b77SAkihiko Odaki #define E1000_EEPROM_CFG_DONE_PORT_1  0x00080000   /* ...for second port */
678c9653b77SAkihiko Odaki 
679c9653b77SAkihiko Odaki /* HH Time Sync */
680c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL_MAX_ALLOWED_DLY_MASK 0x0000F000 /* max delay */
681c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL_SYNC_COMP            0x40000000 /* sync complete */
682c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL_START_SYNC           0x80000000 /* initiate sync */
683c9653b77SAkihiko Odaki 
684c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL_VALID                0x00000001 /* Tx timestamp valid */
685c9653b77SAkihiko Odaki #define E1000_TSYNCTXCTL_ENABLED              0x00000010 /* enable Tx timestamping */
686c9653b77SAkihiko Odaki 
687c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_VALID                0x00000001 /* Rx timestamp valid */
688c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_MASK            0x0000000E /* Rx type mask */
689c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_L2_V2           0x00
690c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_L4_V1           0x02
691c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_L2_L4_V2        0x04
692c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_ALL             0x08
693c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_TYPE_EVENT_V2        0x0A
694c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_ENABLED              0x00000010 /* enable Rx timestamping */
695c9653b77SAkihiko Odaki #define E1000_TSYNCRXCTL_SYSCFI               0x00000020 /* Sys clock frequency */
696c9653b77SAkihiko Odaki 
697c9653b77SAkihiko Odaki #define E1000_RXMTRL_PTP_V1_SYNC_MESSAGE      0x00000000
698c9653b77SAkihiko Odaki #define E1000_RXMTRL_PTP_V1_DELAY_REQ_MESSAGE 0x00010000
699c9653b77SAkihiko Odaki 
700c9653b77SAkihiko Odaki #define E1000_RXMTRL_PTP_V2_SYNC_MESSAGE      0x00000000
701c9653b77SAkihiko Odaki #define E1000_RXMTRL_PTP_V2_DELAY_REQ_MESSAGE 0x01000000
702c9653b77SAkihiko Odaki 
703c9653b77SAkihiko Odaki #define E1000_TIMINCA_INCPERIOD_SHIFT         24
704c9653b77SAkihiko Odaki #define E1000_TIMINCA_INCVALUE_MASK           0x00FFFFFF
705c9653b77SAkihiko Odaki 
706c9653b77SAkihiko Odaki /* PCI Express Control */
707c9653b77SAkihiko Odaki /* 3GIO Control Register - GCR (0x05B00; RW) */
708c9653b77SAkihiko Odaki #define E1000_L0S_ADJUST              (1 << 9)
709c9653b77SAkihiko Odaki #define E1000_L1_ENTRY_LATENCY_MSB    (1 << 23)
710c9653b77SAkihiko Odaki #define E1000_L1_ENTRY_LATENCY_LSB    (1 << 25 | 1 << 26)
711c9653b77SAkihiko Odaki 
712c9653b77SAkihiko Odaki #define E1000_L0S_ADJUST              (1 << 9)
713c9653b77SAkihiko Odaki #define E1000_L1_ENTRY_LATENCY_MSB    (1 << 23)
714c9653b77SAkihiko Odaki #define E1000_L1_ENTRY_LATENCY_LSB    (1 << 25 | 1 << 26)
715c9653b77SAkihiko Odaki 
716c9653b77SAkihiko Odaki #define E1000_GCR_RO_BITS             (1 << 23 | 1 << 25 | 1 << 26)
717c9653b77SAkihiko Odaki 
718c9653b77SAkihiko Odaki /* MSI-X PBA Clear register */
719c9653b77SAkihiko Odaki #define E1000_PBACLR_VALID_MASK       (BIT(5) - 1)
720c9653b77SAkihiko Odaki 
721c9653b77SAkihiko Odaki /* Transmit Descriptor bit definitions */
722c9653b77SAkihiko Odaki #define E1000_TXD_DTYP_D     0x00100000 /* Data Descriptor */
723c9653b77SAkihiko Odaki #define E1000_TXD_DTYP_C     0x00000000 /* Context Descriptor */
724c9653b77SAkihiko Odaki #define E1000_TXD_CMD_EOP    0x01000000 /* End of Packet */
725c9653b77SAkihiko Odaki #define E1000_TXD_CMD_IFCS   0x02000000 /* Insert FCS (Ethernet CRC) */
726c9653b77SAkihiko Odaki #define E1000_TXD_CMD_IC     0x04000000 /* Insert Checksum */
727c9653b77SAkihiko Odaki #define E1000_TXD_CMD_RS     0x08000000 /* Report Status */
728c9653b77SAkihiko Odaki #define E1000_TXD_CMD_RPS    0x10000000 /* Report Packet Sent */
729c9653b77SAkihiko Odaki #define E1000_TXD_CMD_DEXT   0x20000000 /* Descriptor extension (0 = legacy) */
730c9653b77SAkihiko Odaki #define E1000_TXD_CMD_VLE    0x40000000 /* Add VLAN tag */
731c9653b77SAkihiko Odaki #define E1000_TXD_CMD_IDE    0x80000000 /* Enable Tidv register */
732c9653b77SAkihiko Odaki #define E1000_TXD_STAT_DD    0x00000001 /* Descriptor Done */
733c9653b77SAkihiko Odaki #define E1000_TXD_STAT_EC    0x00000002 /* Excess Collisions */
734c9653b77SAkihiko Odaki #define E1000_TXD_STAT_LC    0x00000004 /* Late Collisions */
735c9653b77SAkihiko Odaki #define E1000_TXD_STAT_TU    0x00000008 /* Transmit underrun */
736c9653b77SAkihiko Odaki #define E1000_TXD_CMD_TCP    0x01000000 /* TCP packet */
737c9653b77SAkihiko Odaki #define E1000_TXD_CMD_IP     0x02000000 /* IP packet */
738c9653b77SAkihiko Odaki #define E1000_TXD_CMD_TSE    0x04000000 /* TCP Seg enable */
739c9653b77SAkihiko Odaki #define E1000_TXD_CMD_SNAP   0x40000000 /* Update SNAP header */
740c9653b77SAkihiko Odaki #define E1000_TXD_STAT_TC    0x00000004 /* Tx Underrun */
741c9653b77SAkihiko Odaki #define E1000_TXD_EXTCMD_TSTAMP 0x00000010 /* IEEE1588 Timestamp packet */
742c9653b77SAkihiko Odaki 
743c9653b77SAkihiko Odaki /* Transmit Control */
744c9653b77SAkihiko Odaki #define E1000_TCTL_RST    0x00000001    /* software reset */
745c9653b77SAkihiko Odaki #define E1000_TCTL_EN     0x00000002    /* enable tx */
746c9653b77SAkihiko Odaki #define E1000_TCTL_BCE    0x00000004    /* busy check enable */
747c9653b77SAkihiko Odaki #define E1000_TCTL_PSP    0x00000008    /* pad short packets */
748c9653b77SAkihiko Odaki #define E1000_TCTL_CT     0x00000ff0    /* collision threshold */
749c9653b77SAkihiko Odaki #define E1000_TCTL_COLD   0x003ff000    /* collision distance */
750c9653b77SAkihiko Odaki #define E1000_TCTL_SWXOFF 0x00400000    /* SW Xoff transmission */
751c9653b77SAkihiko Odaki #define E1000_TCTL_PBE    0x00800000    /* Packet Burst Enable */
752c9653b77SAkihiko Odaki #define E1000_TCTL_RTLC   0x01000000    /* Re-transmit on late collision */
753c9653b77SAkihiko Odaki #define E1000_TCTL_NRTU   0x02000000    /* No Re-transmit on underrun */
754c9653b77SAkihiko Odaki #define E1000_TCTL_MULR   0x10000000    /* Multiple request support */
755c9653b77SAkihiko Odaki 
756c9653b77SAkihiko Odaki /* Legacy Receive Descriptor */
757c9653b77SAkihiko Odaki struct e1000_rx_desc {
758c9653b77SAkihiko Odaki     uint64_t buffer_addr; /* Address of the descriptor's data buffer */
759c9653b77SAkihiko Odaki     uint16_t length;     /* Length of data DMAed into data buffer */
760c9653b77SAkihiko Odaki     uint16_t csum;       /* Packet checksum */
761c9653b77SAkihiko Odaki     uint8_t status;      /* Descriptor status */
762c9653b77SAkihiko Odaki     uint8_t errors;      /* Descriptor Errors */
763c9653b77SAkihiko Odaki     uint16_t special;
764c9653b77SAkihiko Odaki };
765c9653b77SAkihiko Odaki 
766c9653b77SAkihiko Odaki /* Extended Receive Descriptor */
767c9653b77SAkihiko Odaki union e1000_rx_desc_extended {
768c9653b77SAkihiko Odaki     struct {
769c9653b77SAkihiko Odaki         uint64_t buffer_addr;
770c9653b77SAkihiko Odaki         uint64_t reserved;
771c9653b77SAkihiko Odaki     } read;
772c9653b77SAkihiko Odaki     struct {
773c9653b77SAkihiko Odaki         struct {
774c9653b77SAkihiko Odaki             uint32_t mrq;           /* Multiple Rx Queues */
775c9653b77SAkihiko Odaki             union {
776c9653b77SAkihiko Odaki                 uint32_t rss;       /* RSS Hash */
777c9653b77SAkihiko Odaki                 struct {
778c9653b77SAkihiko Odaki                     uint16_t ip_id; /* IP id */
779c9653b77SAkihiko Odaki                     uint16_t csum;  /* Packet Checksum */
780c9653b77SAkihiko Odaki                 } csum_ip;
781c9653b77SAkihiko Odaki             } hi_dword;
782c9653b77SAkihiko Odaki         } lower;
783c9653b77SAkihiko Odaki         struct {
784c9653b77SAkihiko Odaki             uint32_t status_error;  /* ext status/error */
785c9653b77SAkihiko Odaki             uint16_t length;
786c9653b77SAkihiko Odaki             uint16_t vlan;          /* VLAN tag */
787c9653b77SAkihiko Odaki         } upper;
788c9653b77SAkihiko Odaki     } wb;                           /* writeback */
789c9653b77SAkihiko Odaki };
790c9653b77SAkihiko Odaki 
791c9653b77SAkihiko Odaki #define MAX_PS_BUFFERS 4
792c9653b77SAkihiko Odaki 
793c9653b77SAkihiko Odaki /* Number of packet split data buffers (not including the header buffer) */
794c9653b77SAkihiko Odaki #define PS_PAGE_BUFFERS    (MAX_PS_BUFFERS - 1)
795c9653b77SAkihiko Odaki 
796c9653b77SAkihiko Odaki /* Receive Descriptor - Packet Split */
797c9653b77SAkihiko Odaki union e1000_rx_desc_packet_split {
798c9653b77SAkihiko Odaki     struct {
799c9653b77SAkihiko Odaki         /* one buffer for protocol header(s), three data buffers */
800c9653b77SAkihiko Odaki         uint64_t buffer_addr[MAX_PS_BUFFERS];
801c9653b77SAkihiko Odaki     } read;
802c9653b77SAkihiko Odaki     struct {
803c9653b77SAkihiko Odaki         struct {
804c9653b77SAkihiko Odaki             uint32_t mrq;          /* Multiple Rx Queues */
805c9653b77SAkihiko Odaki             union {
806c9653b77SAkihiko Odaki                 uint32_t rss;          /* RSS Hash */
807c9653b77SAkihiko Odaki                 struct {
808c9653b77SAkihiko Odaki                     uint16_t ip_id;    /* IP id */
809c9653b77SAkihiko Odaki                     uint16_t csum;     /* Packet Checksum */
810c9653b77SAkihiko Odaki                 } csum_ip;
811c9653b77SAkihiko Odaki             } hi_dword;
812c9653b77SAkihiko Odaki         } lower;
813c9653b77SAkihiko Odaki         struct {
814c9653b77SAkihiko Odaki             uint32_t status_error;     /* ext status/error */
815c9653b77SAkihiko Odaki             uint16_t length0;      /* length of buffer 0 */
816c9653b77SAkihiko Odaki             uint16_t vlan;         /* VLAN tag */
817c9653b77SAkihiko Odaki         } middle;
818c9653b77SAkihiko Odaki         struct {
819c9653b77SAkihiko Odaki             uint16_t header_status;
820c9653b77SAkihiko Odaki             /* length of buffers 1-3 */
821c9653b77SAkihiko Odaki             uint16_t length[PS_PAGE_BUFFERS];
822c9653b77SAkihiko Odaki         } upper;
823c9653b77SAkihiko Odaki         uint64_t reserved;
824c9653b77SAkihiko Odaki     } wb; /* writeback */
825c9653b77SAkihiko Odaki };
826c9653b77SAkihiko Odaki 
827c9653b77SAkihiko Odaki /* Receive Checksum Control bits */
828c9653b77SAkihiko Odaki #define E1000_RXCSUM_IPOFLD     0x100   /* IP Checksum Offload Enable */
829c9653b77SAkihiko Odaki #define E1000_RXCSUM_TUOFLD     0x200   /* TCP/UDP Checksum Offload Enable */
830c9653b77SAkihiko Odaki #define E1000_RXCSUM_PCSD       0x2000  /* Packet Checksum Disable */
831c9653b77SAkihiko Odaki 
832c9653b77SAkihiko Odaki #define E1000_RING_DESC_LEN       (16)
833c9653b77SAkihiko Odaki #define E1000_RING_DESC_LEN_SHIFT (4)
834c9653b77SAkihiko Odaki 
835c9653b77SAkihiko Odaki #define E1000_MIN_RX_DESC_LEN   E1000_RING_DESC_LEN
836c9653b77SAkihiko Odaki 
837c9653b77SAkihiko Odaki /* Receive Descriptor bit definitions */
838c9653b77SAkihiko Odaki #define E1000_RXD_STAT_DD       0x01    /* Descriptor Done */
839c9653b77SAkihiko Odaki #define E1000_RXD_STAT_EOP      0x02    /* End of Packet */
840c9653b77SAkihiko Odaki #define E1000_RXD_STAT_IXSM     0x04    /* Ignore checksum */
841c9653b77SAkihiko Odaki #define E1000_RXD_STAT_VP       0x08    /* IEEE VLAN Packet */
842*2431f4f1SMichael Tokarev #define E1000_RXD_STAT_UDPCS    0x10    /* UDP xsum calculated */
843c9653b77SAkihiko Odaki #define E1000_RXD_STAT_TCPCS    0x20    /* TCP xsum calculated */
844c9653b77SAkihiko Odaki #define E1000_RXD_STAT_IPCS     0x40    /* IP xsum calculated */
845c9653b77SAkihiko Odaki #define E1000_RXD_STAT_PIF      0x80    /* passed in-exact filter */
846c9653b77SAkihiko Odaki #define E1000_RXD_STAT_IPIDV    0x200   /* IP identification valid */
847c9653b77SAkihiko Odaki #define E1000_RXD_STAT_UDPV     0x400   /* Valid UDP checksum */
848c9653b77SAkihiko Odaki #define E1000_RXD_STAT_ACK      0x8000  /* ACK Packet indication */
849c9653b77SAkihiko Odaki #define E1000_RXD_ERR_CE        0x01    /* CRC Error */
850c9653b77SAkihiko Odaki #define E1000_RXD_ERR_SE        0x02    /* Symbol Error */
851c9653b77SAkihiko Odaki #define E1000_RXD_ERR_SEQ       0x04    /* Sequence Error */
852c9653b77SAkihiko Odaki #define E1000_RXD_ERR_CXE       0x10    /* Carrier Extension Error */
853c9653b77SAkihiko Odaki #define E1000_RXD_ERR_TCPE      0x20    /* TCP/UDP Checksum Error */
854c9653b77SAkihiko Odaki #define E1000_RXD_ERR_IPE       0x40    /* IP Checksum Error */
855c9653b77SAkihiko Odaki #define E1000_RXD_ERR_RXE       0x80    /* Rx Data Error */
856c9653b77SAkihiko Odaki #define E1000_RXD_SPC_VLAN_MASK 0x0FFF  /* VLAN ID is in lower 12 bits */
857c9653b77SAkihiko Odaki #define E1000_RXD_SPC_PRI_MASK  0xE000  /* Priority is in upper 3 bits */
858c9653b77SAkihiko Odaki #define E1000_RXD_SPC_PRI_SHIFT 13
859c9653b77SAkihiko Odaki #define E1000_RXD_SPC_CFI_MASK  0x1000  /* CFI is bit 12 */
860c9653b77SAkihiko Odaki #define E1000_RXD_SPC_CFI_SHIFT 12
861c9653b77SAkihiko Odaki 
862c9653b77SAkihiko Odaki /* RX packet types */
863c9653b77SAkihiko Odaki #define E1000_RXD_PKT_MAC       (0)
864c9653b77SAkihiko Odaki #define E1000_RXD_PKT_IP4       (1)
865c9653b77SAkihiko Odaki #define E1000_RXD_PKT_IP4_XDP   (2)
866c9653b77SAkihiko Odaki #define E1000_RXD_PKT_IP6       (5)
867c9653b77SAkihiko Odaki #define E1000_RXD_PKT_IP6_XDP   (6)
868c9653b77SAkihiko Odaki 
869c9653b77SAkihiko Odaki #define E1000_RXD_PKT_TYPE(t) ((t) << 16)
870c9653b77SAkihiko Odaki 
871c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_CE    0x01000000
872c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_SE    0x02000000
873c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_SEQ   0x04000000
874c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_CXE   0x10000000
875c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_TCPE  0x20000000
876c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_IPE   0x40000000
877c9653b77SAkihiko Odaki #define E1000_RXDEXT_STATERR_RXE   0x80000000
878c9653b77SAkihiko Odaki 
879c9653b77SAkihiko Odaki #define E1000_RXDPS_HDRSTAT_HDRSP        0x00008000
880c9653b77SAkihiko Odaki #define E1000_RXDPS_HDRSTAT_HDRLEN_MASK  0x000003FF
881c9653b77SAkihiko Odaki 
882c9653b77SAkihiko Odaki /* Receive Address */
883c9653b77SAkihiko Odaki #define E1000_RAH_AV  0x80000000        /* Receive descriptor valid */
884c9653b77SAkihiko Odaki 
885c9653b77SAkihiko Odaki /* Offload Context Descriptor */
886c9653b77SAkihiko Odaki struct e1000_context_desc {
887c9653b77SAkihiko Odaki     union {
888c9653b77SAkihiko Odaki         uint32_t ip_config;
889c9653b77SAkihiko Odaki         struct {
890c9653b77SAkihiko Odaki             uint8_t ipcss;      /* IP checksum start */
891c9653b77SAkihiko Odaki             uint8_t ipcso;      /* IP checksum offset */
892c9653b77SAkihiko Odaki             uint16_t ipcse;     /* IP checksum end */
893c9653b77SAkihiko Odaki         } ip_fields;
894c9653b77SAkihiko Odaki     } lower_setup;
895c9653b77SAkihiko Odaki     union {
896c9653b77SAkihiko Odaki         uint32_t tcp_config;
897c9653b77SAkihiko Odaki         struct {
898c9653b77SAkihiko Odaki             uint8_t tucss;      /* TCP checksum start */
899c9653b77SAkihiko Odaki             uint8_t tucso;      /* TCP checksum offset */
900c9653b77SAkihiko Odaki             uint16_t tucse;     /* TCP checksum end */
901c9653b77SAkihiko Odaki         } tcp_fields;
902c9653b77SAkihiko Odaki     } upper_setup;
903c9653b77SAkihiko Odaki     uint32_t cmd_and_length;    /* */
904c9653b77SAkihiko Odaki     union {
905c9653b77SAkihiko Odaki         uint32_t data;
906c9653b77SAkihiko Odaki         struct {
907c9653b77SAkihiko Odaki             uint8_t status;     /* Descriptor status */
908c9653b77SAkihiko Odaki             uint8_t hdr_len;    /* Header length */
909c9653b77SAkihiko Odaki             uint16_t mss;       /* Maximum segment size */
910c9653b77SAkihiko Odaki         } fields;
911c9653b77SAkihiko Odaki     } tcp_seg_setup;
912c9653b77SAkihiko Odaki };
913c9653b77SAkihiko Odaki 
914c9653b77SAkihiko Odaki /* Filters */
915c9653b77SAkihiko Odaki #define E1000_NUM_UNICAST          16  /* Unicast filter entries */
916c9653b77SAkihiko Odaki #define E1000_MC_TBL_SIZE          128 /* Multicast Filter Table (4096 bits) */
917c9653b77SAkihiko Odaki #define E1000_VLAN_FILTER_TBL_SIZE 128 /* VLAN Filter Table (4096 bits) */
918c9653b77SAkihiko Odaki 
919c9653b77SAkihiko Odaki /* Management Control */
920c9653b77SAkihiko Odaki #define E1000_MANC_SMBUS_EN      0x00000001 /* SMBus Enabled - RO */
921c9653b77SAkihiko Odaki #define E1000_MANC_ASF_EN        0x00000002 /* ASF Enabled - RO */
922c9653b77SAkihiko Odaki #define E1000_MANC_R_ON_FORCE    0x00000004 /* Reset on Force TCO - RO */
923c9653b77SAkihiko Odaki #define E1000_MANC_RMCP_EN       0x00000100 /* Enable RCMP 026Fh Filtering */
924c9653b77SAkihiko Odaki #define E1000_MANC_0298_EN       0x00000200 /* Enable RCMP 0298h Filtering */
925c9653b77SAkihiko Odaki #define E1000_MANC_IPV4_EN       0x00000400 /* Enable IPv4 */
926c9653b77SAkihiko Odaki #define E1000_MANC_IPV6_EN       0x00000800 /* Enable IPv6 */
927c9653b77SAkihiko Odaki #define E1000_MANC_SNAP_EN       0x00001000 /* Accept LLC/SNAP */
928c9653b77SAkihiko Odaki #define E1000_MANC_ARP_EN        0x00002000 /* Enable ARP Request Filtering */
929c9653b77SAkihiko Odaki #define E1000_MANC_NEIGHBOR_EN   0x00004000 /* Enable Neighbor Discovery
930c9653b77SAkihiko Odaki                                              * Filtering */
931c9653b77SAkihiko Odaki #define E1000_MANC_ARP_RES_EN    0x00008000 /* Enable ARP response Filtering */
932c9653b77SAkihiko Odaki #define E1000_MANC_DIS_IP_CHK_ARP  0x10000000 /* Disable IP address chacking */
933c9653b77SAkihiko Odaki                                               /*for ARP packets - in 82574 */
934c9653b77SAkihiko Odaki #define E1000_MANC_TCO_RESET     0x00010000 /* TCO Reset Occurred */
935c9653b77SAkihiko Odaki #define E1000_MANC_RCV_TCO_EN    0x00020000 /* Receive TCO Packets Enabled */
936c9653b77SAkihiko Odaki #define E1000_MANC_REPORT_STATUS 0x00040000 /* Status Reporting Enabled */
937c9653b77SAkihiko Odaki #define E1000_MANC_RCV_ALL       0x00080000 /* Receive All Enabled */
938c9653b77SAkihiko Odaki #define E1000_MANC_BLK_PHY_RST_ON_IDE   0x00040000 /* Block phy resets */
939c9653b77SAkihiko Odaki #define E1000_MANC_EN_MAC_ADDR_FILTER   0x00100000 /* Enable MAC address
940c9653b77SAkihiko Odaki                                                     * filtering */
941c9653b77SAkihiko Odaki #define E1000_MANC_EN_MNG2HOST   0x00200000 /* Enable MNG packets to host
942c9653b77SAkihiko Odaki                                              * memory */
943c9653b77SAkihiko Odaki #define E1000_MANC_EN_IP_ADDR_FILTER    0x00400000 /* Enable IP address
944c9653b77SAkihiko Odaki                                                     * filtering */
945c9653b77SAkihiko Odaki #define E1000_MANC_EN_XSUM_FILTER   0x00800000 /* Enable checksum filtering */
946c9653b77SAkihiko Odaki #define E1000_MANC_BR_EN         0x01000000 /* Enable broadcast filtering */
947c9653b77SAkihiko Odaki #define E1000_MANC_SMB_REQ       0x01000000 /* SMBus Request */
948c9653b77SAkihiko Odaki #define E1000_MANC_SMB_GNT       0x02000000 /* SMBus Grant */
949c9653b77SAkihiko Odaki #define E1000_MANC_SMB_CLK_IN    0x04000000 /* SMBus Clock In */
950c9653b77SAkihiko Odaki #define E1000_MANC_SMB_DATA_IN   0x08000000 /* SMBus Data In */
951c9653b77SAkihiko Odaki #define E1000_MANC_SMB_DATA_OUT  0x10000000 /* SMBus Data Out */
952c9653b77SAkihiko Odaki #define E1000_MANC_SMB_CLK_OUT   0x20000000 /* SMBus Clock Out */
953c9653b77SAkihiko Odaki 
954c9653b77SAkihiko Odaki #define E1000_MANC_SMB_DATA_OUT_SHIFT  28 /* SMBus Data Out Shift */
955c9653b77SAkihiko Odaki #define E1000_MANC_SMB_CLK_OUT_SHIFT   29 /* SMBus Clock Out Shift */
956c9653b77SAkihiko Odaki 
957c9653b77SAkihiko Odaki /* FACTPS Control */
958c9653b77SAkihiko Odaki #define E1000_FACTPS_LAN0_ON     0x00000004 /* Lan 0 enable */
959c9653b77SAkihiko Odaki 
960c9653b77SAkihiko Odaki /* For checksumming, the sum of all words in the EEPROM should equal 0xBABA. */
961c9653b77SAkihiko Odaki #define EEPROM_SUM 0xBABA
962c9653b77SAkihiko Odaki 
963c9653b77SAkihiko Odaki /* I/O-Mapped Access to Internal Registers, Memories, and Flash */
964c9653b77SAkihiko Odaki #define E1000_IOADDR 0x00
965c9653b77SAkihiko Odaki #define E1000_IODATA 0x04
966c9653b77SAkihiko Odaki 
967c9653b77SAkihiko Odaki #define E1000_VFTA_ENTRY_SHIFT          5
968c9653b77SAkihiko Odaki #define E1000_VFTA_ENTRY_MASK           0x7F
969c9653b77SAkihiko Odaki #define E1000_VFTA_ENTRY_BIT_SHIFT_MASK 0x1F
970c9653b77SAkihiko Odaki 
971c9653b77SAkihiko Odaki #endif /* HW_E1000_REGS_H */
972