fixes ifxmips pci support and adds GENERIC_GPIO
[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
26 /*------------ GENERAL */
27
28 #define BOARD_SYSTEM_TYPE               "IFXMIPS"
29
30 #define IOPORT_RESOURCE_START   0x10000000
31 #define IOPORT_RESOURCE_END             0xffffffff
32 #define IOMEM_RESOURCE_START    0x10000000
33 #define IOMEM_RESOURCE_END              0xffffffff
34
35 #define IFXMIPS_FLASH_START     0x10000000
36 #define IFXMIPS_FLASH_MAX       0x2000000
37
38
39 /*------------ ASC1 */
40
41 #define IFXMIPS_ASC1_BASE_ADDR  (KSEG1 + 0x1E100C00)
42
43 /* FIFO status register */
44 #define IFXMIPS_ASC1_FSTAT              ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0048))
45 #define ASCFSTAT_TXFFLMASK              0x3F00
46 #define ASCFSTAT_TXFFLOFF               8
47
48 /* ASC1 transmit buffer */
49 #define IFXMIPS_ASC1_TBUF               ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0020))
50
51 /* channel operating modes */
52 #define ASCOPT_CSIZE                    0x3
53 #define ASCOPT_CS7                              0x1
54 #define ASCOPT_CS8                              0x2
55 #define ASCOPT_PARENB                   0x4
56 #define ASCOPT_STOPB                    0x8
57 #define ASCOPT_PARODD                   0x0
58 #define ASCOPT_CREAD                    0x20
59
60 /* hardware modified control register */
61 #define IFXMIPS_ASC1_WHBSTATE   ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0018))
62
63 /* receive buffer register */
64 #define IFXMIPS_ASC1_RBUF               ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0024))
65
66 /* status register */
67 #define IFXMIPS_ASC1_STATE              ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0014))
68
69 /* interrupt control */
70 #define IFXMIPS_ASC1_IRNCR              ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x00F8))
71
72 #define ASC_IRNCR_TIR                   0x4
73 #define ASC_IRNCR_RIR                   0x2
74 #define ASC_IRNCR_EIR                   0x4
75
76 /* clock control */
77 #define IFXMIPS_ASC1_CLC                        ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0000))
78
79 #define IFXMIPS_ASC1_CLC_DISS   0x2
80
81 /* port input select register */
82 #define IFXMIPS_ASC1_PISEL              ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0004))
83
84 /* tx fifo */
85 #define IFXMIPS_ASC1_TXFCON             ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0044))
86
87 /* rx fifo */
88 #define IFXMIPS_ASC1_RXFCON             ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0040))
89
90 /* control */
91 #define IFXMIPS_ASC1_CON                        ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0010))
92
93 /* timer reload */
94 #define IFXMIPS_ASC1_BG                 ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x0050))
95
96 /* int enable */
97 #define IFXMIPS_ASC1_IRNREN             ((u32*)(IFXMIPS_ASC1_BASE_ADDR + 0x00F4))
98
99 #define ASC_IRNREN_RX_BUF               0x8
100 #define ASC_IRNREN_TX_BUF               0x4
101 #define ASC_IRNREN_ERR                  0x2
102 #define ASC_IRNREN_TX                   0x1
103
104
105 /*------------ RCU */
106
107 #define IFXMIPS_RCU_BASE_ADDR   0xBF203000
108
109 /* reset request */
110 #define IFXMIPS_RCU_REQ                 ((u32*)(IFXMIPS_RCU_BASE_ADDR + 0x0010))
111 #define IFXMIPS_RST_ALL                 0x40000000
112
113 #define IFXMIPS_RCU_RST_REQ_DFE (1 << 7)
114 #define IFXMIPS_RCU_RST_REQ_AFE (1 << 11)
115 #define IFXMIPS_RCU_RST_REQ_ARC_JTAG    (1 << 20)
116
117 /*------------ MCD */
118
119 #define IFXMIPS_MCD_BASE_ADDR   (KSEG1 + 0x1F106000)
120
121 /* chip id */
122 #define IFXMIPS_MCD_CHIPID              ((u32*)(IFXMIPS_MCD_BASE_ADDR + 0x0028))
123
124
125 /*------------ GPTU */
126
127 #define IFXMIPS_GPTU_BASE_ADDR  0xB8000300
128
129 /* clock control register */
130 #define IFXMIPS_GPTU_GPT_CLC            ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0000))
131
132 /* captur reload register */
133 #define IFXMIPS_GPTU_GPT_CAPREL ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0030))
134
135 /* timer 6 control register */
136 #define IFXMIPS_GPTU_GPT_T6CON  ((u32*)(IFXMIPS_GPTU_BASE_ADDR + 0x0020))
137
138
139 /*------------ EBU */
140
141 #define IFXMIPS_EBU_BASE_ADDR   0xBE105300
142
143 /* bus configuration register */
144 #define IFXMIPS_EBU_BUSCON0             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x0060))
145 #define IFXMIPS_EBU_PCC_CON             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x0090))
146 #define IFXMIPS_EBU_PCC_IEN             ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x00A4))
147 #define IFXMIPS_EBU_PCC_ISTAT   ((u32*)(IFXMIPS_EBU_BASE_ADDR + 0x00A0))
148
149
150 /*------------ CGU */
151
152 #define IFXMIPS_CGU_BASE_ADDR   0xBF103000
153
154 /* clock mux */
155 #define IFXMIPS_CGU_SYS                 ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0010))
156 #define IFXMIPS_CGU_IFCCR               ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0018))
157 #define IFXMIPS_CGU_PCICR               ((u32*)(IFXMIPS_CGU_BASE_ADDR + 0x0034))
158
159 #define CLOCK_60M                               60000000
160 #define CLOCK_83M                               83333333
161 #define CLOCK_111M                              111111111
162 #define CLOCK_133M                              133333333
163 #define CLOCK_167M                              166666667
164 #define CLOCK_333M                              333333333
165
166
167 /*------------ CGU */
168
169 #define IFXMIPS_PMU_BASE_ADDR   (KSEG1 + 0x1F102000)
170
171 #define IFXMIPS_PMU_PWDCR               ((u32*)(IFXMIPS_PMU_BASE_ADDR + 0x001C))
172 #define IFXMIPS_PMU_PWDSR               ((u32*)(IFXMIPS_PMU_BASE_ADDR + 0x0020))
173
174
175 /*------------ ICU */
176
177 #define IFXMIPS_ICU_BASE_ADDR   0xBF880200
178
179
180 #define IFXMIPS_ICU_IM0_ISR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0000))
181 #define IFXMIPS_ICU_IM0_IER             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0008))
182 #define IFXMIPS_ICU_IM0_IOSR            ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0010))
183 #define IFXMIPS_ICU_IM0_IRSR            ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0018))
184 #define IFXMIPS_ICU_IM0_IMR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0020))
185
186 #define IFXMIPS_ICU_IM1_ISR             ((u32*)(IFXMIPS_ICU_BASE_ADDR + 0x0028))
187
188 #define IFXMIPS_ICU_OFFSET              (IFXMIPS_ICU_IM1_ISR - IFXMIPS_ICU_IM0_ISR)
189
190
191 /*------------ ETOP */
192
193 #define IFXMIPS_PPE32_BASE_ADDR 0xBE180000
194
195 #define ETHERNET_PACKET_DMA_BUFFER_SIZE         0x600
196
197 #define IFXMIPS_PPE32_MEM_MAP   ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x10000))
198 #define IFXMIPS_PPE32_SRST              ((u32*)(IFXMIPS_PPE32_BASE_ADDR + 0x10080))
199
200 #define MII_MODE 1
201 #define REV_MII_MODE 2
202
203 /* mdio access */
204 #define IFXMIPS_PPE32_MDIO_ACC  ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1804))
205
206 #define MDIO_ACC_REQUEST                0x80000000
207 #define MDIO_ACC_READ                   0x40000000
208 #define MDIO_ACC_ADDR_MASK              0x1f
209 #define MDIO_ACC_ADDR_OFFSET    0x15
210 #define MDIO_ACC_REG_MASK               0xff
211 #define MDIO_ACC_REG_OFFSET             0x10
212 #define MDIO_ACC_VAL_MASK               0xffff
213
214 /* configuration */
215 #define IFXMIPS_PPE32_CFG               ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1808))
216
217 #define PPE32_MII_MASK                  0xfffffffc
218 #define PPE32_MII_NORMAL                0x8
219 #define PPE32_MII_REVERSE               0xe
220
221 /* packet length */
222 #define IFXMIPS_PPE32_IG_PLEN_CTRL      ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1820))
223
224 #define PPE32_PLEN_OVER                 0x5ee
225 #define PPE32_PLEN_UNDER                0x400000
226
227 /* enet */
228 #define IFXMIPS_PPE32_ENET_MAC_CFG      ((u32*)(IFXMIPS_PPE32_MEM_MAP + 0x1840))
229
230 #define PPE32_CGEN                              0x800
231
232
233 /*------------ DMA */
234 #define IFXMIPS_DMA_BASE_ADDR   0xBE104100
235
236 #define IFXMIPS_DMA_CS                  ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x18))
237 #define IFXMIPS_DMA_CIE                 ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x2C))
238 #define IFXMIPS_DMA_IRNEN               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0xf4))
239 #define IFXMIPS_DMA_CCTRL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x1C))
240 #define IFXMIPS_DMA_CIS                 ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x28))
241 #define IFXMIPS_DMA_CDLEN               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x24))
242 #define IFXMIPS_DMA_PS                  ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x40))
243 #define IFXMIPS_DMA_PCTRL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x44))
244 #define IFXMIPS_DMA_CTRL                        ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x10))
245 #define IFXMIPS_DMA_CPOLL               ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x14))
246 #define IFXMIPS_DMA_CDBA                        ((u32*)(IFXMIPS_DMA_BASE_ADDR + 0x20))
247
248
249 /*------------ PCI */
250 #define PCI_CR_PR_BASE_ADDR             (KSEG1 + 0x1E105400)
251
252 #define PCI_CR_FCI_ADDR_MAP0    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C0))
253 #define PCI_CR_FCI_ADDR_MAP1    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C4))
254 #define PCI_CR_FCI_ADDR_MAP2    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C8))
255 #define PCI_CR_FCI_ADDR_MAP3    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00CC))
256 #define PCI_CR_FCI_ADDR_MAP4    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D0))
257 #define PCI_CR_FCI_ADDR_MAP5    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D4))
258 #define PCI_CR_FCI_ADDR_MAP6    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D8))
259 #define PCI_CR_FCI_ADDR_MAP7    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00DC))
260 #define PCI_CR_CLK_CTRL                 ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0000))
261 #define PCI_CR_PCI_MOD                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0030))
262 #define PCI_CR_PC_ARB                   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0080))
263 #define PCI_CR_FCI_ADDR_MAP11hg ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E4))
264 #define PCI_CR_BAR11MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0044))
265 #define PCI_CR_BAR12MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0048))
266 #define PCI_CR_BAR13MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x004C))
267 #define PCI_CS_BASE_ADDR1               ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0010))
268 #define PCI_CR_PCI_ADDR_MAP11   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0064))
269 #define PCI_CR_FCI_BURST_LENGTH ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E8))
270 #define PCI_CR_PCI_EOI                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x002C))
271
272 #define PCI_CS_PR_BASE_ADDR             (KSEG1 + 0x17000000)
273
274 #define PCI_CS_STS_CMD                  ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0004))
275
276 #define PCI_MASTER0_REQ_MASK_2BITS      8
277 #define PCI_MASTER1_REQ_MASK_2BITS      10
278 #define PCI_MASTER2_REQ_MASK_2BITS      12
279 #define INTERNAL_ARB_ENABLE_BIT         0
280
281
282 /*------------ WDT */
283
284 #define IFXMIPS_WDT_BASE_ADDR   (KSEG1 + 0x1F880000)
285
286 #define IFXMIPS_BIU_WDT_CR              ((u32*)(IFXMIPS_WDT_BASE_ADDR + 0x03F0))
287 #define IFXMIPS_BIU_WDT_SR              ((u32*)(IFXMIPS_WDT_BASE_ADDR + 0x03F8))
288
289 #define IFXMIPS_BIU_WDT_CR_GEN                          (1 << 31)
290 #define IFXMIPS_BIU_WDT_CR_DSEN                         (1 << 30)
291 #define IFXMIPS_BIU_WDT_CR_LPEN                         (1 << 29)
292
293 #define IFXMIPS_BIU_WDT_CR_CLKDIV_GET(value) (((value) >> 24) & ((1 << 2) - 1))
294 #define IFXMIPS_BIU_WDT_CR_PWL_GET(value)       (((value) >> 26) & ((1 << 2) - 1))
295 #define IFXMIPS_BIU_WDT_CR_PWL_SET(value)       ((((1 << 2) - 1) & (value)) << 26)
296 #define IFXMIPS_BIU_WDT_CR_PW_SET(value)                (((( 1 << 8) - 1) & (value)) << 16)
297 #define IFXMIPS_BIU_WDT_CR_CLKDIV_SET(value)    (((( 1 << 2) - 1) & (value)) << 24)
298 #define IFXMIPS_BIU_WDT_CR_RELOAD_SET(value)    (((( 1 << 16) - 1) & (value)) << 0)
299
300
301 /*------------ LED */
302
303 #define IFXMIPS_LED_BASE_ADDR   (KSEG1 + 0x1E100BB0)
304 #define IFXMIPS_LED_CON0                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0000))
305 #define IFXMIPS_LED_CON1                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0004))
306 #define IFXMIPS_LED_CPU0                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0008))
307 #define IFXMIPS_LED_CPU1                        ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x000C))
308 #define IFXMIPS_LED_AR                  ((u32*)(IFXMIPS_LED_BASE_ADDR + 0x0010))
309
310 #define LED_CON0_SWU                    (1 << 31)
311 #define LED_CON0_AD1                    (1 << 25)
312 #define LED_CON0_AD0                    (1 << 24)
313
314 #define IFXMIPS_LED_2HZ          (0)
315 #define IFXMIPS_LED_4HZ          (1 << 23)
316 #define IFXMIPS_LED_8HZ          (2 << 23)
317 #define IFXMIPS_LED_10HZ         (3 << 23)
318 #define IFXMIPS_LED_MASK         (0xf << 23)
319
320 #define IFXMIPS_LED_UPD_SRC_FPI  (1 << 31)
321 #define IFXMIPS_LED_UPD_MASK     (3 << 30)
322 #define IFXMIPS_LED_ADSL_SRC            (3 << 24)
323
324 #define IFXMIPS_LED_GROUP0              (1 << 0)
325 #define IFXMIPS_LED_GROUP1              (1 << 1)
326 #define IFXMIPS_LED_GROUP2              (1 << 2)
327
328 #define IFXMIPS_LED_RISING              0
329 #define IFXMIPS_LED_FALLING             (1 << 26)
330 #define IFXMIPS_LED_EDGE_MASK   (1 << 26)
331
332
333 /*------------ GPIO */
334
335 #define IFXMIPS_GPIO_BASE_ADDR  (0xBE100B00)
336
337 #define IFXMIPS_GPIO_P0_OUT             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0010))
338 #define IFXMIPS_GPIO_P1_OUT             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0040))
339 #define IFXMIPS_GPIO_P0_IN              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0014))
340 #define IFXMIPS_GPIO_P1_IN              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0044))
341 #define IFXMIPS_GPIO_P0_DIR             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0018))
342 #define IFXMIPS_GPIO_P1_DIR             ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0048))
343 #define IFXMIPS_GPIO_P0_ALTSEL0 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x001C))
344 #define IFXMIPS_GPIO_P1_ALTSEL0 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x004C))
345 #define IFXMIPS_GPIO_P0_ALTSEL1 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0020))
346 #define IFXMIPS_GPIO_P1_ALTSEL1 ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0050))
347 #define IFXMIPS_GPIO_P0_OD              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0024))
348 #define IFXMIPS_GPIO_P1_OD              ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0054))
349 #define IFXMIPS_GPIO_P0_STOFF   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0028))
350 #define IFXMIPS_GPIO_P1_STOFF   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0058))
351 #define IFXMIPS_GPIO_P0_PUDSEL  ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x002C))
352 #define IFXMIPS_GPIO_P1_PUDSEL  ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x005C))
353 #define IFXMIPS_GPIO_P0_PUDEN   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0030))
354 #define IFXMIPS_GPIO_P1_PUDEN   ((u32*)(IFXMIPS_GPIO_BASE_ADDR + 0x0060))
355
356
357 /*------------ SSC */
358
359 #define IFXMIPS_SSC_BASE_ADDR   (KSEG1 + 0x1e100800)
360
361
362 #define IFXMIPS_SSC_CLC                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0000))
363 #define IFXMIPS_SSC_IRN                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x00F4))
364 #define IFXMIPS_SSC_SFCON               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0060))
365 #define IFXMIPS_SSC_WHBGPOSTAT  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0078))
366 #define IFXMIPS_SSC_STATE       ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0014))
367 #define IFXMIPS_SSC_WHBSTATE    ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0018))
368 #define IFXMIPS_SSC_FSTAT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0038))
369 #define IFXMIPS_SSC_ID                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0008))
370 #define IFXMIPS_SSC_TB                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0020))
371 #define IFXMIPS_SSC_RXFCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0030))
372 #define IFXMIPS_SSC_TXFCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0034))
373 #define IFXMIPS_SSC_CON                 ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0010))
374 #define IFXMIPS_SSC_GPOSTAT             ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0074))
375 #define IFXMIPS_SSC_RB                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0024))
376 #define IFXMIPS_SSC_RXCNT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0084))
377 #define IFXMIPS_SSC_GPOCON              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0070))
378 #define IFXMIPS_SSC_BR                  ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0040))
379 #define IFXMIPS_SSC_RXREQ               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0080))
380 #define IFXMIPS_SSC_SFSTAT              ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0064))
381 #define IFXMIPS_SSC_RXCNT               ((u32*)(IFXMIPS_SSC_BASE_ADDR + 0x0084))
382
383
384 /*------------ MEI */
385
386 #define IFXMIPS_MEI_BASE_ADDR   (0xBE116000)
387
388 #define MEI_DATA_XFR                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0000))
389 #define MEI_VERSION                             ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0004))
390 #define MEI_ARC_GP_STAT                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0008))
391 #define MEI_DATA_XFR_STAT               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x000C))
392 #define MEI_XFR_ADDR                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0010))
393 #define MEI_MAX_WAIT                    ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0014))
394 #define MEI_TO_ARC_INT                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0018))
395 #define ARC_TO_MEI_INT                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x001C))
396 #define ARC_TO_MEI_INT_MASK             ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0020))
397 #define MEI_DEBUG_WAD                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0024))
398 #define MEI_DEBUG_RAD                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0028))
399 #define MEI_DEBUG_DATA                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x002C))
400 #define MEI_DEBUG_DEC                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0030))
401 #define MEI_CONFIG                              ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0034))
402 #define MEI_RST_CONTROL                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0038))
403 #define MEI_DBG_MASTER                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x003C))
404 #define MEI_CLK_CONTROL                 ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0040))
405 #define MEI_BIST_CONTROL                ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0044))
406 #define MEI_BIST_STAT                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0048))
407 #define MEI_XDATA_BASE_SH               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x004c))
408 #define MEI_XDATA_BASE                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0050))
409 #define MEI_XMEM_BAR_BASE               ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0054))
410 #define MEI_XMEM_BAR0                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0054))
411 #define MEI_XMEM_BAR1                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0058))
412 #define MEI_XMEM_BAR2                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x005C))
413 #define MEI_XMEM_BAR3                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0060))
414 #define MEI_XMEM_BAR4                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0064))
415 #define MEI_XMEM_BAR5                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0068))
416 #define MEI_XMEM_BAR6                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x006C))
417 #define MEI_XMEM_BAR7                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0070))
418 #define MEI_XMEM_BAR8                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0074))
419 #define MEI_XMEM_BAR9                   ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0078))
420 #define MEI_XMEM_BAR10                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x007C))
421 #define MEI_XMEM_BAR11                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0080))
422 #define MEI_XMEM_BAR12                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0084))
423 #define MEI_XMEM_BAR13                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0088))
424 #define MEI_XMEM_BAR14                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x008C))
425 #define MEI_XMEM_BAR15                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0090))
426 #define MEI_XMEM_BAR16                  ((u32*)(IFXMIPS_MEI_BASE_ADDR + 0x0094))
427
428
429 /*------------ FUSE */
430
431 #define IFXMIPS_FUSE_BASE_ADDR  (KSEG1 + 0x1F107354)
432
433
434 /*------------ MPS */
435
436 #define IFXMIPS_MPS_BASE_ADDR   (KSEG1 + 0x1F107000)
437
438 #define IFXMIPS_MPS_CHIPID              ((u32*)(IFXMIPS_MPS_BASE_ADDR + 0x0344))
439
440 #endif