| Stephen Hemminger | f1d3d38 | 2006-12-01 16:36:16 -0800 | [diff] [blame] | 1 | /* $Date: 2006/04/28 19:20:17 $ $RCSfile: vsc7326_reg.h,v $ $Revision: 1.5 $ */ | 
 | 2 | #ifndef _VSC7321_REG_H_ | 
 | 3 | #define _VSC7321_REG_H_ | 
 | 4 |  | 
 | 5 | /* Register definitions for Vitesse VSC7321 (Meigs II) MAC | 
 | 6 |  * | 
 | 7 |  * Straight off the data sheet, VMDS-10038 Rev 2.0 and | 
 | 8 |  * PD0011-01-14-Meigs-II 2002-12-12 | 
 | 9 |  */ | 
 | 10 |  | 
 | 11 | /* Just 'cause it's in here doesn't mean it's used. */ | 
 | 12 |  | 
 | 13 | #define CRA(blk,sub,adr) ((((blk) & 0x7) << 13) | (((sub) & 0xf) << 9) | (((adr) & 0xff) << 1)) | 
 | 14 |  | 
 | 15 | /* System and CPU comm's registers */ | 
 | 16 | #define REG_CHIP_ID		CRA(0x7,0xf,0x00)	/* Chip ID */ | 
 | 17 | #define REG_BLADE_ID		CRA(0x7,0xf,0x01)	/* Blade ID */ | 
 | 18 | #define REG_SW_RESET		CRA(0x7,0xf,0x02)	/* Global Soft Reset */ | 
 | 19 | #define REG_MEM_BIST		CRA(0x7,0xf,0x04)	/* mem */ | 
 | 20 | #define REG_IFACE_MODE		CRA(0x7,0xf,0x07)	/* Interface mode */ | 
 | 21 | #define REG_MSCH		CRA(0x7,0x2,0x06)	/* CRC error count */ | 
 | 22 | #define REG_CRC_CNT		CRA(0x7,0x2,0x0a)	/* CRC error count */ | 
 | 23 | #define REG_CRC_CFG		CRA(0x7,0x2,0x0b)	/* CRC config */ | 
 | 24 | #define REG_SI_TRANSFER_SEL	CRA(0x7,0xf,0x18)	/* SI Transfer Select */ | 
 | 25 | #define REG_PLL_CLK_SPEED	CRA(0x7,0xf,0x19)	/* Clock Speed Selection */ | 
 | 26 | #define REG_SYS_CLK_SELECT	CRA(0x7,0xf,0x1c)	/* System Clock Select */ | 
 | 27 | #define REG_GPIO_CTRL		CRA(0x7,0xf,0x1d)	/* GPIO Control */ | 
 | 28 | #define REG_GPIO_OUT		CRA(0x7,0xf,0x1e)	/* GPIO Out */ | 
 | 29 | #define REG_GPIO_IN		CRA(0x7,0xf,0x1f)	/* GPIO In */ | 
 | 30 | #define REG_CPU_TRANSFER_SEL	CRA(0x7,0xf,0x20)	/* CPU Transfer Select */ | 
 | 31 | #define REG_LOCAL_DATA		CRA(0x7,0xf,0xfe)	/* Local CPU Data Register */ | 
 | 32 | #define REG_LOCAL_STATUS	CRA(0x7,0xf,0xff)	/* Local CPU Status Register */ | 
 | 33 |  | 
 | 34 | /* Aggregator registers */ | 
 | 35 | #define REG_AGGR_SETUP		CRA(0x7,0x1,0x00)	/* Aggregator Setup */ | 
 | 36 | #define REG_PMAP_TABLE		CRA(0x7,0x1,0x01)	/* Port map table */ | 
 | 37 | #define REG_MPLS_BIT0		CRA(0x7,0x1,0x08)	/* MPLS bit0 position */ | 
 | 38 | #define REG_MPLS_BIT1		CRA(0x7,0x1,0x09)	/* MPLS bit1 position */ | 
 | 39 | #define REG_MPLS_BIT2		CRA(0x7,0x1,0x0a)	/* MPLS bit2 position */ | 
 | 40 | #define REG_MPLS_BIT3		CRA(0x7,0x1,0x0b)	/* MPLS bit3 position */ | 
 | 41 | #define REG_MPLS_BITMASK	CRA(0x7,0x1,0x0c)	/* MPLS bit mask */ | 
 | 42 | #define REG_PRE_BIT0POS		CRA(0x7,0x1,0x10)	/* Preamble bit0 position */ | 
 | 43 | #define REG_PRE_BIT1POS		CRA(0x7,0x1,0x11)	/* Preamble bit1 position */ | 
 | 44 | #define REG_PRE_BIT2POS		CRA(0x7,0x1,0x12)	/* Preamble bit2 position */ | 
 | 45 | #define REG_PRE_BIT3POS		CRA(0x7,0x1,0x13)	/* Preamble bit3 position */ | 
 | 46 | #define REG_PRE_ERR_CNT		CRA(0x7,0x1,0x14)	/* Preamble parity error count */ | 
 | 47 |  | 
 | 48 | /* BIST registers */ | 
 | 49 | /*#define REG_RAM_BIST_CMD	CRA(0x7,0x2,0x00)*/	/* RAM BIST Command Register */ | 
 | 50 | /*#define REG_RAM_BIST_RESULT	CRA(0x7,0x2,0x01)*/	/* RAM BIST Read Status/Result */ | 
 | 51 | #define REG_RAM_BIST_CMD	CRA(0x7,0x1,0x00)	/* RAM BIST Command Register */ | 
 | 52 | #define REG_RAM_BIST_RESULT	CRA(0x7,0x1,0x01)	/* RAM BIST Read Status/Result */ | 
 | 53 | #define   BIST_PORT_SELECT	0x00			/* BIST port select */ | 
 | 54 | #define   BIST_COMMAND		0x01			/* BIST enable/disable */ | 
 | 55 | #define   BIST_STATUS		0x02			/* BIST operation status */ | 
 | 56 | #define   BIST_ERR_CNT_LSB	0x03			/* BIST error count lo 8b */ | 
 | 57 | #define   BIST_ERR_CNT_MSB	0x04			/* BIST error count hi 8b */ | 
 | 58 | #define   BIST_ERR_SEL_LSB	0x05			/* BIST error select lo 8b */ | 
 | 59 | #define   BIST_ERR_SEL_MSB	0x06			/* BIST error select hi 8b */ | 
 | 60 | #define   BIST_ERROR_STATE	0x07			/* BIST engine internal state */ | 
 | 61 | #define   BIST_ERR_ADR0		0x08			/* BIST error address lo 8b */ | 
 | 62 | #define   BIST_ERR_ADR1		0x09			/* BIST error address lomid 8b */ | 
 | 63 | #define   BIST_ERR_ADR2		0x0a			/* BIST error address himid 8b */ | 
 | 64 | #define   BIST_ERR_ADR3		0x0b			/* BIST error address hi 8b */ | 
 | 65 |  | 
 | 66 | /* FIFO registers | 
 | 67 |  *   ie = 0 for ingress, 1 for egress | 
 | 68 |  *   fn = FIFO number, 0-9 | 
 | 69 |  */ | 
 | 70 | #define REG_TEST(ie,fn)		CRA(0x2,ie&1,0x00+fn)	/* Mode & Test Register */ | 
 | 71 | #define REG_TOP_BOTTOM(ie,fn)	CRA(0x2,ie&1,0x10+fn)	/* FIFO Buffer Top & Bottom */ | 
 | 72 | #define REG_TAIL(ie,fn)		CRA(0x2,ie&1,0x20+fn)	/* FIFO Write Pointer */ | 
 | 73 | #define REG_HEAD(ie,fn)		CRA(0x2,ie&1,0x30+fn)	/* FIFO Read Pointer */ | 
 | 74 | #define REG_HIGH_LOW_WM(ie,fn)	CRA(0x2,ie&1,0x40+fn)	/* Flow Control Water Marks */ | 
 | 75 | #define REG_CT_THRHLD(ie,fn)	CRA(0x2,ie&1,0x50+fn)	/* Cut Through Threshold */ | 
 | 76 | #define REG_FIFO_DROP_CNT(ie,fn) CRA(0x2,ie&1,0x60+fn)	/* Drop & CRC Error Counter */ | 
 | 77 | #define REG_DEBUG_BUF_CNT(ie,fn) CRA(0x2,ie&1,0x70+fn)	/* Input Side Debug Counter */ | 
 | 78 | #define REG_BUCKI(fn) CRA(0x2,2,0x20+fn)	/* Input Side Debug Counter */ | 
 | 79 | #define REG_BUCKE(fn) CRA(0x2,3,0x20+fn)	/* Input Side Debug Counter */ | 
 | 80 |  | 
 | 81 | /* Traffic shaper buckets | 
 | 82 |  *   ie = 0 for ingress, 1 for egress | 
 | 83 |  *   bn = bucket number 0-10 (yes, 11 buckets) | 
 | 84 |  */ | 
 | 85 | /* OK, this one's kinda ugly.  Some hardware designers are perverse. */ | 
 | 86 | #define REG_TRAFFIC_SHAPER_BUCKET(ie,bn) CRA(0x2,ie&1,0x0a + (bn>7) | ((bn&7)<<4)) | 
 | 87 | #define REG_TRAFFIC_SHAPER_CONTROL(ie)	CRA(0x2,ie&1,0x3b) | 
 | 88 |  | 
 | 89 | #define REG_SRAM_ADR(ie)	CRA(0x2,ie&1,0x0e)	/* FIFO SRAM address */ | 
 | 90 | #define REG_SRAM_WR_STRB(ie)	CRA(0x2,ie&1,0x1e)	/* FIFO SRAM write strobe */ | 
 | 91 | #define REG_SRAM_RD_STRB(ie)	CRA(0x2,ie&1,0x2e)	/* FIFO SRAM read strobe */ | 
 | 92 | #define REG_SRAM_DATA_0(ie)	CRA(0x2,ie&1,0x3e)	/* FIFO SRAM data lo 8b */ | 
 | 93 | #define REG_SRAM_DATA_1(ie)	CRA(0x2,ie&1,0x4e)	/* FIFO SRAM data lomid 8b */ | 
 | 94 | #define REG_SRAM_DATA_2(ie)	CRA(0x2,ie&1,0x5e)	/* FIFO SRAM data himid 8b */ | 
 | 95 | #define REG_SRAM_DATA_3(ie)	CRA(0x2,ie&1,0x6e)	/* FIFO SRAM data hi 8b */ | 
 | 96 | #define REG_SRAM_DATA_BLK_TYPE(ie) CRA(0x2,ie&1,0x7e)	/* FIFO SRAM tag */ | 
 | 97 | /* REG_ING_CONTROL equals REG_CONTROL with ie = 0, likewise REG_EGR_CONTROL is ie = 1 */ | 
 | 98 | #define REG_CONTROL(ie)		CRA(0x2,ie&1,0x0f)	/* FIFO control */ | 
 | 99 | #define REG_ING_CONTROL		CRA(0x2,0x0,0x0f)	/* Ingress control (alias) */ | 
 | 100 | #define REG_EGR_CONTROL		CRA(0x2,0x1,0x0f)	/* Egress control (alias) */ | 
 | 101 | #define REG_AGE_TIMER(ie)	CRA(0x2,ie&1,0x1f)	/* Aging timer */ | 
 | 102 | #define REG_AGE_INC(ie)		CRA(0x2,ie&1,0x2f)	/* Aging increment */ | 
 | 103 | #define DEBUG_OUT(ie)		CRA(0x2,ie&1,0x3f)	/* Output debug counter control */ | 
 | 104 | #define DEBUG_CNT(ie)		CRA(0x2,ie&1,0x4f)	/* Output debug counter */ | 
 | 105 |  | 
 | 106 | /* SPI4 interface */ | 
 | 107 | #define REG_SPI4_MISC		CRA(0x5,0x0,0x00)	/* Misc Register */ | 
 | 108 | #define REG_SPI4_STATUS		CRA(0x5,0x0,0x01)	/* CML Status */ | 
 | 109 | #define REG_SPI4_ING_SETUP0	CRA(0x5,0x0,0x02)	/* Ingress Status Channel Setup */ | 
 | 110 | #define REG_SPI4_ING_SETUP1	CRA(0x5,0x0,0x03)	/* Ingress Data Training Setup */ | 
 | 111 | #define REG_SPI4_ING_SETUP2	CRA(0x5,0x0,0x04)	/* Ingress Data Burst Size Setup */ | 
 | 112 | #define REG_SPI4_EGR_SETUP0	CRA(0x5,0x0,0x05)	/* Egress Status Channel Setup */ | 
 | 113 | #define REG_SPI4_DBG_CNT(n)	CRA(0x5,0x0,0x10+n)	/* Debug counters 0-9 */ | 
 | 114 | #define REG_SPI4_DBG_SETUP	CRA(0x5,0x0,0x1A)	/* Debug counters setup */ | 
 | 115 | #define REG_SPI4_TEST		CRA(0x5,0x0,0x20)	/* Test Setup Register */ | 
 | 116 | #define REG_TPGEN_UP0		CRA(0x5,0x0,0x21)	/* Test Pattern generator user pattern 0 */ | 
 | 117 | #define REG_TPGEN_UP1		CRA(0x5,0x0,0x22)	/* Test Pattern generator user pattern 1 */ | 
 | 118 | #define REG_TPCHK_UP0		CRA(0x5,0x0,0x23)	/* Test Pattern checker user pattern 0 */ | 
 | 119 | #define REG_TPCHK_UP1		CRA(0x5,0x0,0x24)	/* Test Pattern checker user pattern 1 */ | 
 | 120 | #define REG_TPSAM_P0		CRA(0x5,0x0,0x25)	/* Sampled pattern 0 */ | 
 | 121 | #define REG_TPSAM_P1		CRA(0x5,0x0,0x26)	/* Sampled pattern 1 */ | 
 | 122 | #define REG_TPERR_CNT		CRA(0x5,0x0,0x27)	/* Pattern checker error counter */ | 
 | 123 | #define REG_SPI4_STICKY		CRA(0x5,0x0,0x30)	/* Sticky bits register */ | 
 | 124 | #define REG_SPI4_DBG_INH	CRA(0x5,0x0,0x31)	/* Core egress & ingress inhibit */ | 
 | 125 | #define REG_SPI4_DBG_STATUS	CRA(0x5,0x0,0x32)	/* Sampled ingress status */ | 
 | 126 | #define REG_SPI4_DBG_GRANT	CRA(0x5,0x0,0x33)	/* Ingress cranted credit value */ | 
 | 127 |  | 
 | 128 | #define REG_SPI4_DESKEW 	CRA(0x5,0x0,0x43)	/* Ingress cranted credit value */ | 
 | 129 |  | 
 | 130 | /* 10GbE MAC Block Registers */ | 
 | 131 | /* Note that those registers that are exactly the same for 10GbE as for | 
 | 132 |  * tri-speed are only defined with the version that needs a port number. | 
 | 133 |  * Pass 0xa in those cases. | 
 | 134 |  * | 
 | 135 |  * Also note that despite the presence of a MAC address register, this part | 
 | 136 |  * does no ingress MAC address filtering.  That register is used only for | 
 | 137 |  * pause frame detection and generation. | 
 | 138 |  */ | 
 | 139 | /* 10GbE specific, and different from tri-speed */ | 
 | 140 | #define REG_MISC_10G		CRA(0x1,0xa,0x00)	/* Misc 10GbE setup */ | 
 | 141 | #define REG_PAUSE_10G		CRA(0x1,0xa,0x01)	/* Pause register */ | 
 | 142 | #define REG_NORMALIZER_10G	CRA(0x1,0xa,0x05)	/* 10G normalizer */ | 
 | 143 | #define REG_STICKY_RX		CRA(0x1,0xa,0x06)	/* RX debug register */ | 
 | 144 | #define REG_DENORM_10G		CRA(0x1,0xa,0x07)	/* Denormalizer  */ | 
 | 145 | #define REG_STICKY_TX		CRA(0x1,0xa,0x08)	/* TX sticky bits */ | 
 | 146 | #define REG_MAX_RXHIGH		CRA(0x1,0xa,0x0a)	/* XGMII lane 0-3 debug */ | 
 | 147 | #define REG_MAX_RXLOW		CRA(0x1,0xa,0x0b)	/* XGMII lane 4-7 debug */ | 
 | 148 | #define REG_MAC_TX_STICKY	CRA(0x1,0xa,0x0c)	/* MAC Tx state sticky debug */ | 
 | 149 | #define REG_MAC_TX_RUNNING	CRA(0x1,0xa,0x0d)	/* MAC Tx state running debug */ | 
 | 150 | #define REG_TX_ABORT_AGE	CRA(0x1,0xa,0x14)	/* Aged Tx frames discarded */ | 
 | 151 | #define REG_TX_ABORT_SHORT	CRA(0x1,0xa,0x15)	/* Short Tx frames discarded */ | 
 | 152 | #define REG_TX_ABORT_TAXI	CRA(0x1,0xa,0x16)	/* Taxi error frames discarded */ | 
 | 153 | #define REG_TX_ABORT_UNDERRUN	CRA(0x1,0xa,0x17)	/* Tx Underrun abort counter */ | 
 | 154 | #define REG_TX_DENORM_DISCARD	CRA(0x1,0xa,0x18)	/* Tx denormalizer discards */ | 
 | 155 | #define REG_XAUI_STAT_A		CRA(0x1,0xa,0x20)	/* XAUI status A */ | 
 | 156 | #define REG_XAUI_STAT_B		CRA(0x1,0xa,0x21)	/* XAUI status B */ | 
 | 157 | #define REG_XAUI_STAT_C		CRA(0x1,0xa,0x22)	/* XAUI status C */ | 
 | 158 | #define REG_XAUI_CONF_A		CRA(0x1,0xa,0x23)	/* XAUI configuration A */ | 
 | 159 | #define REG_XAUI_CONF_B		CRA(0x1,0xa,0x24)	/* XAUI configuration B */ | 
 | 160 | #define REG_XAUI_CODE_GRP_CNT	CRA(0x1,0xa,0x25)	/* XAUI code group error count */ | 
 | 161 | #define REG_XAUI_CONF_TEST_A	CRA(0x1,0xa,0x26)	/* XAUI test register A */ | 
 | 162 | #define REG_PDERRCNT		CRA(0x1,0xa,0x27)	/* XAUI test register B */ | 
 | 163 |  | 
 | 164 | /* pn = port number 0-9 for tri-speed, 10 for 10GbE */ | 
 | 165 | /* Both tri-speed and 10GbE */ | 
 | 166 | #define REG_MAX_LEN(pn)		CRA(0x1,pn,0x02)	/* Max length */ | 
 | 167 | #define REG_MAC_HIGH_ADDR(pn)	CRA(0x1,pn,0x03)	/* Upper 24 bits of MAC addr */ | 
 | 168 | #define REG_MAC_LOW_ADDR(pn)	CRA(0x1,pn,0x04)	/* Lower 24 bits of MAC addr */ | 
 | 169 |  | 
 | 170 | /* tri-speed only | 
 | 171 |  * pn = port number, 0-9 | 
 | 172 |  */ | 
 | 173 | #define REG_MODE_CFG(pn)	CRA(0x1,pn,0x00)	/* Mode configuration */ | 
 | 174 | #define REG_PAUSE_CFG(pn)	CRA(0x1,pn,0x01)	/* Pause configuration */ | 
 | 175 | #define REG_NORMALIZER(pn)	CRA(0x1,pn,0x05)	/* Normalizer */ | 
 | 176 | #define REG_TBI_STATUS(pn)	CRA(0x1,pn,0x06)	/* TBI status */ | 
 | 177 | #define REG_PCS_STATUS_DBG(pn)	CRA(0x1,pn,0x07)	/* PCS status debug */ | 
 | 178 | #define REG_PCS_CTRL(pn)	CRA(0x1,pn,0x08)	/* PCS control */ | 
 | 179 | #define REG_TBI_CONFIG(pn)	CRA(0x1,pn,0x09)	/* TBI configuration */ | 
 | 180 | #define REG_STICK_BIT(pn)	CRA(0x1,pn,0x0a)	/* Sticky bits */ | 
 | 181 | #define REG_DEV_SETUP(pn)	CRA(0x1,pn,0x0b)	/* MAC clock/reset setup */ | 
 | 182 | #define REG_DROP_CNT(pn)	CRA(0x1,pn,0x0c)	/* Drop counter */ | 
 | 183 | #define REG_PORT_POS(pn)	CRA(0x1,pn,0x0d)	/* Preamble port position */ | 
 | 184 | #define REG_PORT_FAIL(pn)	CRA(0x1,pn,0x0e)	/* Preamble port position */ | 
 | 185 | #define REG_SERDES_CONF(pn)	CRA(0x1,pn,0x0f)	/* SerDes configuration */ | 
 | 186 | #define REG_SERDES_TEST(pn)	CRA(0x1,pn,0x10)	/* SerDes test */ | 
 | 187 | #define REG_SERDES_STAT(pn)	CRA(0x1,pn,0x11)	/* SerDes status */ | 
 | 188 | #define REG_SERDES_COM_CNT(pn)	CRA(0x1,pn,0x12)	/* SerDes comma counter */ | 
 | 189 | #define REG_DENORM(pn)		CRA(0x1,pn,0x15)	/* Frame denormalization */ | 
 | 190 | #define REG_DBG(pn)		CRA(0x1,pn,0x16)	/* Device 1G debug */ | 
 | 191 | #define REG_TX_IFG(pn)		CRA(0x1,pn,0x18)	/* Tx IFG config */ | 
 | 192 | #define REG_HDX(pn)		CRA(0x1,pn,0x19)	/* Half-duplex config */ | 
 | 193 |  | 
 | 194 | /* Statistics */ | 
