18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci/* $Date: 2006/04/28 19:20:17 $ $RCSfile: vsc7326_reg.h,v $ $Revision: 1.5 $ */ 38c2ecf20Sopenharmony_ci#ifndef _VSC7321_REG_H_ 48c2ecf20Sopenharmony_ci#define _VSC7321_REG_H_ 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_ci/* Register definitions for Vitesse VSC7321 (Meigs II) MAC 78c2ecf20Sopenharmony_ci * 88c2ecf20Sopenharmony_ci * Straight off the data sheet, VMDS-10038 Rev 2.0 and 98c2ecf20Sopenharmony_ci * PD0011-01-14-Meigs-II 2002-12-12 108c2ecf20Sopenharmony_ci */ 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci/* Just 'cause it's in here doesn't mean it's used. */ 138c2ecf20Sopenharmony_ci 148c2ecf20Sopenharmony_ci#define CRA(blk,sub,adr) ((((blk) & 0x7) << 13) | (((sub) & 0xf) << 9) | (((adr) & 0xff) << 1)) 158c2ecf20Sopenharmony_ci 168c2ecf20Sopenharmony_ci/* System and CPU comm's registers */ 178c2ecf20Sopenharmony_ci#define REG_CHIP_ID CRA(0x7,0xf,0x00) /* Chip ID */ 188c2ecf20Sopenharmony_ci#define REG_BLADE_ID CRA(0x7,0xf,0x01) /* Blade ID */ 198c2ecf20Sopenharmony_ci#define REG_SW_RESET CRA(0x7,0xf,0x02) /* Global Soft Reset */ 208c2ecf20Sopenharmony_ci#define REG_MEM_BIST CRA(0x7,0xf,0x04) /* mem */ 218c2ecf20Sopenharmony_ci#define REG_IFACE_MODE CRA(0x7,0xf,0x07) /* Interface mode */ 228c2ecf20Sopenharmony_ci#define REG_MSCH CRA(0x7,0x2,0x06) /* CRC error count */ 238c2ecf20Sopenharmony_ci#define REG_CRC_CNT CRA(0x7,0x2,0x0a) /* CRC error count */ 248c2ecf20Sopenharmony_ci#define REG_CRC_CFG CRA(0x7,0x2,0x0b) /* CRC config */ 258c2ecf20Sopenharmony_ci#define REG_SI_TRANSFER_SEL CRA(0x7,0xf,0x18) /* SI Transfer Select */ 268c2ecf20Sopenharmony_ci#define REG_PLL_CLK_SPEED CRA(0x7,0xf,0x19) /* Clock Speed Selection */ 278c2ecf20Sopenharmony_ci#define REG_SYS_CLK_SELECT CRA(0x7,0xf,0x1c) /* System Clock Select */ 288c2ecf20Sopenharmony_ci#define REG_GPIO_CTRL CRA(0x7,0xf,0x1d) /* GPIO Control */ 298c2ecf20Sopenharmony_ci#define REG_GPIO_OUT CRA(0x7,0xf,0x1e) /* GPIO Out */ 308c2ecf20Sopenharmony_ci#define REG_GPIO_IN CRA(0x7,0xf,0x1f) /* GPIO In */ 318c2ecf20Sopenharmony_ci#define REG_CPU_TRANSFER_SEL CRA(0x7,0xf,0x20) /* CPU Transfer Select */ 328c2ecf20Sopenharmony_ci#define REG_LOCAL_DATA CRA(0x7,0xf,0xfe) /* Local CPU Data Register */ 338c2ecf20Sopenharmony_ci#define REG_LOCAL_STATUS CRA(0x7,0xf,0xff) /* Local CPU Status Register */ 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_ci/* Aggregator registers */ 368c2ecf20Sopenharmony_ci#define REG_AGGR_SETUP CRA(0x7,0x1,0x00) /* Aggregator Setup */ 378c2ecf20Sopenharmony_ci#define REG_PMAP_TABLE CRA(0x7,0x1,0x01) /* Port map table */ 388c2ecf20Sopenharmony_ci#define REG_MPLS_BIT0 CRA(0x7,0x1,0x08) /* MPLS bit0 position */ 398c2ecf20Sopenharmony_ci#define REG_MPLS_BIT1 CRA(0x7,0x1,0x09) /* MPLS bit1 position */ 408c2ecf20Sopenharmony_ci#define REG_MPLS_BIT2 CRA(0x7,0x1,0x0a) /* MPLS bit2 position */ 418c2ecf20Sopenharmony_ci#define REG_MPLS_BIT3 CRA(0x7,0x1,0x0b) /* MPLS bit3 position */ 428c2ecf20Sopenharmony_ci#define REG_MPLS_BITMASK CRA(0x7,0x1,0x0c) /* MPLS bit mask */ 438c2ecf20Sopenharmony_ci#define REG_PRE_BIT0POS CRA(0x7,0x1,0x10) /* Preamble bit0 position */ 448c2ecf20Sopenharmony_ci#define REG_PRE_BIT1POS CRA(0x7,0x1,0x11) /* Preamble bit1 position */ 458c2ecf20Sopenharmony_ci#define REG_PRE_BIT2POS CRA(0x7,0x1,0x12) /* Preamble bit2 position */ 468c2ecf20Sopenharmony_ci#define REG_PRE_BIT3POS CRA(0x7,0x1,0x13) /* Preamble bit3 position */ 478c2ecf20Sopenharmony_ci#define REG_PRE_ERR_CNT CRA(0x7,0x1,0x14) /* Preamble parity error count */ 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci/* BIST registers */ 508c2ecf20Sopenharmony_ci/*#define REG_RAM_BIST_CMD CRA(0x7,0x2,0x00)*/ /* RAM BIST Command Register */ 518c2ecf20Sopenharmony_ci/*#define REG_RAM_BIST_RESULT CRA(0x7,0x2,0x01)*/ /* RAM BIST Read Status/Result */ 528c2ecf20Sopenharmony_ci#define REG_RAM_BIST_CMD CRA(0x7,0x1,0x00) /* RAM BIST Command Register */ 538c2ecf20Sopenharmony_ci#define REG_RAM_BIST_RESULT CRA(0x7,0x1,0x01) /* RAM BIST Read Status/Result */ 548c2ecf20Sopenharmony_ci#define BIST_PORT_SELECT 0x00 /* BIST port select */ 558c2ecf20Sopenharmony_ci#define BIST_COMMAND 0x01 /* BIST enable/disable */ 568c2ecf20Sopenharmony_ci#define BIST_STATUS 0x02 /* BIST operation status */ 578c2ecf20Sopenharmony_ci#define BIST_ERR_CNT_LSB 0x03 /* BIST error count lo 8b */ 588c2ecf20Sopenharmony_ci#define BIST_ERR_CNT_MSB 0x04 /* BIST error count hi 8b */ 598c2ecf20Sopenharmony_ci#define BIST_ERR_SEL_LSB 0x05 /* BIST error select lo 8b */ 608c2ecf20Sopenharmony_ci#define BIST_ERR_SEL_MSB 0x06 /* BIST error select hi 8b */ 618c2ecf20Sopenharmony_ci#define BIST_ERROR_STATE 0x07 /* BIST engine internal state */ 628c2ecf20Sopenharmony_ci#define BIST_ERR_ADR0 0x08 /* BIST error address lo 8b */ 638c2ecf20Sopenharmony_ci#define BIST_ERR_ADR1 0x09 /* BIST error address lomid 8b */ 648c2ecf20Sopenharmony_ci#define BIST_ERR_ADR2 0x0a /* BIST error address himid 8b */ 658c2ecf20Sopenharmony_ci#define BIST_ERR_ADR3 0x0b /* BIST error address hi 8b */ 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_ci/* FIFO registers 688c2ecf20Sopenharmony_ci * ie = 0 for ingress, 1 for egress 698c2ecf20Sopenharmony_ci * fn = FIFO number, 0-9 708c2ecf20Sopenharmony_ci */ 718c2ecf20Sopenharmony_ci#define REG_TEST(ie,fn) CRA(0x2,ie&1,0x00+fn) /* Mode & Test Register */ 728c2ecf20Sopenharmony_ci#define REG_TOP_BOTTOM(ie,fn) CRA(0x2,ie&1,0x10+fn) /* FIFO Buffer Top & Bottom */ 738c2ecf20Sopenharmony_ci#define REG_TAIL(ie,fn) CRA(0x2,ie&1,0x20+fn) /* FIFO Write Pointer */ 748c2ecf20Sopenharmony_ci#define REG_HEAD(ie,fn) CRA(0x2,ie&1,0x30+fn) /* FIFO Read Pointer */ 758c2ecf20Sopenharmony_ci#define REG_HIGH_LOW_WM(ie,fn) CRA(0x2,ie&1,0x40+fn) /* Flow Control Water Marks */ 768c2ecf20Sopenharmony_ci#define REG_CT_THRHLD(ie,fn) CRA(0x2,ie&1,0x50+fn) /* Cut Through Threshold */ 778c2ecf20Sopenharmony_ci#define REG_FIFO_DROP_CNT(ie,fn) CRA(0x2,ie&1,0x60+fn) /* Drop & CRC Error Counter */ 788c2ecf20Sopenharmony_ci#define REG_DEBUG_BUF_CNT(ie,fn) CRA(0x2,ie&1,0x70+fn) /* Input Side Debug Counter */ 798c2ecf20Sopenharmony_ci#define REG_BUCKI(fn) CRA(0x2,2,0x20+fn) /* Input Side Debug Counter */ 808c2ecf20Sopenharmony_ci#define REG_BUCKE(fn) CRA(0x2,3,0x20+fn) /* Input Side Debug Counter */ 818c2ecf20Sopenharmony_ci 828c2ecf20Sopenharmony_ci/* Traffic shaper buckets 838c2ecf20Sopenharmony_ci * ie = 0 for ingress, 1 for egress 848c2ecf20Sopenharmony_ci * bn = bucket number 0-10 (yes, 11 buckets) 858c2ecf20Sopenharmony_ci */ 868c2ecf20Sopenharmony_ci/* OK, this one's kinda ugly. Some hardware designers are perverse. */ 878c2ecf20Sopenharmony_ci#define REG_TRAFFIC_SHAPER_BUCKET(ie,bn) CRA(0x2,ie&1,0x0a + (bn>7) | ((bn&7)<<4)) 888c2ecf20Sopenharmony_ci#define REG_TRAFFIC_SHAPER_CONTROL(ie) CRA(0x2,ie&1,0x3b) 898c2ecf20Sopenharmony_ci 908c2ecf20Sopenharmony_ci#define REG_SRAM_ADR(ie) CRA(0x2,ie&1,0x0e) /* FIFO SRAM address */ 918c2ecf20Sopenharmony_ci#define REG_SRAM_WR_STRB(ie) CRA(0x2,ie&1,0x1e) /* FIFO SRAM write strobe */ 928c2ecf20Sopenharmony_ci#define REG_SRAM_RD_STRB(ie) CRA(0x2,ie&1,0x2e) /* FIFO SRAM read strobe */ 938c2ecf20Sopenharmony_ci#define REG_SRAM_DATA_0(ie) CRA(0x2,ie&1,0x3e) /* FIFO SRAM data lo 8b */ 948c2ecf20Sopenharmony_ci#define REG_SRAM_DATA_1(ie) CRA(0x2,ie&1,0x4e) /* FIFO SRAM data lomid 8b */ 958c2ecf20Sopenharmony_ci#define REG_SRAM_DATA_2(ie) CRA(0x2,ie&1,0x5e) /* FIFO SRAM data himid 8b */ 968c2ecf20Sopenharmony_ci#define REG_SRAM_DATA_3(ie) CRA(0x2,ie&1,0x6e) /* FIFO SRAM data hi 8b */ 978c2ecf20Sopenharmony_ci#define REG_SRAM_DATA_BLK_TYPE(ie) CRA(0x2,ie&1,0x7e) /* FIFO SRAM tag */ 988c2ecf20Sopenharmony_ci/* REG_ING_CONTROL equals REG_CONTROL with ie = 0, likewise REG_EGR_CONTROL is ie = 1 */ 998c2ecf20Sopenharmony_ci#define REG_CONTROL(ie) CRA(0x2,ie&1,0x0f) /* FIFO control */ 1008c2ecf20Sopenharmony_ci#define REG_ING_CONTROL CRA(0x2,0x0,0x0f) /* Ingress control (alias) */ 1018c2ecf20Sopenharmony_ci#define REG_EGR_CONTROL CRA(0x2,0x1,0x0f) /* Egress control (alias) */ 1028c2ecf20Sopenharmony_ci#define REG_AGE_TIMER(ie) CRA(0x2,ie&1,0x1f) /* Aging timer */ 1038c2ecf20Sopenharmony_ci#define REG_AGE_INC(ie) CRA(0x2,ie&1,0x2f) /* Aging increment */ 1048c2ecf20Sopenharmony_ci#define DEBUG_OUT(ie) CRA(0x2,ie&1,0x3f) /* Output debug counter control */ 1058c2ecf20Sopenharmony_ci#define DEBUG_CNT(ie) CRA(0x2,ie&1,0x4f) /* Output debug counter */ 1068c2ecf20Sopenharmony_ci 1078c2ecf20Sopenharmony_ci/* SPI4 interface */ 1088c2ecf20Sopenharmony_ci#define REG_SPI4_MISC CRA(0x5,0x0,0x00) /* Misc Register */ 1098c2ecf20Sopenharmony_ci#define REG_SPI4_STATUS CRA(0x5,0x0,0x01) /* CML Status */ 1108c2ecf20Sopenharmony_ci#define REG_SPI4_ING_SETUP0 CRA(0x5,0x0,0x02) /* Ingress Status Channel Setup */ 1118c2ecf20Sopenharmony_ci#define REG_SPI4_ING_SETUP1 CRA(0x5,0x0,0x03) /* Ingress Data Training Setup */ 1128c2ecf20Sopenharmony_ci#define REG_SPI4_ING_SETUP2 CRA(0x5,0x0,0x04) /* Ingress Data Burst Size Setup */ 1138c2ecf20Sopenharmony_ci#define REG_SPI4_EGR_SETUP0 CRA(0x5,0x0,0x05) /* Egress Status Channel Setup */ 1148c2ecf20Sopenharmony_ci#define REG_SPI4_DBG_CNT(n) CRA(0x5,0x0,0x10+n) /* Debug counters 0-9 */ 1158c2ecf20Sopenharmony_ci#define REG_SPI4_DBG_SETUP CRA(0x5,0x0,0x1A) /* Debug counters setup */ 1168c2ecf20Sopenharmony_ci#define REG_SPI4_TEST CRA(0x5,0x0,0x20) /* Test Setup Register */ 1178c2ecf20Sopenharmony_ci#define REG_TPGEN_UP0 CRA(0x5,0x0,0x21) /* Test Pattern generator user pattern 0 */ 1188c2ecf20Sopenharmony_ci#define REG_TPGEN_UP1 CRA(0x5,0x0,0x22) /* Test Pattern generator user pattern 1 */ 1198c2ecf20Sopenharmony_ci#define REG_TPCHK_UP0 CRA(0x5,0x0,0x23) /* Test Pattern checker user pattern 0 */ 1208c2ecf20Sopenharmony_ci#define REG_TPCHK_UP1 CRA(0x5,0x0,0x24) /* Test Pattern checker user pattern 1 */ 1218c2ecf20Sopenharmony_ci#define REG_TPSAM_P0 CRA(0x5,0x0,0x25) /* Sampled pattern 0 */ 1228c2ecf20Sopenharmony_ci#define REG_TPSAM_P1 CRA(0x5,0x0,0x26) /* Sampled pattern 1 */ 1238c2ecf20Sopenharmony_ci#define REG_TPERR_CNT CRA(0x5,0x0,0x27) /* Pattern checker error counter */ 1248c2ecf20Sopenharmony_ci#define REG_SPI4_STICKY CRA(0x5,0x0,0x30) /* Sticky bits register */ 1258c2ecf20Sopenharmony_ci#define REG_SPI4_DBG_INH CRA(0x5,0x0,0x31) /* Core egress & ingress inhibit */ 1268c2ecf20Sopenharmony_ci#define REG_SPI4_DBG_STATUS CRA(0x5,0x0,0x32) /* Sampled ingress status */ 1278c2ecf20Sopenharmony_ci#define REG_SPI4_DBG_GRANT CRA(0x5,0x0,0x33) /* Ingress cranted credit value */ 1288c2ecf20Sopenharmony_ci 1298c2ecf20Sopenharmony_ci#define REG_SPI4_DESKEW CRA(0x5,0x0,0x43) /* Ingress cranted credit value */ 1308c2ecf20Sopenharmony_ci 1318c2ecf20Sopenharmony_ci/* 10GbE MAC Block Registers */ 1328c2ecf20Sopenharmony_ci/* Note that those registers that are exactly the same for 10GbE as for 1338c2ecf20Sopenharmony_ci * tri-speed are only defined with the version that needs a port number. 1348c2ecf20Sopenharmony_ci * Pass 0xa in those cases. 1358c2ecf20Sopenharmony_ci * 1368c2ecf20Sopenharmony_ci * Also note that despite the presence of a MAC address register, this part 1378c2ecf20Sopenharmony_ci * does no ingress MAC address filtering. That register is used only for 1388c2ecf20Sopenharmony_ci * pause frame detection and generation. 1398c2ecf20Sopenharmony_ci */ 1408c2ecf20Sopenharmony_ci/* 10GbE specific, and different from tri-speed */ 1418c2ecf20Sopenharmony_ci#define REG_MISC_10G CRA(0x1,0xa,0x00) /* Misc 10GbE setup */ 1428c2ecf20Sopenharmony_ci#define REG_PAUSE_10G CRA(0x1,0xa,0x01) /* Pause register */ 1438c2ecf20Sopenharmony_ci#define REG_NORMALIZER_10G CRA(0x1,0xa,0x05) /* 10G normalizer */ 1448c2ecf20Sopenharmony_ci#define REG_STICKY_RX CRA(0x1,0xa,0x06) /* RX debug register */ 1458c2ecf20Sopenharmony_ci#define REG_DENORM_10G CRA(0x1,0xa,0x07) /* Denormalizer */ 1468c2ecf20Sopenharmony_ci#define REG_STICKY_TX CRA(0x1,0xa,0x08) /* TX sticky bits */ 1478c2ecf20Sopenharmony_ci#define REG_MAX_RXHIGH CRA(0x1,0xa,0x0a) /* XGMII lane 0-3 debug */ 1488c2ecf20Sopenharmony_ci#define REG_MAX_RXLOW CRA(0x1,0xa,0x0b) /* XGMII lane 4-7 debug */ 1498c2ecf20Sopenharmony_ci#define REG_MAC_TX_STICKY CRA(0x1,0xa,0x0c) /* MAC Tx state sticky debug */ 1508c2ecf20Sopenharmony_ci#define REG_MAC_TX_RUNNING CRA(0x1,0xa,0x0d) /* MAC Tx state running debug */ 1518c2ecf20Sopenharmony_ci#define REG_TX_ABORT_AGE CRA(0x1,0xa,0x14) /* Aged Tx frames discarded */ 1528c2ecf20Sopenharmony_ci#define REG_TX_ABORT_SHORT CRA(0x1,0xa,0x15) /* Short Tx frames discarded */ 1538c2ecf20Sopenharmony_ci#define REG_TX_ABORT_TAXI CRA(0x1,0xa,0x16) /* Taxi error frames discarded */ 1548c2ecf20Sopenharmony_ci#define REG_TX_ABORT_UNDERRUN CRA(0x1,0xa,0x17) /* Tx Underrun abort counter */ 1558c2ecf20Sopenharmony_ci#define REG_TX_DENORM_DISCARD CRA(0x1,0xa,0x18) /* Tx denormalizer discards */ 1568c2ecf20Sopenharmony_ci#define REG_XAUI_STAT_A CRA(0x1,0xa,0x20) /* XAUI status A */ 1578c2ecf20Sopenharmony_ci#define REG_XAUI_STAT_B CRA(0x1,0xa,0x21) /* XAUI status B */ 1588c2ecf20Sopenharmony_ci#define REG_XAUI_STAT_C CRA(0x1,0xa,0x22) /* XAUI status C */ 1598c2ecf20Sopenharmony_ci#define REG_XAUI_CONF_A CRA(0x1,0xa,0x23) /* XAUI configuration A */ 1608c2ecf20Sopenharmony_ci#define REG_XAUI_CONF_B CRA(0x1,0xa,0x24) /* XAUI configuration B */ 1618c2ecf20Sopenharmony_ci#define REG_XAUI_CODE_GRP_CNT CRA(0x1,0xa,0x25) /* XAUI code group error count */ 1628c2ecf20Sopenharmony_ci#define REG_XAUI_CONF_TEST_A CRA(0x1,0xa,0x26) /* XAUI test register A */ 1638c2ecf20Sopenharmony_ci#define REG_PDERRCNT CRA(0x1,0xa,0x27) /* XAUI test register B */ 1648c2ecf20Sopenharmony_ci 1658c2ecf20Sopenharmony_ci/* pn = port number 0-9 for tri-speed, 10 for 10GbE */ 1668c2ecf20Sopenharmony_ci/* Both tri-speed and 10GbE */ 1678c2ecf20Sopenharmony_ci#define REG_MAX_LEN(pn) CRA(0x1,pn,0x02) /* Max length */ 1688c2ecf20Sopenharmony_ci#define REG_MAC_HIGH_ADDR(pn) CRA(0x1,pn,0x03) /* Upper 24 bits of MAC addr */ 1698c2ecf20Sopenharmony_ci#define REG_MAC_LOW_ADDR(pn) CRA(0x1,pn,0x04) /* Lower 24 bits of MAC addr */ 1708c2ecf20Sopenharmony_ci 1718c2ecf20Sopenharmony_ci/* tri-speed only 1728c2ecf20Sopenharmony_ci * pn = port number, 0-9 1738c2ecf20Sopenharmony_ci */ 1748c2ecf20Sopenharmony_ci#define REG_MODE_CFG(pn) CRA(0x1,pn,0x00) /* Mode configuration */ 1758c2ecf20Sopenharmony_ci#define REG_PAUSE_CFG(pn) CRA(0x1,pn,0x01) /* Pause configuration */ 1768c2ecf20Sopenharmony_ci#define REG_NORMALIZER(pn) CRA(0x1,pn,0x05) /* Normalizer */ 1778c2ecf20Sopenharmony_ci#define REG_TBI_STATUS(pn) CRA(0x1,pn,0x06) /* TBI status */ 1788c2ecf20Sopenharmony_ci#define REG_PCS_STATUS_DBG(pn) CRA(0x1,pn,0x07) /* PCS status debug */ 1798c2ecf20Sopenharmony_ci#define REG_PCS_CTRL(pn) CRA(0x1,pn,0x08) /* PCS control */ 1808c2ecf20Sopenharmony_ci#define REG_TBI_CONFIG(pn) CRA(0x1,pn,0x09) /* TBI configuration */ 1818c2ecf20Sopenharmony_ci#define REG_STICK_BIT(pn) CRA(0x1,pn,0x0a) /* Sticky bits */ 1828c2ecf20Sopenharmony_ci#define REG_DEV_SETUP(pn) CRA(0x1,pn,0x0b) /* MAC clock/reset setup */ 1838c2ecf20Sopenharmony_ci#define REG_DROP_CNT(pn) CRA(0x1,pn,0x0c) /* Drop counter */ 1848c2ecf20Sopenharmony_ci#define REG_PORT_POS(pn) CRA(0x1,pn,0x0d) /* Preamble port position */ 1858c2ecf20Sopenharmony_ci#define REG_PORT_FAIL(pn) CRA(0x1,pn,0x0e) /* Preamble port position */ 1868c2ecf20Sopenharmony_ci#define REG_SERDES_CONF(pn) CRA(0x1,pn,0x0f) /* SerDes configuration */ 1878c2ecf20Sopenharmony_ci#define REG_SERDES_TEST(pn) CRA(0x1,pn,0x10) /* SerDes test */ 1888c2ecf20Sopenharmony_ci#define REG_SERDES_STAT(pn) CRA(0x1,pn,0x11) /* SerDes status */ 1898c2ecf20Sopenharmony_ci#define REG_SERDES_COM_CNT(pn) CRA(0x1,pn,0x12) /* SerDes comma counter */ 1908c2ecf20Sopenharmony_ci#define REG_DENORM(pn) CRA(0x1,pn,0x15) /* Frame denormalization */ 1918c2ecf20Sopenharmony_ci#define REG_DBG(pn) CRA(0x1,pn,0x16) /* Device 1G debug */ 1928c2ecf20Sopenharmony_ci#define REG_TX_IFG(pn) CRA(0x1,pn,0x18) /* Tx IFG config */ 1938c2ecf20Sopenharmony_ci#define REG_HDX(pn) CRA(0x1,pn,0x19) /* Half-duplex config */ 1948c2ecf20Sopenharmony_ci 1958c2ecf20Sopenharmony_ci/* Statistics */ 1968c2ecf20Sopenharmony_ci/* CRA(0x4,pn,reg) */ 1978c2ecf20Sopenharmony_ci/* reg below */ 1988c2ecf20Sopenharmony_ci/* pn = port number, 0-a, a = 10GbE */ 1998c2ecf20Sopenharmony_ci 2008c2ecf20Sopenharmony_cienum { 2018c2ecf20Sopenharmony_ci RxInBytes = 0x00, // # Rx in octets 2028c2ecf20Sopenharmony_ci RxSymbolCarrier = 0x01, // Frames w/ symbol errors 2038c2ecf20Sopenharmony_ci RxPause = 0x02, // # pause frames received 2048c2ecf20Sopenharmony_ci RxUnsupOpcode = 0x03, // # control frames with unsupported opcode 2058c2ecf20Sopenharmony_ci RxOkBytes = 0x04, // # octets in good frames 2068c2ecf20Sopenharmony_ci RxBadBytes = 0x05, // # octets in bad frames 2078c2ecf20Sopenharmony_ci RxUnicast = 0x06, // # good unicast frames 2088c2ecf20Sopenharmony_ci RxMulticast = 0x07, // # good multicast frames 2098c2ecf20Sopenharmony_ci RxBroadcast = 0x08, // # good broadcast frames 2108c2ecf20Sopenharmony_ci Crc = 0x09, // # frames w/ bad CRC only 2118c2ecf20Sopenharmony_ci RxAlignment = 0x0a, // # frames w/ alignment err 2128c2ecf20Sopenharmony_ci RxUndersize = 0x0b, // # frames undersize 2138c2ecf20Sopenharmony_ci RxFragments = 0x0c, // # frames undersize w/ crc err 2148c2ecf20Sopenharmony_ci RxInRangeLengthError = 0x0d, // # frames with length error 2158c2ecf20Sopenharmony_ci RxOutOfRangeError = 0x0e, // # frames with illegal length field 2168c2ecf20Sopenharmony_ci RxOversize = 0x0f, // # frames oversize 2178c2ecf20Sopenharmony_ci RxJabbers = 0x10, // # frames oversize w/ crc err 2188c2ecf20Sopenharmony_ci RxSize64 = 0x11, // # frames 64 octets long 2198c2ecf20Sopenharmony_ci RxSize65To127 = 0x12, // # frames 65-127 octets 2208c2ecf20Sopenharmony_ci RxSize128To255 = 0x13, // # frames 128-255 2218c2ecf20Sopenharmony_ci RxSize256To511 = 0x14, // # frames 256-511 2228c2ecf20Sopenharmony_ci RxSize512To1023 = 0x15, // # frames 512-1023 2238c2ecf20Sopenharmony_ci RxSize1024To1518 = 0x16, // # frames 1024-1518 2248c2ecf20Sopenharmony_ci RxSize1519ToMax = 0x17, // # frames 1519-max 2258c2ecf20Sopenharmony_ci 2268c2ecf20Sopenharmony_ci TxOutBytes = 0x18, // # octets tx 2278c2ecf20Sopenharmony_ci TxPause = 0x19, // # pause frames sent 2288c2ecf20Sopenharmony_ci TxOkBytes = 0x1a, // # octets tx OK 2298c2ecf20Sopenharmony_ci TxUnicast = 0x1b, // # frames unicast 2308c2ecf20Sopenharmony_ci TxMulticast = 0x1c, // # frames multicast 2318c2ecf20Sopenharmony_ci TxBroadcast = 0x1d, // # frames broadcast 2328c2ecf20Sopenharmony_ci TxMultipleColl = 0x1e, // # frames tx after multiple collisions 2338c2ecf20Sopenharmony_ci TxLateColl = 0x1f, // # late collisions detected 2348c2ecf20Sopenharmony_ci TxXcoll = 0x20, // # frames lost, excessive collisions 2358c2ecf20Sopenharmony_ci TxDefer = 0x21, // # frames deferred on first tx attempt 2368c2ecf20Sopenharmony_ci TxXdefer = 0x22, // # frames excessively deferred 2378c2ecf20Sopenharmony_ci TxCsense = 0x23, // carrier sense errors at frame end 2388c2ecf20Sopenharmony_ci TxSize64 = 0x24, // # frames 64 octets long 2398c2ecf20Sopenharmony_ci TxSize65To127 = 0x25, // # frames 65-127 octets 2408c2ecf20Sopenharmony_ci TxSize128To255 = 0x26, // # frames 128-255 2418c2ecf20Sopenharmony_ci TxSize256To511 = 0x27, // # frames 256-511 2428c2ecf20Sopenharmony_ci TxSize512To1023 = 0x28, // # frames 512-1023 2438c2ecf20Sopenharmony_ci TxSize1024To1518 = 0x29, // # frames 1024-1518 2448c2ecf20Sopenharmony_ci TxSize1519ToMax = 0x2a, // # frames 1519-max 2458c2ecf20Sopenharmony_ci TxSingleColl = 0x2b, // # frames tx after single collision 2468c2ecf20Sopenharmony_ci TxBackoff2 = 0x2c, // # frames tx ok after 2 backoffs/collisions 2478c2ecf20Sopenharmony_ci TxBackoff3 = 0x2d, // after 3 backoffs/collisions 2488c2ecf20Sopenharmony_ci TxBackoff4 = 0x2e, // after 4 2498c2ecf20Sopenharmony_ci TxBackoff5 = 0x2f, // after 5 2508c2ecf20Sopenharmony_ci TxBackoff6 = 0x30, // after 6 2518c2ecf20Sopenharmony_ci TxBackoff7 = 0x31, // after 7 2528c2ecf20Sopenharmony_ci TxBackoff8 = 0x32, // after 8 2538c2ecf20Sopenharmony_ci TxBackoff9 = 0x33, // after 9 2548c2ecf20Sopenharmony_ci TxBackoff10 = 0x34, // after 10 2558c2ecf20Sopenharmony_ci TxBackoff11 = 0x35, // after 11 2568c2ecf20Sopenharmony_ci TxBackoff12 = 0x36, // after 12 2578c2ecf20Sopenharmony_ci TxBackoff13 = 0x37, // after 13 2588c2ecf20Sopenharmony_ci TxBackoff14 = 0x38, // after 14 2598c2ecf20Sopenharmony_ci TxBackoff15 = 0x39, // after 15 2608c2ecf20Sopenharmony_ci TxUnderrun = 0x3a, // # frames dropped from underrun 2618c2ecf20Sopenharmony_ci // Hole. See REG_RX_XGMII_PROT_ERR below. 2628c2ecf20Sopenharmony_ci RxIpgShrink = 0x3c, // # of IPG shrinks detected 2638c2ecf20Sopenharmony_ci // Duplicate. See REG_STAT_STICKY10G below. 2648c2ecf20Sopenharmony_ci StatSticky1G = 0x3e, // tri-speed sticky bits 2658c2ecf20Sopenharmony_ci StatInit = 0x3f // Clear all statistics 2668c2ecf20Sopenharmony_ci}; 2678c2ecf20Sopenharmony_ci 2688c2ecf20Sopenharmony_ci#define REG_RX_XGMII_PROT_ERR CRA(0x4,0xa,0x3b) /* # protocol errors detected on XGMII interface */ 2698c2ecf20Sopenharmony_ci#define REG_STAT_STICKY10G CRA(0x4,0xa,StatSticky1G) /* 10GbE sticky bits */ 2708c2ecf20Sopenharmony_ci 2718c2ecf20Sopenharmony_ci#define REG_RX_OK_BYTES(pn) CRA(0x4,pn,RxOkBytes) 2728c2ecf20Sopenharmony_ci#define REG_RX_BAD_BYTES(pn) CRA(0x4,pn,RxBadBytes) 2738c2ecf20Sopenharmony_ci#define REG_TX_OK_BYTES(pn) CRA(0x4,pn,TxOkBytes) 2748c2ecf20Sopenharmony_ci 2758c2ecf20Sopenharmony_ci/* MII-Management Block registers */ 2768c2ecf20Sopenharmony_ci/* These are for MII-M interface 0, which is the bidirectional LVTTL one. If 2778c2ecf20Sopenharmony_ci * we hooked up to the one with separate directions, the middle 0x0 needs to 2788c2ecf20Sopenharmony_ci * change to 0x1. And the current errata states that MII-M 1 doesn't work. 2798c2ecf20Sopenharmony_ci */ 2808c2ecf20Sopenharmony_ci 2818c2ecf20Sopenharmony_ci#define REG_MIIM_STATUS CRA(0x3,0x0,0x00) /* MII-M Status */ 2828c2ecf20Sopenharmony_ci#define REG_MIIM_CMD CRA(0x3,0x0,0x01) /* MII-M Command */ 2838c2ecf20Sopenharmony_ci#define REG_MIIM_DATA CRA(0x3,0x0,0x02) /* MII-M Data */ 2848c2ecf20Sopenharmony_ci#define REG_MIIM_PRESCALE CRA(0x3,0x0,0x03) /* MII-M MDC Prescale */ 2858c2ecf20Sopenharmony_ci 2868c2ecf20Sopenharmony_ci#define REG_ING_FFILT_UM_EN CRA(0x2, 0, 0xd) 2878c2ecf20Sopenharmony_ci#define REG_ING_FFILT_BE_EN CRA(0x2, 0, 0x1d) 2888c2ecf20Sopenharmony_ci#define REG_ING_FFILT_VAL0 CRA(0x2, 0, 0x2d) 2898c2ecf20Sopenharmony_ci#define REG_ING_FFILT_VAL1 CRA(0x2, 0, 0x3d) 2908c2ecf20Sopenharmony_ci#define REG_ING_FFILT_MASK0 CRA(0x2, 0, 0x4d) 2918c2ecf20Sopenharmony_ci#define REG_ING_FFILT_MASK1 CRA(0x2, 0, 0x5d) 2928c2ecf20Sopenharmony_ci#define REG_ING_FFILT_MASK2 CRA(0x2, 0, 0x6d) 2938c2ecf20Sopenharmony_ci#define REG_ING_FFILT_ETYPE CRA(0x2, 0, 0x7d) 2948c2ecf20Sopenharmony_ci 2958c2ecf20Sopenharmony_ci 2968c2ecf20Sopenharmony_ci/* Whew. */ 2978c2ecf20Sopenharmony_ci 2988c2ecf20Sopenharmony_ci#endif 299