fixes mdio, adds runtime board configuration for ifxmips
[openwrt.git] / target / linux / ifxmips / files / include / asm-mips / ifxmips / ifxmips.h
1 /*
2  *   This program is free software; you can redistribute it and/or modify
3  *   it under the terms of the GNU General Public License as published by
4  *   the Free Software Foundation; either version 2 of the License, or
5  *   (at your option) any later version.
6  *
7  *   This program is distributed in the hope that it will be useful,
8  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
9  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  *   GNU General Public License for more details.
11  *
12  *   You should have received a copy of the GNU General Public License
13  *   along with this program; if not, write to the Free Software
14  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
15  *
16  *   Copyright (C) 2005 infineon
17  *   Copyright (C) 2007 John Crispin <blogic@openwrt.org> 
18  *
19  */
20 #ifndef _IFXMIPS_H__
21 #define _IFXMIPS_H__
22
23 #define ifxmips_r32(reg) __raw_readl(reg)
24 #define ifxmips_w32(val,reg) __raw_writel(val,reg)
25 #define ifxmips_w32_mask(clear,set,reg) ifxmips_w32((ifxmips_r32(reg) & ~clear) | set, reg)
26
27 /*------------ GENERAL */
28
29 #define BOARD_SYSTEM_TYPE               "IFXMIPS"
30
31 #define IOPORT_RESOURCE_START   0x10000000
32 #define IOPORT_RESOURCE_END             0xffffffff
33 #define IOMEM_RESOURCE_START    0x10000000
34 #define IOMEM_RESOURCE_END              0xffffffff
35
36 #define IFXMIPS_FLASH_START     0x10000000
37 #define IFXMIPS_FLASH_MAX       0x2000000
38
39
40 /*------------ ASC1 */
41
42 #define IFXMIPS_ASC_BASE_ADDR   (KSEG1 + 0x1E100400)
43 #define IFXMIPS_ASC_BASE_DIFF   (0x1E100C00 - 0x1E100400)
44
45 #define IFXMIPS_ASC_FSTAT               0x0048
46 #define IFXMIPS_ASC_TBUF                0x0020
47 #define IFXMIPS_ASC_WHBSTATE    0x0018
48 #define IFXMIPS_ASC_RBUF                0x0024
49 #define IFXMIPS_ASC_STATE               0x0014
50 #define IFXMIPS_ASC_IRNCR               0x00F8
51 #define IFXMIPS_ASC_CLC                 0x0000
52 #define IFXMIPS_ASC_PISEL               0x0004
53 #define IFXMIPS_ASC_TXFCON              0x0044
54 #define IFXMIPS_ASC_RXFCON              0x0040
55 #define IFXMIPS_ASC_CON                 0x0010
56 #define IFXMIPS_ASC_BG                  0x0050
57 #define IFXMIPS_ASC_IRNREN              0x00F4
58
59 #define IFXMIPS_ASC_CLC_DISS    0x2
60 #define ASC_IRNREN_RX_BUF               0x8
61 #define ASC_IRNREN_TX_BUF               0x4
62 #define ASC_IRNREN_ERR                  0x2
63 #define ASC_IRNREN_TX                   0x1
64 #define ASC_IRNCR_TIR                   0x4
65 #define ASC_IRNCR_RIR                   0x2
66 #define ASC_IRNCR_EIR                   0x4
67 #define ASCOPT_CSIZE                    0x3
68 #define ASCOPT_CS7                              0x1
69 #define ASCOPT_CS8                              0x2
70 #define ASCOPT_PARENB                   0x4
71 #define ASCOPT_STOPB                    0x8
72 #define ASCOPT_PARODD                   0x0
73 #define ASCOPT_CREAD                    0x20
74 #define ASCFSTAT_TXFFLMASK              0x3F00
75 #define ASCFSTAT_TXFFLOFF               8
76
77
78
79 /*------------ RCU */
80 #define IFXMIPS_RCU_BASE_ADDR   0xBF203000
81
82 /* reset request */
83 #define IFXMIPS_RCU_RST                 ((u32*)(IFXMIPS_RCU_BASE_ADDR + 0x0010))
84 #define IFXMIPS_RCU_RST_CPU1    (1 << 3)
85 #define IFXMIPS_RCU_RST_ALL             0x40000000
86
87 #define IFXMIPS_RCU_RST_REQ_DFE (1 << 7)
88 #define IFXMIPS_RCU_RST_REQ_AFE (1 << 11)
89 #define IFXMIPS_RCU_RST_REQ_ARC_JTAG    (1 << 20)
90
91
92 /*------------ GPTU */
93
94 #define IFXMIPS_GPTU_BASE_ADDR  0xB8000300
95
96 /* clock control register */
97 #define IFXMIPS_GPTU_GPT_CLC            ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0000))
98
99 /* captur reload register */
100 #define IFXMIPS_GPTU_GPT_CAPREL ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0030))
101
102 /* timer 6 control register */
103 #define IFXMIPS_GPTU_GPT_T6CON  ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0020))
104
105
106 /*------------ EBU */
107
108 #define IFXMIPS_EBU_BASE_ADDR   0xBE105300
109
110 /* bus configuration register */
111 #define IFXMIPS_EBU_BUSCON0             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x0060))
112 #define IFXMIPS_EBU_PCC_CON             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x0090))
113 #define IFXMIPS_EBU_PCC_IEN             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x00A4))
114 #define IFXMIPS_EBU_PCC_ISTAT   ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x00A0))
115
116
117 /*------------ CGU */
118 #define IFXMIPS_CGU_BASE_ADDR           (KSEG1 + 0x1F103000)
119 #define IFXMIPS_CGU_PLL0_CFG            ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0004))
120 #define IFXMIPS_CGU_PLL1_CFG            ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0008))
121 #define IFXMIPS_CGU_PLL2_CFG            ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x000C))
122 #define IFXMIPS_CGU_SYS                         ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0010))
123 #define IFXMIPS_CGU_UPDATE                      ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0014))
124 #define IFXMIPS_CGU_IF_CLK                      ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0018))
125 #define IFXMIPS_CGU_OSC_CON                     ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x001C))
126 #define IFXMIPS_CGU_SMD                         ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0020))
127 #define IFXMIPS_CGU_CT1SR                       ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0028))
128 #define IFXMIPS_CGU_CT2SR                       ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x002C))
129 #define IFXMIPS_CGU_PCMCR                       ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0030))
130 #define IFXMIPS_CGU_PCI_CR                      ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0034))
131 #define IFXMIPS_CGU_PD_PC                       ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0038))
132 #define IFXMIPS_CGU_FMR                         ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x003C))
133
134 /* clock mux */
135 #define IFXMIPS_CGU_SYS                 ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0010))
136 #define IFXMIPS_CGU_IFCCR               ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0018))
137 #define IFXMIPS_CGU_PCICR               ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0034))
138
139 #define CLOCK_60M                               60000000
140 #define CLOCK_83M                               83333333
141 #define CLOCK_111M                              111111111
142 #define CLOCK_133M                              133333333
143 #define CLOCK_167M                              166666667
144 #define CLOCK_333M                              333333333
145
146
147 /*------------ CGU */
148
149 #define IFXMIPS_PMU_BASE_ADDR   (KSEG1 + 0x1F102000)
150
151 #define IFXMIPS_PMU_PWDCR               ((u32*)(IFXMIPS_PMU_BASE_ADDR + 0x001C))
152 #define IFXMIPS_PMU_PWDSR               ((u32*)(IFXMIPS_PMU_BASE_ADDR + 0x0020))
153
154
155 /*------------ ICU */
156
157 #define IFXMIPS_ICU_BASE_ADDR   0xBF880200
158
159
160 #define IFXMIPS_ICU_IM0_ISR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0000))
161 #define IFXMIPS_ICU_IM0_IER             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0008))
162 #define IFXMIPS_ICU_IM0_IOSR    ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0010))
163 #define IFXMIPS_ICU_IM0_IRSR    ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0018))
164 #define IFXMIPS_ICU_IM0_IMR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0020))
165
166 #define IFXMIPS_ICU_IM1_ISR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0028))
167 #define IFXMIPS_ICU_IM5_IER             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x00D0))
168
169 #define IFXMIPS_ICU_OFFSET              (IFXMIPS_ICU_IM1_ISR - IFXMIPS_ICU_IM0_ISR)
170
171
172 /*------------ ETOP */
173
174 #define IFXMIPS_PPE32_BASE_ADDR 0xBE180000
175
176 #define ETHERNET_PACKET_DMA_BUFFER_SIZE         0x600
177
178 #define IFXMIPS_PPE32_MEM_MAP   ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x10000))
179 #define IFXMIPS_PPE32_SRST              ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x10080))
180
181 #define MII_MODE 1
182 #define REV_MII_MODE 2
183
184 /* mdio access */
185 #define IFXMIPS_PPE32_MDIO_CFG  ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x11800))
186 #define IFXMIPS_PPE32_MDIO_ACC  ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x11804))
187
188 #define MDIO_ACC_REQUEST                0x80000000
189 #define MDIO_ACC_READ                   0x40000000
190 #define MDIO_ACC_ADDR_MASK              0x1f
191 #define MDIO_ACC_ADDR_OFFSET    0x15
192 #define MDIO_ACC_REG_MASK               0xff
193 #define MDIO_ACC_REG_OFFSET             0x10
194 #define MDIO_ACC_VAL_MASK               0xffff
195
196 /* configuration */
197 #define IFXMIPS_PPE32_CFG               ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1808))
198
199 #define PPE32_MII_MASK                  0xfffffffc
200 #define PPE32_MII_NORMAL                0x8
201 #define PPE32_MII_REVERSE               0xe
202
203 /* packet length */
204 #define IFXMIPS_PPE32_IG_PLEN_CTRL      ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1820))
205
206 #define PPE32_PLEN_OVER                 0x5ee
207 #define PPE32_PLEN_UNDER                0x400000
208
209 /* enet */
210 #define IFXMIPS_PPE32_ENET_MAC_CFG      ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1840))
211
212 #define PPE32_CGEN                              0x800
213
214
215 /*------------ DMA */
216 #define IFXMIPS_DMA_BASE_ADDR   0xBE104100
217
218 #define IFXMIPS_DMA_CS                  ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x18))
219 #define IFXMIPS_DMA_CIE                 ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x2C))
220 #define IFXMIPS_DMA_IRNEN               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0xf4))
221 #define IFXMIPS_DMA_CCTRL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x1C))
222 #define IFXMIPS_DMA_CIS                 ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x28))
223 #define IFXMIPS_DMA_CDLEN               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x24))
224 #define IFXMIPS_DMA_PS                  ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x40))
225 #define IFXMIPS_DMA_PCTRL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x44))
226 #define IFXMIPS_DMA_CTRL                        ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x10))
227 #define IFXMIPS_DMA_CPOLL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x14))
228 #define IFXMIPS_DMA_CDBA                        ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x20))
229
230
231 /*------------ PCI */
232 #define PCI_CR_PR_BASE_ADDR             (KSEG1 + 0x1E105400)
233
234 #define PCI_CR_FCI_ADDR_MAP0    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C0))
235 #define PCI_CR_FCI_ADDR_MAP1    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C4))
236 #define PCI_CR_FCI_ADDR_MAP2    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C8))
237 #define PCI_CR_FCI_ADDR_MAP3    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00CC))
238 #define PCI_CR_FCI_ADDR_MAP4    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D0))
239 #define PCI_CR_FCI_ADDR_MAP5    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D4))
240 #define PCI_CR_FCI_ADDR_MAP6    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D8))
241 #define PCI_CR_FCI_ADDR_MAP7    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00DC))
242 #define PCI_CR_CLK_CTRL                 ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0000))
243 #define PCI_CR_PCI_MOD                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0030))
244 #define PCI_CR_PC_ARB                   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0080))
245 #define PCI_CR_FCI_ADDR_MAP11hg ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E4))
246 #define PCI_CR_BAR11MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0044))
247 #define PCI_CR_BAR12MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0048))
248 #define PCI_CR_BAR13MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x004C))
249 #define PCI_CS_BASE_ADDR1               ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0010))
250 #define PCI_CR_PCI_ADDR_MAP11   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0064))
251 #define PCI_CR_FCI_BURST_LENGTH ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E8))
252 #define PCI_CR_PCI_EOI                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x002C))
253
254 #define PCI_CS_PR_BASE_ADDR             (KSEG1 + 0x17000000)
255
256 #define PCI_CS_STS_CMD                  ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0004))
257
258 #define PCI_MASTER0_REQ_MASK_2BITS      8
259 #define PCI_MASTER1_REQ_MASK_2BITS      10
260 #define PCI_MASTER2_REQ_MASK_2BITS      12
261 #define INTERNAL_ARB_ENABLE_BIT         0
262
263
264 /*------------ WDT */
265
266 #define IFXMIPS_WDT_BASE_ADDR   (KSEG1 + 0x1F880000)
267
268 #define IFXMIPS_BIU_WDT_CR              ((u32*)(IFXMIPS_WDT_BASE_ADDR + 0x03F0))
269 #define IFXMIPS_BIU_WDT_SR              ((u32*)(IFXMIPS_WDT_BASE_ADDR + 0x03F8))
270
271
272 /*------------ LED */
273
274 #define IFXMIPS_LED_BASE_ADDR   (KSEG1 + 0x1E100BB0)
275 #define IFXMIPS_LED_CON0                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0000))
276 #define IFXMIPS_LED_CON1                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0004))
277 #define IFXMIPS_LED_CPU0                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0008))
278 #define IFXMIPS_LED_CPU1                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x000C))
279 #define IFXMIPS_LED_AR                  ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0010))
280
281 #define LED_CON0_SWU                    (1 << 31)
282 #define LED_CON0_AD1                    (1 << 25)
283 #define LED_CON0_AD0                    (1 << 24)
284
285 #define IFXMIPS_LED_2HZ          (0)
286 #define IFXMIPS_LED_4HZ          (1 << 23)
287 #define IFXMIPS_LED_8HZ          (2 << 23)
288 #define IFXMIPS_LED_10HZ         (3 << 23)
289 #define IFXMIPS_LED_MASK         (0xf << 23)
290
291 #define IFXMIPS_LED_UPD_SRC_FPI  (1 << 31)
292 #define IFXMIPS_LED_UPD_MASK     (3 << 30)
293 #define IFXMIPS_LED_ADSL_SRC            (3 << 24)
294
295 #define IFXMIPS_LED_GROUP0              (1 << 0)
296 #define IFXMIPS_LED_GROUP1              (1 << 1)
297 #define IFXMIPS_LED_GROUP2              (1 << 2)
298
299 #define IFXMIPS_LED_RISING              0
300 #define IFXMIPS_LED_FALLING             (1 << 26)
301 #define IFXMIPS_LED_EDGE_MASK   (1 << 26)
302
303
304 /*------------ GPIO */
305
306 #define IFXMIPS_GPIO_BASE_ADDR  (0xBE100B00)
307
308 #define IFXMIPS_GPIO_P0_OUT             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0010))
309 #define IFXMIPS_GPIO_P1_OUT             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0040))
310 #define IFXMIPS_GPIO_P0_IN              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0014))
311 #define IFXMIPS_GPIO_P1_IN              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0044))
312 #define IFXMIPS_GPIO_P0_DIR             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0018))
313 #define IFXMIPS_GPIO_P1_DIR             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0048))
314 #define IFXMIPS_GPIO_P0_ALTSEL0 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x001C))
315 #define IFXMIPS_GPIO_P1_ALTSEL0 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x004C))
316 #define IFXMIPS_GPIO_P0_ALTSEL1 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0020))
317 #define IFXMIPS_GPIO_P1_ALTSEL1 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0050))
318 #define IFXMIPS_GPIO_P0_OD              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0024))
319 #define IFXMIPS_GPIO_P1_OD              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0054))
320 #define IFXMIPS_GPIO_P0_STOFF   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0028))
321 #define IFXMIPS_GPIO_P1_STOFF   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0058))
322 #define IFXMIPS_GPIO_P0_PUDSEL  ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x002C))
323 #define IFXMIPS_GPIO_P1_PUDSEL  ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x005C))
324 #define IFXMIPS_GPIO_P0_PUDEN   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0030))
325 #define IFXMIPS_GPIO_P1_PUDEN   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0060))
326
327
328 /*------------ SSC */
329
330 #define IFXMIPS_SSC_BASE_ADDR   (KSEG1 + 0x1e100800)
331
332
333 #define IFXMIPS_SSC_CLC                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0000))
334 #define IFXMIPS_SSC_IRN                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x00F4))
335 #define IFXMIPS_SSC_SFCON               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0060))
336 #define IFXMIPS_SSC_WHBGPOSTAT  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0078))
337 #define IFXMIPS_SSC_STATE       ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0014))
338 #define IFXMIPS_SSC_WHBSTATE    ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0018))
339 #define IFXMIPS_SSC_FSTAT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0038))
340 #define IFXMIPS_SSC_ID                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0008))
341 #define IFXMIPS_SSC_TB                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0020))
342 #define IFXMIPS_SSC_RXFCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0030))
343 #define IFXMIPS_SSC_TXFCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0034))
344 #define IFXMIPS_SSC_CON                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0010))
345 #define IFXMIPS_SSC_GPOSTAT             ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0074))
346 #define IFXMIPS_SSC_RB                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0024))
347 #define IFXMIPS_SSC_RXCNT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0084))
348 #define IFXMIPS_SSC_GPOCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0070))
349 #define IFXMIPS_SSC_BR                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0040))
350 #define IFXMIPS_SSC_RXREQ               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0080))
351 #define IFXMIPS_SSC_SFSTAT              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0064))
352 #define IFXMIPS_SSC_RXCNT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0084))
353
354
355 /*------------ MEI */
356
357 #define IFXMIPS_MEI_BASE_ADDR   (0xBE116000)
358
359 #define MEI_DATA_XFR                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0000))
360 #define MEI_VERSION                             ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0004))
361 #define MEI_ARC_GP_STAT                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0008))
362 #define MEI_DATA_XFR_STAT               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x000C))
363 #define MEI_XFR_ADDR                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0010))
364 #define MEI_MAX_WAIT                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0014))
365 #define MEI_TO_ARC_INT                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0018))
366 #define ARC_TO_MEI_INT                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x001C))
367 #define ARC_TO_MEI_INT_MASK             ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0020))
368 #define MEI_DEBUG_WAD                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0024))
369 #define MEI_DEBUG_RAD                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0028))
370 #define MEI_DEBUG_DATA                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x002C))
371 #define MEI_DEBUG_DEC                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0030))
372 #define MEI_CONFIG                              ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0034))
373 #define MEI_RST_CONTROL                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0038))
374 #define MEI_DBG_MASTER                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x003C))
375 #define MEI_CLK_CONTROL                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0040))
376 #define MEI_BIST_CONTROL                ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0044))
377 #define MEI_BIST_STAT                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0048))
378 #define MEI_XDATA_BASE_SH               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x004c))
379 #define MEI_XDATA_BASE                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0050))
380 #define MEI_XMEM_BAR_BASE               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0054))
381 #define MEI_XMEM_BAR0                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0054))
382 #define MEI_XMEM_BAR1                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0058))
383 #define MEI_XMEM_BAR2                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x005C))
384 #define MEI_XMEM_BAR3                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0060))
385 #define MEI_XMEM_BAR4                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0064))
386 #define MEI_XMEM_BAR5                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0068))
387 #define MEI_XMEM_BAR6                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x006C))
388 #define MEI_XMEM_BAR7                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0070))
389 #define MEI_XMEM_BAR8                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0074))
390 #define MEI_XMEM_BAR9                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0078))
391 #define MEI_XMEM_BAR10                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x007C))
392 #define MEI_XMEM_BAR11                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0080))
393 #define MEI_XMEM_BAR12                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0084))
394 #define MEI_XMEM_BAR13                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0088))
395 #define MEI_XMEM_BAR14                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x008C))
396 #define MEI_XMEM_BAR15                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0090))
397 #define MEI_XMEM_BAR16                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0094))
398
399
400 /*------------ DEU */
401
402 #define IFXMIPS_DEU_BASE     (KSEG1 + 0x1E103100)
403 #define IFXMIPS_DEU_CLK                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0000))
404 #define IFXMIPS_DEU_ID                  ((u32 *)(IFXMIPS_DEU_BASE + 0x0008))
405
406 #define IFXMIPS_DES_CON                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0010))
407 #define IFXMIPS_DES_IHR                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0014))
408 #define IFXMIPS_DES_ILR                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0018))
409 #define IFXMIPS_DES_K1HR                ((u32 *)(IFXMIPS_DEU_BASE + 0x001C))
410 #define IFXMIPS_DES_K1LR                ((u32 *)(IFXMIPS_DEU_BASE + 0x0020))
411 #define IFXMIPS_DES_K3HR                ((u32 *)(IFXMIPS_DEU_BASE + 0x0024))
412 #define IFXMIPS_DES_K3LR                ((u32 *)(IFXMIPS_DEU_BASE + 0x0028))
413 #define IFXMIPS_DES_IVHR                ((u32 *)(IFXMIPS_DEU_BASE + 0x002C))
414 #define IFXMIPS_DES_IVLR                ((u32 *)(IFXMIPS_DEU_BASE + 0x0030))
415 #define IFXMIPS_DES_OHR                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0040))
416 #define IFXMIPS_DES_OLR                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0050))
417 #define IFXMIPS_AES_CON                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0050))
418 #define IFXMIPS_AES_ID3R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0054))
419 #define IFXMIPS_AES_ID2R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0058))
420 #define IFXMIPS_AES_ID1R                ((u32 *)(IFXMIPS_DEU_BASE + 0x005C))
421 #define IFXMIPS_AES_ID0R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0060))
422 #define IFXMIPS_AES_K7R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0064))
423 #define IFXMIPS_AES_K6R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0068))
424 #define IFXMIPS_AES_K5R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x006C))
425 #define IFXMIPS_AES_K4R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0070))
426 #define IFXMIPS_AES_K3R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0074))
427 #define IFXMIPS_AES_K2R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0078))
428 #define IFXMIPS_AES_K1R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x007C))
429 #define IFXMIPS_AES_K0R                 ((u32 *)(IFXMIPS_DEU_BASE + 0x0080))
430 #define IFXMIPS_AES_IV3R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0084))
431 #define IFXMIPS_AES_IV2R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0088))
432 #define IFXMIPS_AES_IV1R                ((u32 *)(IFXMIPS_DEU_BASE + 0x008C))
433 #define IFXMIPS_AES_IV0R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0090))
434 #define IFXMIPS_AES_0D3R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0094))
435 #define IFXMIPS_AES_0D2R                ((u32 *)(IFXMIPS_DEU_BASE + 0x0098))
436 #define IFXMIPS_AES_OD1R                ((u32 *)(IFXMIPS_DEU_BASE + 0x009C))
437 #define IFXMIPS_AES_OD0R                ((u32 *)(IFXMIPS_DEU_BASE + 0x00A0))
438
439 /*------------ FUSE */
440
441 #define IFXMIPS_FUSE_BASE_ADDR  (KSEG1 + 0x1F107354)
442
443
444 /*------------ MPS */
445
446 #define IFXMIPS_MPS_BASE_ADDR   (KSEG1 + 0x1F107000)
447 #define IFXMIPS_MPS_SRAM                ((u32*)(KSEG1 + 0x1F200000))
448
449 #define IFXMIPS_MPS_CHIPID              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0344))
450 #define IFXMIPS_MPS_VC0ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0000))
451 #define IFXMIPS_MPS_VC1ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0004))
452 #define IFXMIPS_MPS_VC2ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0008))
453 #define IFXMIPS_MPS_VC3ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x000C))
454 #define IFXMIPS_MPS_RVC0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0010))
455 #define IFXMIPS_MPS_RVC1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0014))
456 #define IFXMIPS_MPS_RVC2SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0018))
457 #define IFXMIPS_MPS_RVC3SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x001C))
458 #define IFXMIPS_MPS_SVC0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0020))
459 #define IFXMIPS_MPS_SVC1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0024))
460 #define IFXMIPS_MPS_SVC2SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0028))
461 #define IFXMIPS_MPS_SVC3SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x002C))
462 #define IFXMIPS_MPS_CVC0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0030))
463 #define IFXMIPS_MPS_CVC1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0034))
464 #define IFXMIPS_MPS_CVC2SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0038))
465 #define IFXMIPS_MPS_CVC3SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x003C))
466 #define IFXMIPS_MPS_RAD0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0040))
467 #define IFXMIPS_MPS_RAD1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0044))
468 #define IFXMIPS_MPS_SAD0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0048))
469 #define IFXMIPS_MPS_SAD1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x004C))
470 #define IFXMIPS_MPS_CAD0SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0050))
471 #define IFXMIPS_MPS_CAD1SR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0054))
472 #define IFXMIPS_MPS_AD0ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0058))
473 #define IFXMIPS_MPS_AD1ENR              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x005C))
474
475 #define IFXMIPS_MPS_CHIPID_VERSION_GET(value)    (((value) >> 28) & ((1 << 4) - 1))
476 #define IFXMIPS_MPS_CHIPID_VERSION_SET(value)   (((( 1 << 4) - 1) & (value)) << 28)
477 #define IFXMIPS_MPS_CHIPID_PARTNUM_GET(value)   (((value) >> 12) & ((1 << 16) - 1))
478 #define IFXMIPS_MPS_CHIPID_PARTNUM_SET(value)   (((( 1 << 16) - 1) & (value)) << 12)
479 #define IFXMIPS_MPS_CHIPID_MANID_GET(value)             (((value) >> 1) & ((1 << 10) - 1))
480 #define IFXMIPS_MPS_CHIPID_MANID_SET(value)             (((( 1 << 10) - 1) & (value)) << 1)
481
482 #endif