| Francois Romieu | 8343246 | 2006-12-12 00:13:48 +0100 | [diff] [blame] | 195 | /* CRA(0x4,pn,reg) */ | 
 | 196 | /* reg below */ | 
| Stephen Hemminger | f1d3d38 | 2006-12-01 16:36:16 -0800 | [diff] [blame] | 197 | /* pn = port number, 0-a, a = 10GbE */ | 
| Stephen Hemminger | f1d3d38 | 2006-12-01 16:36:16 -0800 | [diff] [blame] | 198 |  | 
| Francois Romieu | 8343246 | 2006-12-12 00:13:48 +0100 | [diff] [blame] | 199 | enum { | 
 | 200 | 	RxInBytes		= 0x00,	// # Rx in octets | 
 | 201 | 	RxSymbolCarrier		= 0x01,	// Frames w/ symbol errors | 
 | 202 | 	RxPause			= 0x02,	// # pause frames received | 
 | 203 | 	RxUnsupOpcode		= 0x03,	// # control frames with unsupported opcode | 
 | 204 | 	RxOkBytes		= 0x04,	// # octets in good frames | 
 | 205 | 	RxBadBytes		= 0x05,	// # octets in bad frames | 
 | 206 | 	RxUnicast		= 0x06,	// # good unicast frames | 
 | 207 | 	RxMulticast		= 0x07,	// # good multicast frames | 
 | 208 | 	RxBroadcast		= 0x08,	// # good broadcast frames | 
 | 209 | 	Crc			= 0x09,	// # frames w/ bad CRC only | 
 | 210 | 	RxAlignment		= 0x0a,	// # frames w/ alignment err | 
 | 211 | 	RxUndersize		= 0x0b,	// # frames undersize | 
 | 212 | 	RxFragments		= 0x0c,	// # frames undersize w/ crc err | 
 | 213 | 	RxInRangeLengthError	= 0x0d,	// # frames with length error | 
 | 214 | 	RxOutOfRangeError	= 0x0e,	// # frames with illegal length field | 
 | 215 | 	RxOversize		= 0x0f,	// # frames oversize | 
 | 216 | 	RxJabbers		= 0x10,	// # frames oversize w/ crc err | 
 | 217 | 	RxSize64		= 0x11,	// # frames 64 octets long | 
 | 218 | 	RxSize65To127		= 0x12,	// # frames 65-127 octets | 
 | 219 | 	RxSize128To255		= 0x13,	// # frames 128-255 | 
 | 220 | 	RxSize256To511		= 0x14,	// # frames 256-511 | 
 | 221 | 	RxSize512To1023		= 0x15,	// # frames 512-1023 | 
 | 222 | 	RxSize1024To1518	= 0x16,	// # frames 1024-1518 | 
 | 223 | 	RxSize1519ToMax		= 0x17,	// # frames 1519-max | 
| Stephen Hemminger | f1d3d38 | 2006-12-01 16:36:16 -0800 | [diff] [blame] | 224 |  | 
| Francois Romieu | 8343246 | 2006-12-12 00:13:48 +0100 | [diff] [blame] | 225 | 	TxOutBytes		= 0x18,	// # octets tx | 
 | 226 | 	TxPause			= 0x19,	// # pause frames sent | 
 | 227 | 	TxOkBytes		= 0x1a, // # octets tx OK | 
 | 228 | 	TxUnicast		= 0x1b,	// # frames unicast | 
 | 229 | 	TxMulticast		= 0x1c,	// # frames multicast | 
 | 230 | 	TxBroadcast		= 0x1d,	// # frames broadcast | 
 | 231 | 	TxMultipleColl		= 0x1e,	// # frames tx after multiple collisions | 
 | 232 | 	TxLateColl		= 0x1f,	// # late collisions detected | 
 | 233 | 	TxXcoll			= 0x20,	// # frames lost, excessive collisions | 
 | 234 | 	TxDefer			= 0x21,	// # frames deferred on first tx attempt | 
 | 235 | 	TxXdefer		= 0x22,	// # frames excessively deferred | 
 | 236 | 	TxCsense		= 0x23,	// carrier sense errors at frame end | 
 | 237 | 	TxSize64		= 0x24,	// # frames 64 octets long | 
 | 238 | 	TxSize65To127		= 0x25,	// # frames 65-127 octets | 
 | 239 | 	TxSize128To255		= 0x26,	// # frames 128-255 | 
 | 240 | 	TxSize256To511		= 0x27,	// # frames 256-511 | 
 | 241 | 	TxSize512To1023		= 0x28,	// # frames 512-1023 | 
 | 242 | 	TxSize1024To1518	= 0x29,	// # frames 1024-1518 | 
 | 243 | 	TxSize1519ToMax		= 0x2a,	// # frames 1519-max | 
 | 244 | 	TxSingleColl		= 0x2b,	// # frames tx after single collision | 
 | 245 | 	TxBackoff2		= 0x2c,	// # frames tx ok after 2 backoffs/collisions | 
 | 246 | 	TxBackoff3		= 0x2d,	//   after 3 backoffs/collisions | 
 | 247 | 	TxBackoff4		= 0x2e,	//   after 4 | 
 | 248 | 	TxBackoff5		= 0x2f,	//   after 5 | 
 | 249 | 	TxBackoff6		= 0x30,	//   after 6 | 
 | 250 | 	TxBackoff7		= 0x31,	//   after 7 | 
 | 251 | 	TxBackoff8		= 0x32,	//   after 8 | 
 | 252 | 	TxBackoff9		= 0x33,	//   after 9 | 
 | 253 | 	TxBackoff10		= 0x34,	//   after 10 | 
 | 254 | 	TxBackoff11		= 0x35,	//   after 11 | 
 | 255 | 	TxBackoff12		= 0x36,	//   after 12 | 
 | 256 | 	TxBackoff13		= 0x37,	//   after 13 | 
 | 257 | 	TxBackoff14		= 0x38,	//   after 14 | 
 | 258 | 	TxBackoff15		= 0x39,	//   after 15 | 
 | 259 | 	TxUnderrun		= 0x3a,	// # frames dropped from underrun | 
 | 260 | 	// Hole. See REG_RX_XGMII_PROT_ERR below. | 
 | 261 | 	RxIpgShrink		= 0x3c,	// # of IPG shrinks detected | 
 | 262 | 	// Duplicate. See REG_STAT_STICKY10G below. | 
 | 263 | 	StatSticky1G		= 0x3e,	// tri-speed sticky bits | 
 | 264 | 	StatInit		= 0x3f	// Clear all statistics | 
 | 265 | }; | 
 | 266 |  | 
 | 267 | #define REG_RX_XGMII_PROT_ERR	CRA(0x4,0xa,0x3b)		/* # protocol errors detected on XGMII interface */ | 
 | 268 | #define REG_STAT_STICKY10G	CRA(0x4,0xa,StatSticky1G)	/* 10GbE sticky bits */ | 
 | 269 |  | 
 | 270 | #define REG_RX_OK_BYTES(pn)	CRA(0x4,pn,RxOkBytes) | 
 | 271 | #define REG_RX_BAD_BYTES(pn)	CRA(0x4,pn,RxBadBytes) | 
 | 272 | #define REG_TX_OK_BYTES(pn)	CRA(0x4,pn,TxOkBytes) | 
