xref: /onnv-gate/usr/src/uts/common/io/atge/atge_cmn_reg.h (revision 11353:db56a54bf91c)
110393SSaurabh.Mishra@Sun.COM /*
210393SSaurabh.Mishra@Sun.COM  * CDDL HEADER START
310393SSaurabh.Mishra@Sun.COM  *
410393SSaurabh.Mishra@Sun.COM  * The contents of this file are subject to the terms of the
510393SSaurabh.Mishra@Sun.COM  * Common Development and Distribution License (the "License").
610393SSaurabh.Mishra@Sun.COM  * You may not use this file except in compliance with the License.
710393SSaurabh.Mishra@Sun.COM  *
810393SSaurabh.Mishra@Sun.COM  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
910393SSaurabh.Mishra@Sun.COM  * or http://www.opensolaris.org/os/licensing.
1010393SSaurabh.Mishra@Sun.COM  * See the License for the specific language governing permissions
1110393SSaurabh.Mishra@Sun.COM  * and limitations under the License.
1210393SSaurabh.Mishra@Sun.COM  *
1310393SSaurabh.Mishra@Sun.COM  * When distributing Covered Code, include this CDDL HEADER in each
1410393SSaurabh.Mishra@Sun.COM  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
1510393SSaurabh.Mishra@Sun.COM  * If applicable, add the following below this CDDL HEADER, with the
1610393SSaurabh.Mishra@Sun.COM  * fields enclosed by brackets "[]" replaced with your own identifying
1710393SSaurabh.Mishra@Sun.COM  * information: Portions Copyright [yyyy] [name of copyright owner]
1810393SSaurabh.Mishra@Sun.COM  *
1910393SSaurabh.Mishra@Sun.COM  * CDDL HEADER END
2010393SSaurabh.Mishra@Sun.COM  */
2110393SSaurabh.Mishra@Sun.COM /*
2210393SSaurabh.Mishra@Sun.COM  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
2310393SSaurabh.Mishra@Sun.COM  * Use is subject to license terms.
2410393SSaurabh.Mishra@Sun.COM  */
2510393SSaurabh.Mishra@Sun.COM 
2610393SSaurabh.Mishra@Sun.COM #ifndef _ATGE_CMN_REG_H
2710393SSaurabh.Mishra@Sun.COM #define	_ATGE_CMN_REG_H
2810393SSaurabh.Mishra@Sun.COM 
2910393SSaurabh.Mishra@Sun.COM #ifdef __cplusplus
3010393SSaurabh.Mishra@Sun.COM 	extern "C" {
3110393SSaurabh.Mishra@Sun.COM #endif
3210393SSaurabh.Mishra@Sun.COM 
3310393SSaurabh.Mishra@Sun.COM #define	ATGE_SPI_CTRL	0x200
3410393SSaurabh.Mishra@Sun.COM #define	SPI_VPD_ENB	0x00002000
3510393SSaurabh.Mishra@Sun.COM 
3610393SSaurabh.Mishra@Sun.COM #define	PCIE_DEVCTRL	0x0060	/* L1 */
3710393SSaurabh.Mishra@Sun.COM 
3810393SSaurabh.Mishra@Sun.COM /*
3910393SSaurabh.Mishra@Sun.COM  * Station Address
4010393SSaurabh.Mishra@Sun.COM  */
4110393SSaurabh.Mishra@Sun.COM #define	ATGE_PAR0		0x1488
4210393SSaurabh.Mishra@Sun.COM #define	ATGE_PAR1		0x148C
4310393SSaurabh.Mishra@Sun.COM 
4410393SSaurabh.Mishra@Sun.COM #define	ATGE_MASTER_CFG		0x1400
4510393SSaurabh.Mishra@Sun.COM #define	MASTER_RESET		0x00000001
4610393SSaurabh.Mishra@Sun.COM #define	MASTER_MTIMER_ENB	0x00000002
4710393SSaurabh.Mishra@Sun.COM #define	MASTER_ITIMER_ENB	0x00000004	/* L1 */
4810393SSaurabh.Mishra@Sun.COM #define	MASTER_IM_TX_TIMER_ENB	0x00000004	/* L1E */
4910393SSaurabh.Mishra@Sun.COM #define	MASTER_MANUAL_INT_ENB	0x00000008
5010393SSaurabh.Mishra@Sun.COM #define	MASTER_IM_RX_TIMER_ENB	0x00000020
5110393SSaurabh.Mishra@Sun.COM #define	MASTER_INT_RDCLR	0x00000040
5210393SSaurabh.Mishra@Sun.COM #define	MASTER_LED_MODE		0x00000200
5310393SSaurabh.Mishra@Sun.COM #define	MASTER_CHIP_REV_MASK	0x00FF0000
5410393SSaurabh.Mishra@Sun.COM #define	MASTER_CHIP_ID_MASK	0xFF000000
5510393SSaurabh.Mishra@Sun.COM #define	MASTER_CHIP_REV_SHIFT	16
5610393SSaurabh.Mishra@Sun.COM #define	MASTER_CHIP_ID_SHIFT	24
5710393SSaurabh.Mishra@Sun.COM 
5810393SSaurabh.Mishra@Sun.COM #define	ATGE_RESET_TIMEOUT	100
5910393SSaurabh.Mishra@Sun.COM 
6010393SSaurabh.Mishra@Sun.COM #define	ATGE_IDLE_STATUS	0x1410
6110393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_RXMAC	0x00000001
6210393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_TXMAC	0x00000002
6310393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_RXQ		0x00000004
6410393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_TXQ		0x00000008
6510393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_DMARD	0x00000010
6610393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_DMAWR	0x00000020
6710393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_SMB		0x00000040
6810393SSaurabh.Mishra@Sun.COM #define	IDLE_STATUS_CMB		0x00000080
6910393SSaurabh.Mishra@Sun.COM 
7010393SSaurabh.Mishra@Sun.COM #define	ATGE_MAC_CFG			0x1480
7110393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_ENB			0x00000001
7210393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_RX_ENB			0x00000002
7310393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_FC			0x00000004
7410393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_RX_FC			0x00000008
7510393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_LOOP			0x00000010
7610393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_FULL_DUPLEX		0x00000020
7710393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_CRC_ENB		0x00000040
7810393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_AUTO_PAD		0x00000080
7910393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_LENCHK		0x00000100
8010393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_RX_JUMBO_ENB		0x00000200
8110393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_PREAMBLE_MASK		0x00003C00
8210393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_VLAN_TAG_STRIP		0x00004000
8310393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_PROMISC		0x00008000
8410393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_PAUSE		0x00010000
8510393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_SCNT			0x00020000
8610393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_SYNC_RST_TX		0x00040000
8710393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_SPEED_MASK		0x00300000
8810393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_SPEED_10_100		0x00100000
8910393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_SPEED_1000		0x00200000
9010393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_DBG_TX_BACKOFF		0x00400000
9110393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_TX_JUMBO_ENB		0x00800000
9210393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_RXCSUM_ENB		0x01000000
9310393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_ALLMULTI		0x02000000
9410393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_BCAST			0x04000000
9510393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_DBG			0x08000000
9610393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_PREAMBLE_SHIFT		10
9710393SSaurabh.Mishra@Sun.COM #define	ATGE_CFG_PREAMBLE_DEFAULT	7
9810393SSaurabh.Mishra@Sun.COM 
9910393SSaurabh.Mishra@Sun.COM /*
10010393SSaurabh.Mishra@Sun.COM  * Interrupt related registers.
10110393SSaurabh.Mishra@Sun.COM  */
10210393SSaurabh.Mishra@Sun.COM #define	ATGE_INTR_MASK			0x1604
10310393SSaurabh.Mishra@Sun.COM #define	ATGE_INTR_STATUS		0x1600
10410393SSaurabh.Mishra@Sun.COM #define	INTR_SMB			0x00000001
10510393SSaurabh.Mishra@Sun.COM #define	INTR_MOD_TIMER			0x00000002
10610393SSaurabh.Mishra@Sun.COM #define	INTR_MANUAL_TIMER		0x00000004
10710393SSaurabh.Mishra@Sun.COM #define	INTR_RX_FIFO_OFLOW		0x00000008
10810393SSaurabh.Mishra@Sun.COM #define	INTR_RD_UNDERRUN		0x00000010
10910393SSaurabh.Mishra@Sun.COM #define	INTR_RRD_OFLOW			0x00000020
11010393SSaurabh.Mishra@Sun.COM #define	INTR_TX_FIFO_UNDERRUN		0x00000040
11110393SSaurabh.Mishra@Sun.COM #define	INTR_LINK_CHG			0x00000080
11210393SSaurabh.Mishra@Sun.COM #define	INTR_HOST_RD_UNDERRUN		0x00000100
11310393SSaurabh.Mishra@Sun.COM #define	INTR_HOST_RRD_OFLOW		0x00000200
11410393SSaurabh.Mishra@Sun.COM #define	INTR_DMA_RD_TO_RST		0x00000400
11510393SSaurabh.Mishra@Sun.COM #define	INTR_DMA_WR_TO_RST		0x00000800
11610393SSaurabh.Mishra@Sun.COM #define	INTR_GPHY			0x00001000
11710393SSaurabh.Mishra@Sun.COM #define	INTR_RX_PKT			0x00010000
11810393SSaurabh.Mishra@Sun.COM #define	INTR_TX_PKT			0x00020000
11910393SSaurabh.Mishra@Sun.COM #define	INTR_TX_DMA			0x00040000
12010393SSaurabh.Mishra@Sun.COM #define	INTR_MAC_RX			0x00400000
12110393SSaurabh.Mishra@Sun.COM #define	INTR_MAC_TX			0x00800000
12210393SSaurabh.Mishra@Sun.COM #define	INTR_UNDERRUN			0x01000000
12310393SSaurabh.Mishra@Sun.COM #define	INTR_FRAME_ERROR		0x02000000
12410393SSaurabh.Mishra@Sun.COM #define	INTR_FRAME_OK			0x04000000
12510393SSaurabh.Mishra@Sun.COM #define	INTR_CSUM_ERROR			0x08000000
12610393SSaurabh.Mishra@Sun.COM #define	INTR_PHY_LINK_DOWN		0x10000000
127*11353SSaurabh.Mishra@Sun.COM #define	INTR_DIS_SM			0x20000000
128*11353SSaurabh.Mishra@Sun.COM #define	INTR_DIS_DMA			0x40000000
12910393SSaurabh.Mishra@Sun.COM #define	INTR_DIS_INT			0x80000000
13010393SSaurabh.Mishra@Sun.COM 
13110393SSaurabh.Mishra@Sun.COM /* L1E intr status */
13210393SSaurabh.Mishra@Sun.COM #define	INTR_RX_PKT1			0x00080000
13310393SSaurabh.Mishra@Sun.COM #define	INTR_RX_PKT2			0x00100000
13410393SSaurabh.Mishra@Sun.COM #define	INTR_RX_PKT3			0x00200000
13510393SSaurabh.Mishra@Sun.COM 
13610393SSaurabh.Mishra@Sun.COM /* L1 intr status */
13710393SSaurabh.Mishra@Sun.COM #define	INTR_TX_DMA			0x00040000
13810393SSaurabh.Mishra@Sun.COM 
13910393SSaurabh.Mishra@Sun.COM /*
14010393SSaurabh.Mishra@Sun.COM  * L1E specific errors. We keep it here since some errors are common for
14110393SSaurabh.Mishra@Sun.COM  * both L1 and L1E chip.
14210393SSaurabh.Mishra@Sun.COM  *
14310393SSaurabh.Mishra@Sun.COM  */
14410393SSaurabh.Mishra@Sun.COM #define	L1E_INTR_ERRORS		\
14510393SSaurabh.Mishra@Sun.COM 	(INTR_DMA_RD_TO_RST | INTR_DMA_WR_TO_RST)
14610393SSaurabh.Mishra@Sun.COM 
14710393SSaurabh.Mishra@Sun.COM /*
14810393SSaurabh.Mishra@Sun.COM  * TXQ CFG registers.
14910393SSaurabh.Mishra@Sun.COM  */
15010393SSaurabh.Mishra@Sun.COM #define	ATGE_TXQ_CFG			0x1580
15110393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TPD_BURST_MASK		0x0000000F
15210393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_ENB			0x00000020
15310393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_ENHANCED_MODE		0x00000040
15410393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TX_FIFO_BURST_MASK	0xFFFF0000
15510393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TPD_BURST_SHIFT		0
15610393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TPD_BURST_DEFAULT	4
15710393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TX_FIFO_BURST_SHIFT	16
15810393SSaurabh.Mishra@Sun.COM #define	TXQ_CFG_TX_FIFO_BURST_DEFAULT	256
15910393SSaurabh.Mishra@Sun.COM 
16010393SSaurabh.Mishra@Sun.COM /*
16110393SSaurabh.Mishra@Sun.COM  * RXQ CFG register.
16210393SSaurabh.Mishra@Sun.COM  */
16310393SSaurabh.Mishra@Sun.COM #define	ATGE_RXQ_CFG			0x15A0
16410393SSaurabh.Mishra@Sun.COM 
16510393SSaurabh.Mishra@Sun.COM /*
16610393SSaurabh.Mishra@Sun.COM  * Common registers for DMA CFG.
16710393SSaurabh.Mishra@Sun.COM  */
16810393SSaurabh.Mishra@Sun.COM #define	ATGE_DMA_CFG			0x15C0
16910393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_IN_ORDER		0x00000001
17010393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_ENH_ORDER		0x00000002
17110393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_OUT_ORDER		0x00000004
17210393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RCB_64			0x00000000
17310393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RCB_128			0x00000008
17410393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_128		0x00000000
17510393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_256		0x00000010
17610393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_512		0x00000020
17710393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_1024		0x00000030
17810393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_2048		0x00000040
17910393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_BURST_4096		0x00000050
18010393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_128		0x00000000
18110393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_256		0x00000080
18210393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_512		0x00000100
18310393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_1024		0x00000180
18410393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_2048		0x00000200
18510393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_BURST_4096		0x00000280
18610393SSaurabh.Mishra@Sun.COM 
18710393SSaurabh.Mishra@Sun.COM /* L1E specific but can go into common regs */
18810393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RXCMB_ENB		0x00200000
18910393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_DELAY_CNT_DEFAULT	15
19010393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_DELAY_CNT_SHIFT	11
19110393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_RD_DELAY_CNT_MASK	0x0000F800
19210393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_DELAY_CNT_DEFAULT	4
19310393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_DELAY_CNT_SHIFT	16
19410393SSaurabh.Mishra@Sun.COM #define	DMA_CFG_WR_DELAY_CNT_MASK	0x000F0000
19510393SSaurabh.Mishra@Sun.COM 
19610393SSaurabh.Mishra@Sun.COM /*
19710393SSaurabh.Mishra@Sun.COM  * Common PHY registers.
19810393SSaurabh.Mishra@Sun.COM  */
19910393SSaurabh.Mishra@Sun.COM #define	ATGE_MDIO			0x1414
20010393SSaurabh.Mishra@Sun.COM #define	MDIO_DATA_MASK			0x0000FFFF
20110393SSaurabh.Mishra@Sun.COM #define	MDIO_REG_ADDR_MASK		0x001F0000
20210393SSaurabh.Mishra@Sun.COM #define	MDIO_OP_READ			0x00200000
20310393SSaurabh.Mishra@Sun.COM #define	MDIO_OP_WRITE			0x00000000
20410393SSaurabh.Mishra@Sun.COM #define	MDIO_SUP_PREAMBLE		0x00400000
20510393SSaurabh.Mishra@Sun.COM #define	MDIO_OP_EXECUTE			0x00800000
20610393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_4			0x00000000
20710393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_6			0x02000000
20810393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_8			0x03000000
20910393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_10			0x04000000
21010393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_14			0x05000000
21110393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_20			0x06000000
21210393SSaurabh.Mishra@Sun.COM #define	MDIO_CLK_25_28			0x07000000
21310393SSaurabh.Mishra@Sun.COM #define	MDIO_OP_BUSY			0x08000000
21410393SSaurabh.Mishra@Sun.COM #define	MDIO_DATA_SHIFT			0
21510393SSaurabh.Mishra@Sun.COM #define	MDIO_REG_ADDR_SHIFT		16
21610393SSaurabh.Mishra@Sun.COM 
21710393SSaurabh.Mishra@Sun.COM #define	MDIO_REG_ADDR(x)	\
21810393SSaurabh.Mishra@Sun.COM 	(((x) << MDIO_REG_ADDR_SHIFT) & MDIO_REG_ADDR_MASK)
21910393SSaurabh.Mishra@Sun.COM 
220*11353SSaurabh.Mishra@Sun.COM #define	ATGE_GPHY_CTRL			0x140C	/* 16-bits */
221*11353SSaurabh.Mishra@Sun.COM #define	GPHY_CTRL_RST			0x0000
222*11353SSaurabh.Mishra@Sun.COM #define	GPHY_CTRL_CLR			0x0001
223*11353SSaurabh.Mishra@Sun.COM #define	ATPHY_CDTC			0x16
224*11353SSaurabh.Mishra@Sun.COM #define	PHY_CDTC_ENB			0x0001
225*11353SSaurabh.Mishra@Sun.COM #define	PHY_CDTC_POFF			0x8
226*11353SSaurabh.Mishra@Sun.COM #define	ATPHY_CDTS			0x1C
227*11353SSaurabh.Mishra@Sun.COM 
22810393SSaurabh.Mishra@Sun.COM 
22910393SSaurabh.Mishra@Sun.COM #define	ATGE_PHY_ADDR			0
23010393SSaurabh.Mishra@Sun.COM #define	ATGE_PHY_STATUS			0x1418
23110393SSaurabh.Mishra@Sun.COM #define	PHY_TIMEOUT			1000
23210393SSaurabh.Mishra@Sun.COM 
23310393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_TPD_CNT		0x155C
23410393SSaurabh.Mishra@Sun.COM #define	DESC_TPD_CNT_MASK		0x00003FF
23510393SSaurabh.Mishra@Sun.COM #define	DESC_TPD_CNT_SHIFT		0
23610393SSaurabh.Mishra@Sun.COM 
23710393SSaurabh.Mishra@Sun.COM #define	ATGE_DMA_BLOCK			0x1534
23810393SSaurabh.Mishra@Sun.COM #define	DMA_BLOCK_LOAD			0x00000001
23910393SSaurabh.Mishra@Sun.COM 
24010393SSaurabh.Mishra@Sun.COM #define	ATGE_MBOX			0x15F0
24110393SSaurabh.Mishra@Sun.COM #define	MBOX_RD_PROD_IDX_MASK		0x000007FF
24210393SSaurabh.Mishra@Sun.COM #define	MBOX_RRD_CONS_IDX_MASK		0x003FF800
24310393SSaurabh.Mishra@Sun.COM #define	MBOX_TD_PROD_IDX_MASK		0xFFC00000
24410393SSaurabh.Mishra@Sun.COM #define	MBOX_RD_PROD_IDX_SHIFT		0
24510393SSaurabh.Mishra@Sun.COM #define	MBOX_RRD_CONS_IDX_SHIFT		11
24610393SSaurabh.Mishra@Sun.COM #define	MBOX_TD_PROD_IDX_SHIFT		22
24710393SSaurabh.Mishra@Sun.COM 
24810393SSaurabh.Mishra@Sun.COM 
24910393SSaurabh.Mishra@Sun.COM #define	ATGE_IPG_IFG_CFG		0x1484
25010393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPGT_MASK		0x0000007F
25110393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_MIFG_MASK		0x0000FF00
25210393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG1_MASK		0x007F0000
25310393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG2_MASK		0x7F000000
25410393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPGT_SHIFT		0
25510393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPGT_DEFAULT		0x60
25610393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_MIFG_SHIFT		8
25710393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_MIFG_DEFAULT		0x50
25810393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG1_SHIFT		16
25910393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG1_DEFAULT		0x40
26010393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG2_SHIFT		24
26110393SSaurabh.Mishra@Sun.COM #define	IPG_IFG_IPG2_DEFAULT		0x60
26210393SSaurabh.Mishra@Sun.COM 
26310393SSaurabh.Mishra@Sun.COM /* half-duplex parameter configuration. */
26410393SSaurabh.Mishra@Sun.COM #define	ATGE_HDPX_CFG			0x1498
26510393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_LCOL_MASK		0x000003FF
26610393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_RETRY_MASK		0x0000F000
26710393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_EXC_DEF_EN		0x00010000
26810393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_NO_BACK_C		0x00020000
26910393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_NO_BACK_P		0x00040000
27010393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_ABEBE			0x00080000
27110393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_ABEBT_MASK		0x00F00000
27210393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_JAMIPG_MASK		0x0F000000
27310393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_LCOL_SHIFT		0
27410393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_LCOL_DEFAULT		0x37
27510393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_RETRY_SHIFT		12
27610393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_RETRY_DEFAULT		0x0F
27710393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_ABEBT_SHIFT		20
27810393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_ABEBT_DEFAULT		0x0A
27910393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_JAMIPG_SHIFT		24
28010393SSaurabh.Mishra@Sun.COM #define	HDPX_CFG_JAMIPG_DEFAULT		0x07
28110393SSaurabh.Mishra@Sun.COM 
28210393SSaurabh.Mishra@Sun.COM #define	ATGE_FRAME_SIZE			0x149C
28310393SSaurabh.Mishra@Sun.COM 
28410393SSaurabh.Mishra@Sun.COM #define	ATGE_WOL_CFG			0x14A0
28510393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN			0x00000001
28610393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN_ENB		0x00000002
28710393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_MAGIC			0x00000004
28810393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_MAGIC_ENB		0x00000008
28910393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_LINK_CHG		0x00000010
29010393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_LINK_CHG_ENB		0x00000020
29110393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN_DET		0x00000100
29210393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_MAGIC_DET		0x00000200
29310393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_LINK_CHG_DET		0x00000400
29410393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_CLK_SWITCH_ENB		0x00008000
29510393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN0		0x00010000
29610393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN1		0x00020000
29710393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN2		0x00040000
29810393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN3		0x00080000
29910393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN4		0x00100000
30010393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN5		0x00200000
30110393SSaurabh.Mishra@Sun.COM #define	WOL_CFG_PATTERN6		0x00400000
30210393SSaurabh.Mishra@Sun.COM 
30310393SSaurabh.Mishra@Sun.COM /* WOL pattern length. */
30410393SSaurabh.Mishra@Sun.COM #define	ATGE_PATTERN_CFG0		0x14A4
30510393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_0_LEN_MASK		0x0000007F
30610393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_1_LEN_MASK		0x00007F00
30710393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_2_LEN_MASK		0x007F0000
30810393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_3_LEN_MASK		0x7F000000
30910393SSaurabh.Mishra@Sun.COM 
31010393SSaurabh.Mishra@Sun.COM #define	ATGE_PATTERN_CFG1		0x14A8
31110393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_4_LEN_MASK		0x0000007F
31210393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_5_LEN_MASK		0x00007F00
31310393SSaurabh.Mishra@Sun.COM #define	PATTERN_CFG_6_LEN_MASK		0x007F0000
31410393SSaurabh.Mishra@Sun.COM 
31510393SSaurabh.Mishra@Sun.COM #define	ATGE_TICK_USECS			2
31610393SSaurabh.Mishra@Sun.COM #define	ATGE_USECS(x)			((x) / ATGE_TICK_USECS)
31710393SSaurabh.Mishra@Sun.COM 
31810393SSaurabh.Mishra@Sun.COM #define	ATGE_INTR_CLR_TIMER		0x140E	/* 16-bits */
31910393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TIMER			0x1408
32010393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TIMER2			0x140A
32110393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TIMER_MIN		0
32210393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TIMER_MAX		130000	/* 130 ms */
32310393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TIMER_DEFAULT		100
32410393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_RX_TIMER_DEFAULT	1
32510393SSaurabh.Mishra@Sun.COM #define	ATGE_IM_TX_TIMER_DEFAULT	1
32610393SSaurabh.Mishra@Sun.COM #define	IM_TIMER_TX_SHIFT		0
32710393SSaurabh.Mishra@Sun.COM #define	IM_TIMER_RX_SHIFT		16
32810393SSaurabh.Mishra@Sun.COM 
32910393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_ADDR_HI		0x1540
33010393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_RD_ADDR_LO		0x1544
33110393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_RRD_ADDR_LO		0x1548
33210393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_TPD_ADDR_LO		0x154C
33310393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_CMB_ADDR_LO		0x1550
33410393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_SMB_ADDR_LO		0x1554
33510393SSaurabh.Mishra@Sun.COM #define	ATGE_DESC_RRD_RD_CNT		0x1558
33610393SSaurabh.Mishra@Sun.COM 
33710393SSaurabh.Mishra@Sun.COM #define	ATGE_RXQ_JUMBO_CFG		0x15A4
33810393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_SZ_THRESH_SHIFT	0
33910393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_SZ_THRESH_MASK	0x000007FF
34010393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_LKAH_DEFAULT	0x01
34110393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_LKAH_SHIFT	11
34210393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_LKAH_MASK		0x00007800
34310393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_RRD_TIMER_SHIFT	16
34410393SSaurabh.Mishra@Sun.COM #define	RXQ_JUMBO_CFG_RRD_TIMER_MASK	0xFFFF0000
34510393SSaurabh.Mishra@Sun.COM 
34610393SSaurabh.Mishra@Sun.COM #define	ATGE_RXQ_FIFO_PAUSE_THRESH	0x15A8
34710393SSaurabh.Mishra@Sun.COM #define	RXQ_FIFO_PAUSE_THRESH_LO_MASK	0x00000FFF
34810393SSaurabh.Mishra@Sun.COM #define	RXQ_FIFO_PAUSE_THRESH_HI_MASK	0x0FFF000
34910393SSaurabh.Mishra@Sun.COM #define	RXQ_FIFO_PAUSE_THRESH_LO_SHIFT	0
35010393SSaurabh.Mishra@Sun.COM #define	RXQ_FIFO_PAUSE_THRESH_HI_SHIFT	16
35110393SSaurabh.Mishra@Sun.COM 
35210393SSaurabh.Mishra@Sun.COM #define	ATGE_RXQ_CFG			0x15A0
35310393SSaurabh.Mishra@Sun.COM #define	ATGE_TXQ_CFG			0x1580
35410393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_ALIGN_32		0x00000000
35510393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_ALIGN_64		0x00000001
35610393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_ALIGN_128		0x00000002
35710393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_ALIGN_256		0x00000003
35810393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_QUEUE1_ENB		0x00000010
35910393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_QUEUE2_ENB		0x00000020
36010393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_QUEUE3_ENB		0x00000040
36110393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_IPV6_CSUM_VERIFY	0x00000080
36210393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_TBL_LEN_MASK	0x0000FF00
36310393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_IPV4		0x00010000
36410393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_IPV4_TCP	0x00020000
36510393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_IPV6		0x00040000
36610393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_IPV6_TCP	0x00080000
36710393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_MODE_DIS		0x00000000
36810393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_MODE_SQSINT		0x04000000
36910393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_MODE_MQUESINT	0x08000000
37010393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_MODE_MQUEMINT	0x0C000000
37110393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_NIP_QUEUE_SEL_TBL	0x10000000
37210393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_ENB		0x20000000
37310393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_CUT_THROUGH_ENB		0x40000000
37410393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_ENB			0x80000000
37510393SSaurabh.Mishra@Sun.COM #define	RXQ_CFG_RSS_HASH_TBL_LEN_SHIFT	8
37610393SSaurabh.Mishra@Sun.COM 
37710393SSaurabh.Mishra@Sun.COM /* 64bit multicast hash register. */
37810393SSaurabh.Mishra@Sun.COM #define	ATGE_MAR0			0x1490
37910393SSaurabh.Mishra@Sun.COM #define	ATGE_MAR1			0x1494
38010393SSaurabh.Mishra@Sun.COM 
38110393SSaurabh.Mishra@Sun.COM #define	ATPHY_DBG_ADDR			0x1D
38210393SSaurabh.Mishra@Sun.COM #define	ATPHY_DBG_DATA			0x1E
38310393SSaurabh.Mishra@Sun.COM 
384*11353SSaurabh.Mishra@Sun.COM #define	ATGE_TD_EOP			0x00000001
385*11353SSaurabh.Mishra@Sun.COM #define	ATGE_TD_BUFLEN_MASK		0x00003FFF
386*11353SSaurabh.Mishra@Sun.COM #define	ATGE_TD_BUFLEN_SHIFT		0
387*11353SSaurabh.Mishra@Sun.COM #define	ATGE_TX_BYTES(x)	\
388*11353SSaurabh.Mishra@Sun.COM 	(((x) << ATGE_TD_BUFLEN_SHIFT) & ATGE_TD_BUFLEN_MASK)
389*11353SSaurabh.Mishra@Sun.COM 
390*11353SSaurabh.Mishra@Sun.COM #define	ATGE_ISR_ACK_GPHY		19
391*11353SSaurabh.Mishra@Sun.COM 
39210393SSaurabh.Mishra@Sun.COM #ifdef __cplusplus
39310393SSaurabh.Mishra@Sun.COM }
39410393SSaurabh.Mishra@Sun.COM #endif
39510393SSaurabh.Mishra@Sun.COM 
39610393SSaurabh.Mishra@Sun.COM #endif	/* _ATGE_CMN_REG_H */
397