xref: /netbsd-src/sys/arch/mips/cavium/dev/octeon_asxreg.h (revision 5dd36a3bc8bf2a9dec29ceb6349550414570c447)
1 /*	$NetBSD: octeon_asxreg.h,v 1.1 2015/04/29 08:32:01 hikaru Exp $	*/
2 
3 /*
4  * Copyright (c) 2007 Internet Initiative Japan, Inc.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
20  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  */
28 
29 /*
30  * ASX Registers
31  */
32 
33 #ifndef _OCTEON_ASXREG_H_
34 #define _OCTEON_ASXREG_H_
35 
36 #define	ASX0_RX_PRT_EN				0x00011800b0000000ULL
37 #define	ASX0_TX_PRT_EN				0x00011800b0000008ULL
38 #define	ASX0_INT_REG				0x00011800b0000010ULL
39 #define	ASX0_INT_EN				0x00011800b0000018ULL
40 #define	ASX0_RX_CLK_SET0			0x00011800b0000020ULL
41 #define	ASX0_RX_CLK_SET1			0x00011800b0000028ULL
42 #define	ASX0_RX_CLK_SET2			0x00011800b0000030ULL
43 #define	ASX0_PRT_LOOP				0x00011800b0000040ULL
44 #define	ASX0_TX_CLK_SET0			0x00011800b0000048ULL
45 #define	ASX0_TX_CLK_SET1			0x00011800b0000050ULL
46 #define	ASX0_TX_CLK_SET2			0x00011800b0000058ULL
47 #define	ASX0_COMP_BYP				0x00011800b0000068ULL
48 #define	ASX0_TX_HI_WATER000			0x00011800b0000080ULL
49 #define	ASX0_TX_HI_WATER001			0x00011800b0000088ULL
50 #define	ASX0_TX_HI_WATER002			0x00011800b0000090ULL
51 #define	ASX0_GMII_RX_CLK_SET			0x00011800b0000180ULL
52 #define	ASX0_GMII_RX_DAT_SET			0x00011800b0000188ULL
53 #define	ASX0_MII_RX_DAT_SET			0x00011800b0000190ULL
54 
55 #define ASX0_BASE				0x00011800b0000000ULL
56 #define ASX0_SIZE				0x0198ULL
57 
58 #define	ASX0_RX_PRT_EN_OFFSET			0x0000
59 #define	ASX0_TX_PRT_EN_OFFSET			0x0008
60 #define	ASX0_INT_REG_OFFSET			0x0010
61 #define	ASX0_INT_EN_OFFSET			0x0018
62 #define	ASX0_RX_CLK_SET0_OFFSET			0x0020
63 #define	ASX0_RX_CLK_SET1_OFFSET			0x0028
64 #define	ASX0_RX_CLK_SET2_OFFSET			0x0030
65 #define	ASX0_PRT_LOOP_OFFSET			0x0040
66 #define	ASX0_TX_CLK_SET0_OFFSET			0x0048
67 #define	ASX0_TX_CLK_SET1_OFFSET			0x0050
68 #define	ASX0_TX_CLK_SET2_OFFSET			0x0058
69 #define	ASX0_COMP_BYP_OFFSET			0x0068
70 #define	ASX0_TX_HI_WATER000_OFFSET		0x0080
71 #define	ASX0_TX_HI_WATER001_OFFSET		0x0088
72 #define	ASX0_TX_HI_WATER002_OFFSET		0x0090
73 #define	ASX0_GMII_RX_CLK_SET_OFFSET		0x0180
74 #define	ASX0_GMII_RX_DAT_SET_OFFSET		0x0188
75 #define	ASX0_MII_RX_DAT_SET_OFFSET		0x0190
76 
77 /* XXX */
78 
79 
80 /*
81  * ASX_RX_PRT_EN
82  */
83 #define ASX0_RX_PRT_EN_63_3			0xfffffff8
84 #define ASX0_RX_PRT_EN_PRT_EN			0x00000007
85 
86 /*
87  * ASX0_TX_PRT_EN
88  */
89 #define ASX0_TX_PRT_EN_63_3			0xfffffff8
90 #define ASX0_TX_PRT_EN_PRT_EN			0x00000007
91 
92 /*
93  * ASX0_INT_REG
94  */
95 #define ASX0_INT_REG_63_11			0xfffff800
96 #define ASX0_INT_REG_TXPSH			0x00000700
97 #define ASX0_INT_REG_7				UINT32_C(0x00000080)
98 #define ASX0_INT_REG_TXPOP			0x00000070
99 #define ASX0_INT_REG_3				UINT32_C(0x00000008)
100 #define ASX0_INT_REG_OVRFLW			0x00000007
101 
102 /*
103  * ASX0_INT_EN
104  */
105 #define ASX0_INT_EN_63_11			0xfffff800
106 #define ASX0_INT_EN_TXPSH			0x00000700
107 #define ASX0_INT_EN_7				UINT32_C(0x00000080)
108 #define ASX0_INT_EN_TXPOP			0x00000070
109 #define ASX0_INT_EN_3				UINT32_C(0x00000008)
110 #define ASX0_INT_EN_OVRFLW			0x00000007
111 
112 /*
113  * ASX0_RX_CLK_SET
114  */
115 #define ASX0_RX_CLK_SET_63_5			0xffffffe0
116 #define ASX0_RX_CLK_SET_SETTING			0x0000001f
117 
118 /*
119  * ASX0_RRT_LOOP
120  */
121 #define ASX0_PRT_LOOP_63_7			0xffffff80
122 #define ASX0_PRT_LOOP_EXT_LOOP			0x00000070
123 #define ASX0_PRT_LOOP_3				UINT32_C(0x00000008)
124 #define ASX0_PRT_LOOP_PRT_LOOP			0x00000007
125 
126 /*
127  * ASX0_TX_CLK_SET
128  */
129 #define ASX0_TX_CLK_SET_63_5			0xffffffe0
130 #define ASX0_TX_CLK_SET_SETTING			0x0000001f
131 
132 /*
133  * ASX0_TX_COMP_BYP
134  */
135 #define ASX0_TX_COMP_BYP_63_9			0xfffffe00
136 #define ASX0_TX_COMP_BYP_BYPASS			UINT32_C(0x00000100)
137 #define ASX0_TX_COMP_BYP_PCTL			0x000000f0
138 #define ASX0_TX_COMP_BYP_NCTL			0x0000000f
139 
140 /*
141  * ASX0_TX_HI_WATER
142  */
143 #define ASX0_TX_HI_WATER_63_3			0xfffffff8
144 #define ASX0_TX_HI_WATER_MARK			0x00000007
145 
146 /*
147  * ASX0_GMXII_RX_CLK_SET
148  */
149 #define ASX0_GMII_RX_CLK_SET_63_5		0xffffffe0
150 #define ASX0_GMII_RX_CLK_SET_SETTING		0x0000001f
151 
152 /*
153  * ASX0_GMXII_RX_DAT_SET
154  */
155 #define ASX0_GMII_RX_DAT_SET_63_5		0xffffffe0
156 #define ASX0_GMII_RX_DAT_SET_SETTING		0x0000001f
157 
158 /* ---- */
159 
160 #define	ASX0_RX_PRT_EN_BITS \
161 	"\177"		/* new format */ \
162 	"\020"		/* hex display */ \
163 	"\020"		/* %016x format */ \
164 	"f\x03\x3d"	"63_3\0" \
165 	"f\x00\x03"	"PRT_EN\0"
166 #define	ASX0_TX_PRT_EN_BITS \
167 	"\177"		/* new format */ \
168 	"\020"		/* hex display */ \
169 	"\020"		/* %016x format */ \
170 	"f\x03\x3d"	"63_3\0" \
171 	"f\x00\x03"	"PRT_EN\0"
172 #define	ASX0_INT_REG_BITS \
173 	"\177"		/* new format */ \
174 	"\020"		/* hex display */ \
175 	"\020"		/* %016x format */ \
176 	"f\x0b\x35"	"63_11\0" \
177 	"f\x08\x03"	"TXPSH\0" \
178 	"b\x07"		"7\0" \
179 	"f\x04\x03"	"TXPOP\0" \
180 	"b\x03"		"3\0" \
181 	"f\x00\x03"	"OVRFLW\0"
182 #define	ASX0_INT_EN_BITS \
183 	"\177"		/* new format */ \
184 	"\020"		/* hex display */ \
185 	"\020"		/* %016x format */ \
186 	"f\x0b\x35"	"63_11\0" \
187 	"f\x08\x03"	"TXPSH\0" \
188 	"b\x07"		"7\0" \
189 	"f\x04\x03"	"TXPOP\0" \
190 	"b\x03"		"3\0" \
191 	"f\x00\x03"	"OVRFLW\0"
192 #define	ASX0_RX_CLK_SET0_BITS \
193 	"\177"		/* new format */ \
194 	"\020"		/* hex display */ \
195 	"\020"		/* %016x format */ \
196 
197 #define	ASX0_RX_CLK_SET1_BITS \
198 	"\177"		/* new format */ \
199 	"\020"		/* hex display */ \
200 	"\020"		/* %016x format */ \
201 
202 #define	ASX0_RX_CLK_SET2_BITS \
203 	"\177"		/* new format */ \
204 	"\020"		/* hex display */ \
205 	"\020"		/* %016x format */ \
206 
207 #define	ASX0_PRT_LOOP_BITS \
208 	"\177"		/* new format */ \
209 	"\020"		/* hex display */ \
210 	"\020"		/* %016x format */ \
211 	"f\x07\x39"	"63_7\0" \
212 	"f\x04\x03"	"EXT_LOOP\0" \
213 	"b\x03"		"3\0" \
214 	"f\x00\x03"	"PRT_LOOP\0"
215 #define	ASX0_TX_CLK_SET0_BITS \
216 	"\177"		/* new format */ \
217 	"\020"		/* hex display */ \
218 	"\020"		/* %016x format */ \
219 
220 #define	ASX0_TX_CLK_SET1_BITS \
221 	"\177"		/* new format */ \
222 	"\020"		/* hex display */ \
223 	"\020"		/* %016x format */ \
224 
225 #define	ASX0_TX_CLK_SET2_BITS \
226 	"\177"		/* new format */ \
227 	"\020"		/* hex display */ \
228 	"\020"		/* %016x format */ \
229 
230 #define	ASX0_COMP_BYP_BITS \
231 	"\177"		/* new format */ \
232 	"\020"		/* hex display */ \
233 	"\020"		/* %016x format */ \
234 
235 #define	ASX0_TX_HI_WATER000_BITS \
236 	"\177"		/* new format */ \
237 	"\020"		/* hex display */ \
238 	"\020"		/* %016x format */ \
239 
240 #define	ASX0_TX_HI_WATER001_BITS \
241 	"\177"		/* new format */ \
242 	"\020"		/* hex display */ \
243 	"\020"		/* %016x format */ \
244 
245 #define	ASX0_TX_HI_WATER002_BITS \
246 	"\177"		/* new format */ \
247 	"\020"		/* hex display */ \
248 	"\020"		/* %016x format */ \
249 
250 #define	ASX0_GMII_RX_CLK_SET_BITS \
251 	"\177"		/* new format */ \
252 	"\020"		/* hex display */ \
253 	"\020"		/* %016x format */ \
254 	"f\x05\x3b"	"63_5\0" \
255 	"f\x00\x05"	"SETTING\0"
256 #define	ASX0_GMII_RX_DAT_SET_BITS \
257 	"\177"		/* new format */ \
258 	"\020"		/* hex display */ \
259 	"\020"		/* %016x format */ \
260 	"f\x05\x3b"	"63_5\0" \
261 	"f\x00\x05"	"SETTING\0"
262 #define	ASX0_MII_RX_DAT_SET_BITS \
263 	"\177"		/* new format */ \
264 	"\020"		/* hex display */ \
265 	"\020"		/* %016x format */ \
266 
267 
268 #endif /* _OCTEON_ASXREG_H_ */
269