#ifndef _VSC7326_REG_H_
#define _VSC7326_REG_H_
#define CRA(blk,sub,adr) ((((blk) & 0x7) << 13) | (((sub) & 0xf) << 9) | (((adr) & 0xff) << 1))
#define REG_CHIP_ID CRA(0x7,0xf,0x00)
#define REG_BLADE_ID CRA(0x7,0xf,0x01)
#define REG_SW_RESET CRA(0x7,0xf,0x02)
#define REG_MEM_BIST CRA(0x7,0xf,0x04)
#define REG_IFACE_MODE CRA(0x7,0xf,0x07)
#define REG_MSCH CRA(0x7,0x2,0x06)
#define REG_CRC_CNT CRA(0x7,0x2,0x0a)
#define REG_CRC_CFG CRA(0x7,0x2,0x0b)
#define REG_SI_TRANSFER_SEL CRA(0x7,0xf,0x18)
#define REG_PLL_CLK_SPEED CRA(0x7,0xf,0x19)
#define REG_SYS_CLK_SELECT CRA(0x7,0xf,0x1c)
#define REG_GPIO_CTRL CRA(0x7,0xf,0x1d)
#define REG_GPIO_OUT CRA(0x7,0xf,0x1e)
#define REG_GPIO_IN CRA(0x7,0xf,0x1f)
#define REG_CPU_TRANSFER_SEL CRA(0x7,0xf,0x20)
#define REG_LOCAL_DATA CRA(0x7,0xf,0xfe)
#define REG_LOCAL_STATUS CRA(0x7,0xf,0xff)
#define REG_AGGR_SETUP CRA(0x7,0x1,0x00)
#define REG_PMAP_TABLE CRA(0x7,0x1,0x01)
#define REG_MPLS_BIT0 CRA(0x7,0x1,0x08)
#define REG_MPLS_BIT1 CRA(0x7,0x1,0x09)
#define REG_MPLS_BIT2 CRA(0x7,0x1,0x0a)
#define REG_MPLS_BIT3 CRA(0x7,0x1,0x0b)
#define REG_MPLS_BITMASK CRA(0x7,0x1,0x0c)
#define REG_PRE_BIT0POS CRA(0x7,0x1,0x10)
#define REG_PRE_BIT1POS CRA(0x7,0x1,0x11)
#define REG_PRE_BIT2POS CRA(0x7,0x1,0x12)
#define REG_PRE_BIT3POS CRA(0x7,0x1,0x13)
#define REG_PRE_ERR_CNT CRA(0x7,0x1,0x14)
#define REG_RAM_BIST_CMD CRA(0x7,0x1,0x00)
#define REG_RAM_BIST_RESULT CRA(0x7,0x1,0x01)
#define BIST_PORT_SELECT 0x00
#define BIST_COMMAND 0x01
#define BIST_STATUS 0x02
#define BIST_ERR_CNT_LSB 0x03
#define BIST_ERR_CNT_MSB 0x04
#define BIST_ERR_SEL_LSB 0x05
#define BIST_ERR_SEL_MSB 0x06
#define BIST_ERROR_STATE 0x07
#define BIST_ERR_ADR0 0x08
#define BIST_ERR_ADR1 0x09
#define BIST_ERR_ADR2 0x0a
#define BIST_ERR_ADR3 0x0b
#define REG_TEST(ie,fn) CRA(0x2,ie&1,0x00+fn)
#define REG_TOP_BOTTOM(ie,fn) CRA(0x2,ie&1,0x10+fn)
#define REG_TAIL(ie,fn) CRA(0x2,ie&1,0x20+fn)
#define REG_HEAD(ie,fn) CRA(0x2,ie&1,0x30+fn)
#define REG_HIGH_LOW_WM(ie,fn) CRA(0x2,ie&1,0x40+fn)
#define REG_CT_THRHLD(ie,fn) CRA(0x2,ie&1,0x50+fn)
#define REG_FIFO_DROP_CNT(ie,fn) CRA(0x2,ie&1,0x60+fn)
#define REG_DEBUG_BUF_CNT(ie,fn) CRA(0x2,ie&1,0x70+fn)
#define REG_BUCKI(fn) CRA(0x2,2,0x20+fn)
#define REG_BUCKE(fn) CRA(0x2,3,0x20+fn)
#define REG_TRAFFIC_SHAPER_BUCKET(ie,bn) CRA(0x2,ie&1,0x0a + (bn>7) | ((bn&7)<<4))
#define REG_TRAFFIC_SHAPER_CONTROL(ie) CRA(0x2,ie&1,0x3b)
#define REG_SRAM_ADR(ie) CRA(0x2,ie&1,0x0e)
#define REG_SRAM_WR_STRB(ie) CRA(0x2,ie&1,0x1e)
#define REG_SRAM_RD_STRB(ie) CRA(0x2,ie&1,0x2e)
#define REG_SRAM_DATA_0(ie) CRA(0x2,ie&1,0x3e)
#define REG_SRAM_DATA_1(ie) CRA(0x2,ie&1,0x4e)
#define REG_SRAM_DATA_2(ie) CRA(0x2,ie&1,0x5e)
#define REG_SRAM_DATA_3(ie) CRA(0x2,ie&1,0x6e)
#define REG_SRAM_DATA_BLK_TYPE(ie) CRA(0x2,ie&1,0x7e)
#define REG_CONTROL(ie) CRA(0x2,ie&1,0x0f)
#define REG_ING_CONTROL CRA(0x2,0x0,0x0f)
#define REG_EGR_CONTROL CRA(0x2,0x1,0x0f)
#define REG_AGE_TIMER(ie) CRA(0x2,ie&1,0x1f)
#define REG_AGE_INC(ie) CRA(0x2,ie&1,0x2f)
#define DEBUG_OUT(ie) CRA(0x2,ie&1,0x3f)
#define DEBUG_CNT(ie) CRA(0x2,ie&1,0x4f)
#define REG_SPI4_MISC CRA(0x5,0x0,0x00)
#define REG_SPI4_STATUS CRA(0x5,0x0,0x01)
#define REG_SPI4_ING_SETUP0 CRA(0x5,0x0,0x02)
#define REG_SPI4_ING_SETUP1 CRA(0x5,0x0,0x03)
#define REG_SPI4_ING_SETUP2 CRA(0x5,0x0,0x04)
#define REG_SPI4_EGR_SETUP0 CRA(0x5,0x0,0x05)
#define REG_SPI4_DBG_CNT(n) CRA(0x5,0x0,0x10+n)
#define REG_SPI4_DBG_SETUP CRA(0x5,0x0,0x1A)
#define REG_SPI4_TEST CRA(0x5,0x0,0x20)
#define REG_TPGEN_UP0 CRA(0x5,0x0,0x21)
#define REG_TPGEN_UP1 CRA(0x5,0x0,0x22)
#define REG_TPCHK_UP0 CRA(0x5,0x0,0x23)
#define REG_TPCHK_UP1 CRA(0x5,0x0,0x24)
#define REG_TPSAM_P0 CRA(0x5,0x0,0x25)
#define REG_TPSAM_P1 CRA(0x5,0x0,0x26)
#define REG_TPERR_CNT CRA(0x5,0x0,0x27)
#define REG_SPI4_STICKY CRA(0x5,0x0,0x30)
#define REG_SPI4_DBG_INH CRA(0x5,0x0,0x31)
#define REG_SPI4_DBG_STATUS CRA(0x5,0x0,0x32)
#define REG_SPI4_DBG_GRANT CRA(0x5,0x0,0x33)
#define REG_SPI4_DESKEW CRA(0x5,0x0,0x43)
#define REG_MISC_10G CRA(0x1,0xa,0x00)
#define REG_PAUSE_10G CRA(0x1,0xa,0x01)
#define REG_NORMALIZER_10G CRA(0x1,0xa,0x05)
#define REG_STICKY_RX CRA(0x1,0xa,0x06)
#define REG_DENORM_10G CRA(0x1,0xa,0x07)
#define REG_STICKY_TX CRA(0x1,0xa,0x08)
#define REG_MAX_RXHIGH CRA(0x1,0xa,0x0a)
#define REG_MAX_RXLOW CRA(0x1,0xa,0x0b)
#define REG_MAC_TX_STICKY CRA(0x1,0xa,0x0c)
#define REG_MAC_TX_RUNNING CRA(0x1,0xa,0x0d)
#define REG_TX_ABORT_AGE CRA(0x1,0xa,0x14)
#define REG_TX_ABORT_SHORT CRA(0x1,0xa,0x15)
#define REG_TX_ABORT_TAXI CRA(0x1,0xa,0x16)
#define REG_TX_ABORT_UNDERRUN CRA(0x1,0xa,0x17)
#define REG_TX_DENORM_DISCARD CRA(0x1,0xa,0x18)
#define REG_XAUI_STAT_A CRA(0x1,0xa,0x20)
#define REG_XAUI_STAT_B CRA(0x1,0xa,0x21)
#define REG_XAUI_STAT_C CRA(0x1,0xa,0x22)
#define REG_XAUI_CONF_A CRA(0x1,0xa,0x23)
#define REG_XAUI_CONF_B CRA(0x1,0xa,0x24)
#define REG_XAUI_CODE_GRP_CNT CRA(0x1,0xa,0x25)
#define REG_XAUI_CONF_TEST_A CRA(0x1,0xa,0x26)
#define REG_PDERRCNT CRA(0x1,0xa,0x27)
#define REG_MAX_LEN(pn) CRA(0x1,pn,0x02)
#define REG_MAC_HIGH_ADDR(pn) CRA(0x1,pn,0x03)
#define REG_MAC_LOW_ADDR(pn) CRA(0x1,pn,0x04)
#define REG_MODE_CFG(pn) CRA(0x1,pn,0x00)
#define REG_PAUSE_CFG(pn) CRA(0x1,pn,0x01)
#define REG_NORMALIZER(pn) CRA(0x1,pn,0x05)
#define REG_TBI_STATUS(pn) CRA(0x1,pn,0x06)
#define REG_PCS_STATUS_DBG(pn) CRA(0x1,pn,0x07)
#define REG_PCS_CTRL(pn) CRA(0x1,pn,0x08)
#define REG_TBI_CONFIG(pn) CRA(0x1,pn,0x09)
#define REG_STICK_BIT(pn) CRA(0x1,pn,0x0a)
#define REG_DEV_SETUP(pn) CRA(0x1,pn,0x0b)
#define REG_DROP_CNT(pn) CRA(0x1,pn,0x0c)
#define REG_PORT_POS(pn) CRA(0x1,pn,0x0d)
#define REG_PORT_FAIL(pn) CRA(0x1,pn,0x0e)
#define REG_SERDES_CONF(pn) CRA(0x1,pn,0x0f)
#define REG_SERDES_TEST(pn) CRA(0x1,pn,0x10)
#define REG_SERDES_STAT(pn) CRA(0x1,pn,0x11)
#define REG_SERDES_COM_CNT(pn) CRA(0x1,pn,0x12)
#define REG_DENORM(pn) CRA(0x1,pn,0x15)
#define REG_DBG(pn) CRA(0x1,pn,0x16)
#define REG_TX_IFG(pn) CRA(0x1,pn,0x18)
#define REG_HDX(pn) CRA(0x1,pn,0x19)
#define REG_RX_IN_BYTES(pn) CRA(0x4,pn,0x00)
#define REG_RX_SYMBOL_CARRIER(pn) CRA(0x4,pn,0x01)
#define REG_RX_PAUSE(pn) CRA(0x4,pn,0x02)
#define REG_RX_UNSUP_OPCODE(pn) CRA(0x4,pn,0x03)
#define REG_RX_OK_BYTES(pn) CRA(0x4,pn,0x04)
#define REG_RX_BAD_BYTES(pn) CRA(0x4,pn,0x05)
#define REG_RX_UNICAST(pn) CRA(0x4,pn,0x06)
#define REG_RX_MULTICAST(pn) CRA(0x4,pn,0x07)
#define REG_RX_BROADCAST(pn) CRA(0x4,pn,0x08)
#define REG_CRC(pn) CRA(0x4,pn,0x09)
#define REG_RX_ALIGNMENT(pn) CRA(0x4,pn,0x0a)
#define REG_RX_UNDERSIZE(pn) CRA(0x4,pn,0x0b)
#define REG_RX_FRAGMENTS(pn) CRA(0x4,pn,0x0c)
#define REG_RX_IN_RANGE_LENGTH_ERROR(pn) CRA(0x4,pn,0x0d)
#define REG_RX_OUT_OF_RANGE_ERROR(pn) CRA(0x4,pn,0x0e)
#define REG_RX_OVERSIZE(pn) CRA(0x4,pn,0x0f)
#define REG_RX_JABBERS(pn) CRA(0x4,pn,0x10)
#define REG_RX_SIZE_64(pn) CRA(0x4,pn,0x11)
#define REG_RX_SIZE_65_TO_127(pn) CRA(0x4,pn,0x12)
#define REG_RX_SIZE_128_TO_255(pn) CRA(0x4,pn,0x13)
#define REG_RX_SIZE_256_TO_511(pn) CRA(0x4,pn,0x14)
#define REG_RX_SIZE_512_TO_1023(pn) CRA(0x4,pn,0x15)
#define REG_RX_SIZE_1024_TO_1518(pn) CRA(0x4,pn,0x16)
#define REG_RX_SIZE_1519_TO_MAX(pn) CRA(0x4,pn,0x17)
#define REG_TX_OUT_BYTES(pn) CRA(0x4,pn,0x18)
#define REG_TX_PAUSE(pn) CRA(0x4,pn,0x19)
#define REG_TX_OK_BYTES(pn) CRA(0x4,pn,0x1a)
#define REG_TX_UNICAST(pn) CRA(0x4,pn,0x1b)
#define REG_TX_MULTICAST(pn) CRA(0x4,pn,0x1c)
#define REG_TX_BROADCAST(pn) CRA(0x4,pn,0x1d)
#define REG_TX_MULTIPLE_COLL(pn) CRA(0x4,pn,0x1e)
#define REG_TX_LATE_COLL(pn) CRA(0x4,pn,0x1f)
#define REG_TX_XCOLL(pn) CRA(0x4,pn,0x20)
#define REG_TX_DEFER(pn) CRA(0x4,pn,0x21)
#define REG_TX_XDEFER(pn) CRA(0x4,pn,0x22)
#define REG_TX_CSENSE(pn) CRA(0x4,pn,0x23)
#define REG_TX_SIZE_64(pn) CRA(0x4,pn,0x24)
#define REG_TX_SIZE_65_TO_127(pn) CRA(0x4,pn,0x25)
#define REG_TX_SIZE_128_TO_255(pn) CRA(0x4,pn,0x26)
#define REG_TX_SIZE_256_TO_511(pn) CRA(0x4,pn,0x27)
#define REG_TX_SIZE_512_TO_1023(pn) CRA(0x4,pn,0x28)
#define REG_TX_SIZE_1024_TO_1518(pn) CRA(0x4,pn,0x29)
#define REG_TX_SIZE_1519_TO_MAX(pn) CRA(0x4,pn,0x2a)
#define REG_TX_SINGLE_COLL(pn) CRA(0x4,pn,0x2b)
#define REG_TX_BACKOFF2(pn) CRA(0x4,pn,0x2c)
#define REG_TX_BACKOFF3(pn) CRA(0x4,pn,0x2d)
#define REG_TX_BACKOFF4(pn) CRA(0x4,pn,0x2e)
#define REG_TX_BACKOFF5(pn) CRA(0x4,pn,0x2f)
#define REG_TX_BACKOFF6(pn) CRA(0x4,pn,0x30)
#define REG_TX_BACKOFF7(pn) CRA(0x4,pn,0x31)
#define REG_TX_BACKOFF8(pn) CRA(0x4,pn,0x32)
#define REG_TX_BACKOFF9(pn) CRA(0x4,pn,0x33)
#define REG_TX_BACKOFF10(pn) CRA(0x4,pn,0x34)
#define REG_TX_BACKOFF11(pn) CRA(0x4,pn,0x35)
#define REG_TX_BACKOFF12(pn) CRA(0x4,pn,0x36)
#define REG_TX_BACKOFF13(pn) CRA(0x4,pn,0x37)
#define REG_TX_BACKOFF14(pn) CRA(0x4,pn,0x38)
#define REG_TX_BACKOFF15(pn) CRA(0x4,pn,0x39)
#define REG_TX_UNDERRUN(pn) CRA(0x4,pn,0x3a)
#define REG_RX_XGMII_PROT_ERR CRA(0x4,0xa,0x3b)
#define REG_RX_IPG_SHRINK(pn) CRA(0x4,pn,0x3c)
#define REG_STAT_STICKY1G(pn) CRA(0x4,pn,0x3e)
#define REG_STAT_STICKY10G CRA(0x4,0xa,0x3e)
#define REG_STAT_INIT(pn) CRA(0x4,pn,0x3f)
#define REG_MIIM_STATUS CRA(0x3,0x0,0x00)
#define REG_MIIM_CMD CRA(0x3,0x0,0x01)
#define REG_MIIM_DATA CRA(0x3,0x0,0x02)
#define REG_MIIM_PRESCALE CRA(0x3,0x0,0x03)
#define REG_ING_FFILT_UM_EN CRA(0x2, 0, 0xd)
#define REG_ING_FFILT_BE_EN CRA(0x2, 0, 0x1d)
#define REG_ING_FFILT_VAL0 CRA(0x2, 0, 0x2d)
#define REG_ING_FFILT_VAL1 CRA(0x2, 0, 0x3d)
#define REG_ING_FFILT_MASK0 CRA(0x2, 0, 0x4d)
#define REG_ING_FFILT_MASK1 CRA(0x2, 0, 0x5d)
#define REG_ING_FFILT_MASK2 CRA(0x2, 0, 0x6d)
#define REG_ING_FFILT_ETYPE CRA(0x2, 0, 0x7d)
#endif