📄 e1000_defines.h
字号:
/******************************************************************************* Intel PRO/1000 Linux driver Copyright(c) 1999 - 2007 Intel Corporation. This program is free software; you can redistribute it and/or modify it under the terms and conditions of the GNU General Public License, version 2, as published by the Free Software Foundation. This program is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. The full GNU General Public License is included in this distribution in the file called "COPYING". Contact Information: Linux NICS <linux.nics@intel.com> e1000-devel Mailing List <e1000-devel@lists.sourceforge.net> Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497*******************************************************************************/#ifndef _E1000_DEFINES_H_#define _E1000_DEFINES_H_/* Number of Transmit and Receive Descriptors must be a multiple of 8 */#define REQ_TX_DESCRIPTOR_MULTIPLE 8#define REQ_RX_DESCRIPTOR_MULTIPLE 8/* Definitions for power management and wakeup registers *//* Wake Up Control */#define E1000_WUC_APME 0x00000001 /* APM Enable */#define E1000_WUC_PME_EN 0x00000002 /* PME Enable */#define E1000_WUC_PME_STATUS 0x00000004 /* PME Status */#define E1000_WUC_APMPME 0x00000008 /* Assert PME on APM Wakeup */#define E1000_WUC_SPM 0x80000000 /* Enable SPM *//* Wake Up Filter Control */#define E1000_WUFC_LNKC 0x00000001 /* Link Status Change Wakeup Enable */#define E1000_WUFC_MAG 0x00000002 /* Magic Packet Wakeup Enable */#define E1000_WUFC_EX 0x00000004 /* Directed Exact Wakeup Enable */#define E1000_WUFC_MC 0x00000008 /* Directed Multicast Wakeup Enable */#define E1000_WUFC_BC 0x00000010 /* Broadcast Wakeup Enable */#define E1000_WUFC_ARP 0x00000020 /* ARP Request Packet Wakeup Enable */#define E1000_WUFC_IPV4 0x00000040 /* Directed IPv4 Packet Wakeup Enable */#define E1000_WUFC_IPV6 0x00000080 /* Directed IPv6 Packet Wakeup Enable */#define E1000_WUFC_IGNORE_TCO 0x00008000 /* Ignore WakeOn TCO packets */#define E1000_WUFC_FLX0 0x00010000 /* Flexible Filter 0 Enable */#define E1000_WUFC_FLX1 0x00020000 /* Flexible Filter 1 Enable */#define E1000_WUFC_FLX2 0x00040000 /* Flexible Filter 2 Enable */#define E1000_WUFC_FLX3 0x00080000 /* Flexible Filter 3 Enable */#define E1000_WUFC_ALL_FILTERS 0x000F00FF /* Mask for all wakeup filters */#define E1000_WUFC_FLX_OFFSET 16 /* Offset to the Flexible Filters bits */#define E1000_WUFC_FLX_FILTERS 0x000F0000 /* Mask for the 4 flexible filters *//* Wake Up Status */#define E1000_WUS_LNKC E1000_WUFC_LNKC#define E1000_WUS_MAG E1000_WUFC_MAG#define E1000_WUS_EX E1000_WUFC_EX#define E1000_WUS_MC E1000_WUFC_MC#define E1000_WUS_BC E1000_WUFC_BC#define E1000_WUS_ARP E1000_WUFC_ARP#define E1000_WUS_IPV4 E1000_WUFC_IPV4#define E1000_WUS_IPV6 E1000_WUFC_IPV6#define E1000_WUS_FLX0 E1000_WUFC_FLX0#define E1000_WUS_FLX1 E1000_WUFC_FLX1#define E1000_WUS_FLX2 E1000_WUFC_FLX2#define E1000_WUS_FLX3 E1000_WUFC_FLX3#define E1000_WUS_FLX_FILTERS E1000_WUFC_FLX_FILTERS/* Wake Up Packet Length */#define E1000_WUPL_LENGTH_MASK 0x0FFF /* Only the lower 12 bits are valid *//* Four Flexible Filters are supported */#define E1000_FLEXIBLE_FILTER_COUNT_MAX 4/* Each Flexible Filter is at most 128 (0x80) bytes in length */#define E1000_FLEXIBLE_FILTER_SIZE_MAX 128#define E1000_FFLT_SIZE E1000_FLEXIBLE_FILTER_COUNT_MAX#define E1000_FFMT_SIZE E1000_FLEXIBLE_FILTER_SIZE_MAX#define E1000_FFVT_SIZE E1000_FLEXIBLE_FILTER_SIZE_MAX/* Extended Device Control */#define E1000_CTRL_EXT_GPI0_EN 0x00000001 /* Maps SDP4 to GPI0 */#define E1000_CTRL_EXT_GPI1_EN 0x00000002 /* Maps SDP5 to GPI1 */#define E1000_CTRL_EXT_PHYINT_EN E1000_CTRL_EXT_GPI1_EN#define E1000_CTRL_EXT_GPI2_EN 0x00000004 /* Maps SDP6 to GPI2 */#define E1000_CTRL_EXT_GPI3_EN 0x00000008 /* Maps SDP7 to GPI3 */#define E1000_CTRL_EXT_SDP4_DATA 0x00000010 /* Value of SW Defineable Pin 4 */#define E1000_CTRL_EXT_SDP5_DATA 0x00000020 /* Value of SW Defineable Pin 5 */#define E1000_CTRL_EXT_PHY_INT E1000_CTRL_EXT_SDP5_DATA#define E1000_CTRL_EXT_SDP6_DATA 0x00000040 /* Value of SW Defineable Pin 6 */#define E1000_CTRL_EXT_SDP7_DATA 0x00000080 /* Value of SW Defineable Pin 7 */#define E1000_CTRL_EXT_SDP4_DIR 0x00000100 /* Direction of SDP4 0=in 1=out */#define E1000_CTRL_EXT_SDP5_DIR 0x00000200 /* Direction of SDP5 0=in 1=out */#define E1000_CTRL_EXT_SDP6_DIR 0x00000400 /* Direction of SDP6 0=in 1=out */#define E1000_CTRL_EXT_SDP7_DIR 0x00000800 /* Direction of SDP7 0=in 1=out */#define E1000_CTRL_EXT_ASDCHK 0x00001000 /* Initiate an ASD sequence */#define E1000_CTRL_EXT_EE_RST 0x00002000 /* Reinitialize from EEPROM */#define E1000_CTRL_EXT_IPS 0x00004000 /* Invert Power State */#define E1000_CTRL_EXT_SPD_BYPS 0x00008000 /* Speed Select Bypass */#define E1000_CTRL_EXT_RO_DIS 0x00020000 /* Relaxed Ordering disable */#define E1000_CTRL_EXT_LINK_MODE_MASK 0x00C00000#define E1000_CTRL_EXT_LINK_MODE_GMII 0x00000000#define E1000_CTRL_EXT_LINK_MODE_TBI 0x00C00000#define E1000_CTRL_EXT_LINK_MODE_KMRN 0x00000000#define E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES 0x00C00000#define E1000_CTRL_EXT_LINK_MODE_PCIX_SERDES 0x00800000#define E1000_CTRL_EXT_LINK_MODE_SGMII 0x00800000#define E1000_CTRL_EXT_WR_WMARK_MASK 0x03000000#define E1000_CTRL_EXT_WR_WMARK_256 0x00000000#define E1000_CTRL_EXT_WR_WMARK_320 0x01000000#define E1000_CTRL_EXT_WR_WMARK_384 0x02000000#define E1000_CTRL_EXT_WR_WMARK_448 0x03000000#define E1000_CTRL_EXT_CANC 0x04000000 /* Interrupt delay cancellation */#define E1000_CTRL_EXT_DRV_LOAD 0x10000000 /* Driver loaded bit for FW */#define E1000_CTRL_EXT_IAME 0x08000000 /* Interrupt acknowledge Auto-mask */#define E1000_CTRL_EXT_INT_TIMER_CLR 0x20000000 /* Clear Interrupt timers after IMS clear */#define E1000_CRTL_EXT_PB_PAREN 0x01000000 /* packet buffer parity error detection enabled */#define E1000_CTRL_EXT_DF_PAREN 0x02000000 /* descriptor FIFO parity error detection enable */#define E1000_CTRL_EXT_GHOST_PAREN 0x40000000/* Receive Decriptor bit definitions */#define E1000_RXD_STAT_DD 0x01 /* Descriptor Done */#define E1000_RXD_STAT_EOP 0x02 /* End of Packet */#define E1000_RXD_STAT_IXSM 0x04 /* Ignore checksum */#define E1000_RXD_STAT_VP 0x08 /* IEEE VLAN Packet */#define E1000_RXD_STAT_UDPCS 0x10 /* UDP xsum caculated */#define E1000_RXD_STAT_TCPCS 0x20 /* TCP xsum calculated */#define E1000_RXD_STAT_IPCS 0x40 /* IP xsum calculated */#define E1000_RXD_STAT_PIF 0x80 /* passed in-exact filter */#define E1000_RXD_STAT_IPIDV 0x200 /* IP identification valid */#define E1000_RXD_STAT_UDPV 0x400 /* Valid UDP checksum */#define E1000_RXD_STAT_ACK 0x8000 /* ACK Packet indication */#define E1000_RXD_ERR_CE 0x01 /* CRC Error */#define E1000_RXD_ERR_SE 0x02 /* Symbol Error */#define E1000_RXD_ERR_SEQ 0x04 /* Sequence Error */#define E1000_RXD_ERR_CXE 0x10 /* Carrier Extension Error */#define E1000_RXD_ERR_TCPE 0x20 /* TCP/UDP Checksum Error */#define E1000_RXD_ERR_IPE 0x40 /* IP Checksum Error */#define E1000_RXD_ERR_RXE 0x80 /* Rx Data Error */#define E1000_RXD_SPC_VLAN_MASK 0x0FFF /* VLAN ID is in lower 12 bits */#define E1000_RXD_SPC_PRI_MASK 0xE000 /* Priority is in upper 3 bits */#define E1000_RXD_SPC_PRI_SHIFT 13#define E1000_RXD_SPC_CFI_MASK 0x1000 /* CFI is bit 12 */#define E1000_RXD_SPC_CFI_SHIFT 12#define E1000_RXDEXT_STATERR_CE 0x01000000#define E1000_RXDEXT_STATERR_SE 0x02000000#define E1000_RXDEXT_STATERR_SEQ 0x04000000#define E1000_RXDEXT_STATERR_CXE 0x10000000#define E1000_RXDEXT_STATERR_TCPE 0x20000000#define E1000_RXDEXT_STATERR_IPE 0x40000000#define E1000_RXDEXT_STATERR_RXE 0x80000000/* mask to determine if packets should be dropped due to frame errors */#define E1000_RXD_ERR_FRAME_ERR_MASK ( \ E1000_RXD_ERR_CE | \ E1000_RXD_ERR_SE | \ E1000_RXD_ERR_SEQ | \ E1000_RXD_ERR_CXE | \ E1000_RXD_ERR_RXE)/* Same mask, but for extended and packet split descriptors */#define E1000_RXDEXT_ERR_FRAME_ERR_MASK ( \ E1000_RXDEXT_STATERR_CE | \ E1000_RXDEXT_STATERR_SE | \ E1000_RXDEXT_STATERR_SEQ | \ E1000_RXDEXT_STATERR_CXE | \ E1000_RXDEXT_STATERR_RXE)#define E1000_MRQC_ENABLE_MASK 0x00000007#define E1000_MRQC_ENABLE_RSS_2Q 0x00000001#define E1000_MRQC_ENABLE_RSS_INT 0x00000004#define E1000_MRQC_RSS_FIELD_MASK 0xFFFF0000#define E1000_MRQC_RSS_FIELD_IPV4_TCP 0x00010000#define E1000_MRQC_RSS_FIELD_IPV4 0x00020000#define E1000_MRQC_RSS_FIELD_IPV6_TCP_EX 0x00040000#define E1000_MRQC_RSS_FIELD_IPV6_EX 0x00080000#define E1000_MRQC_RSS_FIELD_IPV6 0x00100000#define E1000_MRQC_RSS_FIELD_IPV6_TCP 0x00200000#define E1000_RXDPS_HDRSTAT_HDRSP 0x00008000#define E1000_RXDPS_HDRSTAT_HDRLEN_MASK 0x000003FF/* Management Control */#define E1000_MANC_SMBUS_EN 0x00000001 /* SMBus Enabled - RO */#define E1000_MANC_ASF_EN 0x00000002 /* ASF Enabled - RO */#define E1000_MANC_R_ON_FORCE 0x00000004 /* Reset on Force TCO - RO */#define E1000_MANC_RMCP_EN 0x00000100 /* Enable RCMP 026Fh Filtering */#define E1000_MANC_0298_EN 0x00000200 /* Enable RCMP 0298h Filtering */#define E1000_MANC_IPV4_EN 0x00000400 /* Enable IPv4 */#define E1000_MANC_IPV6_EN 0x00000800 /* Enable IPv6 */#define E1000_MANC_SNAP_EN 0x00001000 /* Accept LLC/SNAP */#define E1000_MANC_ARP_EN 0x00002000 /* Enable ARP Request Filtering */#define E1000_MANC_NEIGHBOR_EN 0x00004000 /* Enable Neighbor Discovery * Filtering */#define E1000_MANC_ARP_RES_EN 0x00008000 /* Enable ARP response Filtering */#define E1000_MANC_TCO_RESET 0x00010000 /* TCO Reset Occurred */#define E1000_MANC_RCV_TCO_EN 0x00020000 /* Receive TCO Packets Enabled */#define E1000_MANC_REPORT_STATUS 0x00040000 /* Status Reporting Enabled */#define E1000_MANC_RCV_ALL 0x00080000 /* Receive All Enabled */#define E1000_MANC_BLK_PHY_RST_ON_IDE 0x00040000 /* Block phy resets */#define E1000_MANC_EN_MAC_ADDR_FILTER 0x00100000 /* Enable MAC address * filtering */#define E1000_MANC_EN_MNG2HOST 0x00200000 /* Enable MNG packets to host * memory */#define E1000_MANC_EN_IP_ADDR_FILTER 0x00400000 /* Enable IP address * filtering */#define E1000_MANC_EN_XSUM_FILTER 0x00800000 /* Enable checksum filtering */#define E1000_MANC_BR_EN 0x01000000 /* Enable broadcast filtering */#define E1000_MANC_SMB_REQ 0x01000000 /* SMBus Request */#define E1000_MANC_SMB_GNT 0x02000000 /* SMBus Grant */#define E1000_MANC_SMB_CLK_IN 0x04000000 /* SMBus Clock In */#define E1000_MANC_SMB_DATA_IN 0x08000000 /* SMBus Data In */#define E1000_MANC_SMB_DATA_OUT 0x10000000 /* SMBus Data Out */#define E1000_MANC_SMB_CLK_OUT 0x20000000 /* SMBus Clock Out */#define E1000_MANC_SMB_DATA_OUT_SHIFT 28 /* SMBus Data Out Shift */#define E1000_MANC_SMB_CLK_OUT_SHIFT 29 /* SMBus Clock Out Shift *//* Receive Control */#define E1000_RCTL_RST 0x00000001 /* Software reset */#define E1000_RCTL_EN 0x00000002 /* enable */#define E1000_RCTL_SBP 0x00000004 /* store bad packet */#define E1000_RCTL_UPE 0x00000008 /* unicast promiscuous enable */#define E1000_RCTL_MPE 0x00000010 /* multicast promiscuous enab */#define E1000_RCTL_LPE 0x00000020 /* long packet enable */#define E1000_RCTL_LBM_NO 0x00000000 /* no loopback mode */#define E1000_RCTL_LBM_MAC 0x00000040 /* MAC loopback mode */#define E1000_RCTL_LBM_SLP 0x00000080 /* serial link loopback mode */#define E1000_RCTL_LBM_TCVR 0x000000C0 /* tcvr loopback mode */#define E1000_RCTL_DTYP_MASK 0x00000C00 /* Descriptor type mask */#define E1000_RCTL_DTYP_PS 0x00000400 /* Packet Split descriptor */#define E1000_RCTL_RDMTS_HALF 0x00000000 /* rx desc min threshold size */#define E1000_RCTL_RDMTS_QUAT 0x00000100 /* rx desc min threshold size */#define E1000_RCTL_RDMTS_EIGTH 0x00000200 /* rx desc min threshold size */#define E1000_RCTL_MO_SHIFT 12 /* multicast offset shift */#define E1000_RCTL_MO_0 0x00000000 /* multicast offset 11:0 */#define E1000_RCTL_MO_1 0x00001000 /* multicast offset 12:1 */#define E1000_RCTL_MO_2 0x00002000 /* multicast offset 13:2 */#define E1000_RCTL_MO_3 0x00003000 /* multicast offset 15:4 */#define E1000_RCTL_MDR 0x00004000 /* multicast desc ring 0 */#define E1000_RCTL_BAM 0x00008000 /* broadcast enable */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -