1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  */
25 
26 #ifndef _ATGE_L1E_REG_H
27 #define	_ATGE_L1E_REG_H
28 
29 #ifdef __cplusplus
30 	extern "C" {
31 #endif
32 
33 /*
34  * Number of RX Rings (or pages) we use.
35  */
36 #define	L1E_RX_PAGES		2
37 
38 #pragma	pack(1)
39 typedef	struct	rx_rs	{
40 	uint32_t	seqno;
41 	uint32_t	length;
42 	uint32_t	flags;
43 	uint32_t	vtags;
44 } rx_rs_t;
45 
46 typedef	struct	rx_cmb {
47 	uint32_t	cmb[L1E_RX_PAGES];
48 } rx_cmb_t;
49 #pragma	pack()
50 
51 /*
52  * DMA CFG registers (L1E specific).
53  */
54 #define	DMA_CFG_RD_REQ_PRI		0x00000400
55 #define	DMA_CFG_RD_DELAY_CNT_MASK	0x0000F800
56 #define	DMA_CFG_WR_DELAY_CNT_MASK	0x000F0000
57 #define	DMA_CFG_TXCMB_ENB		0x00100000
58 #define	DMA_CFG_RXCMB_ENB		0x00200000
59 #define	DMA_CFG_RD_BURST_MASK		0x07
60 #define	DMA_CFG_RD_BURST_SHIFT		4
61 #define	DMA_CFG_WR_BURST_MASK		0x07
62 #define	DMA_CFG_WR_BURST_SHIFT		7
63 #define	DMA_CFG_RD_DELAY_CNT_SHIFT	11
64 #define	DMA_CFG_WR_DELAY_CNT_SHIFT	16
65 #define	DMA_CFG_RD_DELAY_CNT_DEFAULT	15
66 #define	DMA_CFG_WR_DELAY_CNT_DEFAULT	4
67 
68 #define	L1E_TX_RING_CNT_MIN		32
69 #define	L1E_TX_RING_CNT_MAX		1020
70 #define	L1E_TX_RING_ALIGN		8
71 #define	L1E_RX_PAGE_ALIGN		32
72 #define	L1E_CMB_ALIGN			32
73 #define	L1E_MAX_FRAMELEN		ETHERMAX
74 
75 #define	L1E_RX_PAGE_SZ_MIN		(8 * 1024)
76 #define	L1E_RX_PAGE_SZ_MAX		(1024 * 1024)
77 #define	L1E_RX_FRAMES_PAGE		128
78 #define	L1E_RX_PAGE_SZ	\
79 	(ROUNDUP(L1E_MAX_FRAMELEN, L1E_RX_PAGE_ALIGN) * L1E_RX_FRAMES_PAGE)
80 #define	L1E_TX_CMB_SZ			(sizeof (uint32_t))
81 #define	L1E_RX_CMB_SZ			(sizeof (uint32_t))
82 
83 #define	L1E_PROC_MAX	\
84 	((L1E_RX_PAGE_SZ * L1E_RX_PAGES) / ETHERMAX)
85 #define	L1E_PROC_DEFAULT		(L1E_PROC_MAX / 4)
86 
87 #define	L1E_INTRS                                               \
88 	(INTR_DMA_RD_TO_RST | INTR_DMA_WR_TO_RST |              \
89 	INTR_RX_PKT | INTR_TX_PKT | INTR_RX_FIFO_OFLOW |        \
90 	INTR_TX_FIFO_UNDERRUN | INTR_SMB)
91 
92 #define	L1E_RSS_IDT_TABLE0		0x1560
93 #define	L1E_RSS_CPU			0x157C
94 
95 #define	L1E_SRAM_RX_FIFO_LEN		0x1524
96 
97 #define	L1E_PHY_STATUS			0x1418
98 #define	PHY_STATUS_100M			0x00020000
99 
100 #define	L1E_SMB_STAT_TIMER		0x15C4
101 
102 #define	GPHY_CTRL_EXT_RESET		0x0001
103 #define	GPHY_CTRL_PIPE_MOD		0x0002
104 #define	GPHY_CTRL_BERT_START		0x0010
105 #define	GPHY_CTRL_GL1E_25M_ENB		0x0020
106 #define	GPHY_CTRL_LPW_EXIT		0x0040
107 #define	GPHY_CTRL_PHY_IDDQ		0x0080
108 #define	GPHY_CTRL_PHY_IDDQ_DIS		0x0100
109 #define	GPHY_CTRL_PCLK_SEL_DIS		0x0200
110 #define	GPHY_CTRL_HIB_EN		0x0400
111 #define	GPHY_CTRL_HIB_PULSE		0x0800
112 #define	GPHY_CTRL_SEL_ANA_RESET		0x1000
113 #define	GPHY_CTRL_PHY_PLL_ON		0x2000
114 #define	GPHY_CTRL_PWDOWN_HW		0x4000
115 
116 #define	RXF_VALID			0x01
117 
118 #define	L1E_RXF0_PAGE0			0x15F4
119 #define	L1E_RXF0_PAGE1			0x15F5
120 
121 #define	L1E_RXF0_PAGE0_ADDR_LO		0x1544
122 #define	L1E_RXF0_PAGE1_ADDR_LO		0x1548
123 
124 #define	L1E_RXF_PAGE_SIZE		0x1558
125 
126 #define	L1E_INT_TRIG_THRESH		0x15C8
127 #define	INT_TRIG_TX_THRESH_MASK		0x0000FFFF
128 #define	INT_TRIG_RX_THRESH_MASK		0xFFFF0000
129 #define	INT_TRIG_TX_THRESH_SHIFT	0
130 #define	INT_TRIG_RX_THRESH_SHIFT	16
131 
132 #define	L1E_INT_TRIG_TIMER		0x15CC
133 #define	INT_TRIG_TX_TIMER_MASK		0x0000FFFF
134 #define	INT_TRIG_RX_TIMER_MASK		0x0000FFFF
135 #define	INT_TRIG_TX_TIMER_SHIFT		0
136 #define	INT_TRIG_RX_TIMER_SHIFT		16
137 
138 #define	TX_COALSC_PKT_1e		0x15C8  /* W: L1E */
139 #define	RX_COALSC_PKT_1e		0x15CA  /* W: L1E */
140 #define	TX_COALSC_TO_1e			0x15CC  /* W: L1E */
141 #define	RX_COALSC_TO_1e			0x15CE  /* W: L1E */
142 
143 #define	L1E_HOST_RXF0_PAGEOFF		0x1800
144 #define	L1E_TPD_CONS_IDX		0x1804
145 #define	L1E_HOST_RXF1_PAGEOFF		0x1808
146 #define	L1E_HOST_RXF2_PAGEOFF		0x180C
147 #define	L1E_HOST_RXF3_PAGEOFF		0x1810
148 #define	L1E_RXF0_CMB0_ADDR_LO		0x1820
149 #define	L1E_RXF0_CMB1_ADDR_LO		0x1824
150 #define	L1E_RXF1_CMB0_ADDR_LO		0x1828
151 #define	L1E_RXF1_CMB1_ADDR_LO		0x182C
152 #define	L1E_RXF2_CMB0_ADDR_LO		0x1830
153 #define	L1E_RXF2_CMB1_ADDR_LO		0x1834
154 #define	L1E_RXF3_CMB0_ADDR_LO		0x1838
155 #define	L1E_RXF3_CMB1_ADDR_LO		0x183C
156 #define	L1E_TX_CMB_ADDR_LO		0x1840
157 #define	L1E_SMB_ADDR_LO			0x1844
158 
159 #define	L1E_RD_SEQNO_MASK		0x0000FFFF
160 #define	L1E_RD_HASH_MASK		0xFFFF0000
161 #define	L1E_RD_SEQNO_SHIFT		0
162 #define	L1E_RD_HASH_SHIFT		16
163 #define	L1E_RX_SEQNO(x)		\
164 	(((x) & L1E_RD_SEQNO_MASK) >> L1E_RD_SEQNO_SHIFT)
165 #define	L1E_RD_CSUM_MASK		0x0000FFFF
166 #define	L1E_RD_LEN_MASK			0x3FFF0000
167 #define	L1E_RD_CPU_MASK			0xC0000000
168 #define	L1E_RD_CSUM_SHIFT		0
169 #define	L1E_RD_LEN_SHIFT		16
170 #define	L1E_RD_CPU_SHIFT		30
171 #define	L1E_RX_CSUM(x)	\
172 	(((x) & L1E_RD_CSUM_MASK) >> L1E_RD_CSUM_SHIFT)
173 #define	L1E_RX_BYTES(x)	\
174 	(((x) & L1E_RD_LEN_MASK) >> L1E_RD_LEN_SHIFT)
175 #define	L1E_RX_CPU(x)	\
176 	(((x) & L1E_RD_CPU_MASK) >> L1E_RD_CPU_SHIFT)
177 
178 #define	L1E_RD_RSS_IPV4			0x00000001
179 #define	L1E_RD_RSS_IPV4_TCP		0x00000002
180 #define	L1E_RD_RSS_IPV6			0x00000004
181 #define	L1E_RD_RSS_IPV6_TCP		0x00000008
182 #define	L1E_RD_IPV6			0x00000010
183 #define	L1E_RD_IPV4_FRAG		0x00000020
184 #define	L1E_RD_IPV4_DF			0x00000040
185 #define	L1E_RD_802_3			0x00000080
186 #define	L1E_RD_VLAN			0x00000100
187 #define	L1E_RD_ERROR			0x00000200
188 #define	L1E_RD_IPV4			0x00000400
189 #define	L1E_RD_UDP			0x00000800
190 #define	L1E_RD_TCP			0x00001000
191 #define	L1E_RD_BCAST			0x00002000
192 #define	L1E_RD_MCAST			0x00004000
193 #define	L1E_RD_PAUSE			0x00008000
194 #define	L1E_RD_CRC			0x00010000
195 #define	L1E_RD_CODE			0x00020000
196 #define	L1E_RD_DRIBBLE			0x00040000
197 #define	L1E_RD_RUNT			0x00080000
198 #define	L1E_RD_OFLOW			0x00100000
199 #define	L1E_RD_TRUNC			0x00200000
200 #define	L1E_RD_IPCSUM_NOK		0x00400000
201 #define	L1E_RD_TCP_UDPCSUM_NOK		0x00800000
202 #define	L1E_RD_LENGTH_NOK		0x01000000
203 #define	L1E_RD_DES_ADDR_FILTERED	0x02000000
204 
205 /* TX descriptor fields */
206 #define	L1E_TD_VLAN_MASK		0xFFFF0000
207 #define	L1E_TD_PKT_INT			0x00008000
208 #define	L1E_TD_DMA_INT			0x00004000
209 #define	L1E_TD_VLAN_SHIFT		16
210 #define	L1E_TX_VLAN_TAG(x)	\
211 	(((x) << 4) | ((x) >> 13) | (((x) >> 9) & 8))
212 #define	L1E_TD_BUFLEN_SHIFT		0
213 #define	L1E_TD_MSS			0xFFF80000
214 #define	L1E_TD_TSO_HDR			0x00040000
215 #define	L1E_TD_TCPHDR_LEN		0x0003C000
216 #define	L1E_TD_IPHDR_LEN		0x00003C00
217 #define	L1E_TD_IPV6HDR_LEN2		0x00003C00
218 #define	L1E_TD_LLC_SNAP			0x00000200
219 #define	L1E_TD_VLAN_TAGGED		0x00000100
220 #define	L1E_TD_UDPCSUM			0x00000080
221 #define	L1E_TD_TCPCSUM			0x00000040
222 #define	L1E_TD_IPCSUM			0x00000020
223 #define	L1E_TD_IPV6HDR_LEN1		0x000000E0
224 #define	L1E_TD_TSO			0x00000010
225 #define	L1E_TD_CXSUM			0x00000008
226 #define	L1E_TD_INSERT_VLAN_TAG		0x00000004
227 #define	L1E_TD_IPV6			0x00000002
228 
229 #define	L1E_TD_CSUM_PLOADOFFSET		0x00FF0000
230 #define	L1E_TD_CSUM_XSUMOFFSET		0xFF000000
231 #define	L1E_TD_CSUM_XSUMOFFSET_SHIFT	24
232 #define	L1E_TD_CSUM_PLOADOFFSET_SHIFT	16
233 #define	L1E_TD_MSS_SHIFT		19
234 #define	L1E_TD_TCPHDR_LEN_SHIFT		14
235 #define	L1E_TD_IPHDR_LEN_SHIFT		10
236 
237 #define	L1E_JUMBO_FRAMELEN		8132
238 
239 #define	L1E_TX_JUMBO_THRESH		0x1584
240 #define	TX_JUMBO_THRESH_MASK		0x000007FF
241 #define	TX_JUMBO_THRESH_SHIFT		0
242 #define	TX_JUMBO_THRESH_UNIT		8
243 #define	TX_JUMBO_THRESH_UNIT_SHIFT	3
244 
245 /*
246  * Statistics counters collected by the MAC.
247  * AR81xx requires register access to get MAC statistics
248  * and the format of statistics seems to be the same of L1
249  * except for tx_abort field in TX stats. So keep it separate for simplicity.
250  */
251 #define	L1E_RX_MIB_BASE			0x1700
252 #define	L1E_TX_MIB_BASE			0x1760
253 
254 #pragma	pack(1)
255 typedef	struct smb {
256 	/* Rx stats. */
257 	uint32_t rx_frames;
258 	uint32_t rx_bcast_frames;
259 	uint32_t rx_mcast_frames;
260 	uint32_t rx_pause_frames;
261 	uint32_t rx_control_frames;
262 	uint32_t rx_crcerrs;
263 	uint32_t rx_lenerrs;
264 	uint32_t rx_bytes;
265 	uint32_t rx_runts;
266 	uint32_t rx_fragments;
267 	uint32_t rx_pkts_64;
268 	uint32_t rx_pkts_65_127;
269 	uint32_t rx_pkts_128_255;
270 	uint32_t rx_pkts_256_511;
271 	uint32_t rx_pkts_512_1023;
272 	uint32_t rx_pkts_1024_1518;
273 	uint32_t rx_pkts_1519_max;
274 	uint32_t rx_pkts_truncated;
275 	uint32_t rx_fifo_oflows;
276 	uint32_t rx_rrs_errs;
277 	uint32_t rx_alignerrs;
278 	uint32_t rx_bcast_bytes;
279 	uint32_t rx_mcast_bytes;
280 	uint32_t rx_pkts_filtered;
281 	/* Tx stats. */
282 	uint32_t tx_frames;
283 	uint32_t tx_bcast_frames;
284 	uint32_t tx_mcast_frames;
285 	uint32_t tx_pause_frames;
286 	uint32_t tx_excess_defer;
287 	uint32_t tx_control_frames;
288 	uint32_t tx_deferred;
289 	uint32_t tx_bytes;
290 	uint32_t tx_pkts_64;
291 	uint32_t tx_pkts_65_127;
292 	uint32_t tx_pkts_128_255;
293 	uint32_t tx_pkts_256_511;
294 	uint32_t tx_pkts_512_1023;
295 	uint32_t tx_pkts_1024_1518;
296 	uint32_t tx_pkts_1519_max;
297 	uint32_t tx_single_colls;
298 	uint32_t tx_multi_colls;
299 	uint32_t tx_late_colls;
300 	uint32_t tx_excess_colls;
301 	uint32_t tx_abort;
302 	uint32_t tx_underrun;
303 	uint32_t tx_desc_underrun;
304 	uint32_t tx_lenerrs;
305 	uint32_t tx_pkts_truncated;
306 	uint32_t tx_bcast_bytes;
307 	uint32_t tx_mcast_bytes;
308 } atge_l1e_smb_t;
309 #pragma	pack()
310 
311 #ifdef __cplusplus
312 }
313 #endif
314 
315 #endif	/* _ATGE_L1E_REG_H */
316