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