| Stephen Hemminger | f1d3d38 | 2006-12-01 16:36:16 -0800 | [diff] [blame] | 273 |  | 
 | 274 | /* MII-Management Block registers */ | 
 | 275 | /* These are for MII-M interface 0, which is the bidirectional LVTTL one.  If | 
 | 276 |  * we hooked up to the one with separate directions, the middle 0x0 needs to | 
 | 277 |  * change to 0x1.  And the current errata states that MII-M 1 doesn't work. | 
 | 278 |  */ | 
 | 279 |  | 
 | 280 | #define REG_MIIM_STATUS		CRA(0x3,0x0,0x00)	/* MII-M Status */ | 
 | 281 | #define REG_MIIM_CMD		CRA(0x3,0x0,0x01)	/* MII-M Command */ | 
 | 282 | #define REG_MIIM_DATA		CRA(0x3,0x0,0x02)	/* MII-M Data */ | 
 | 283 | #define REG_MIIM_PRESCALE	CRA(0x3,0x0,0x03)	/* MII-M MDC Prescale */ | 
 | 284 |  | 
 | 285 | #define REG_ING_FFILT_UM_EN	CRA(0x2, 0, 0xd) | 
 | 286 | #define REG_ING_FFILT_BE_EN	CRA(0x2, 0, 0x1d) | 
 | 287 | #define REG_ING_FFILT_VAL0	CRA(0x2, 0, 0x2d) | 
 | 288 | #define REG_ING_FFILT_VAL1	CRA(0x2, 0, 0x3d) | 
 | 289 | #define REG_ING_FFILT_MASK0	CRA(0x2, 0, 0x4d) | 
 | 290 | #define REG_ING_FFILT_MASK1	CRA(0x2, 0, 0x5d) | 
 | 291 | #define REG_ING_FFILT_MASK2	CRA(0x2, 0, 0x6d) | 
 | 292 | #define REG_ING_FFILT_ETYPE	CRA(0x2, 0, 0x7d) | 
 | 293 |  | 
 | 294 |  | 
 | 295 | /* Whew. */ | 
 | 296 |  | 
 | 297 | #endif |