more danube led clean up
[openwrt.git] / target / linux / danube / files / include / asm-mips / danube / danube.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 _DANUBE_H__
21 #define _DANUBE_H__
22
23
24 /*------------ GENERAL */
25
26 #define BOARD_SYSTEM_TYPE               "DANUBE"
27
28 #define IOPORT_RESOURCE_START   0x10000000
29 #define IOPORT_RESOURCE_END             0xffffffff
30 #define IOMEM_RESOURCE_START    0x10000000
31 #define IOMEM_RESOURCE_END              0xffffffff
32
33
34 /*------------ ASC1 */
35
36 #define DANUBE_ASC1_BASE_ADDR   (KSEG1 + 0x1E100C00)
37
38 /* FIFO status register */
39 #define DANUBE_ASC1_FSTAT               ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0048))
40 #define ASCFSTAT_TXFFLMASK              0x3F00
41 #define ASCFSTAT_TXFFLOFF               8
42
43 /* ASC1 transmit buffer */
44 #define DANUBE_ASC1_TBUF                ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0020))
45
46 /* channel operating modes */
47 #define ASCOPT_CSIZE                    0x3
48 #define ASCOPT_CS7                              0x1
49 #define ASCOPT_CS8                              0x2
50 #define ASCOPT_PARENB                   0x4
51 #define ASCOPT_STOPB                    0x8
52 #define ASCOPT_PARODD                   0x0
53 #define ASCOPT_CREAD                    0x20
54
55 /* hardware modified control register */
56 #define DANUBE_ASC1_WHBSTATE    ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0018))
57
58 /* receive buffer register */
59 #define DANUBE_ASC1_RBUF                ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0024))
60
61 /* status register */
62 #define DANUBE_ASC1_STATE               ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0014))
63
64 /* interrupt control */
65 #define DANUBE_ASC1_IRNCR               ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x00F8))
66
67 #define ASC_IRNCR_TIR                   0x4
68 #define ASC_IRNCR_RIR                   0x2
69 #define ASC_IRNCR_EIR                   0x4
70
71 /* clock control */
72 #define DANUBE_ASC1_CLC                 ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0000))
73
74 #define DANUBE_ASC1_CLC_DISS    0x2
75
76 /* port input select register */
77 #define DANUBE_ASC1_PISEL               ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0004))
78
79 /* tx fifo */
80 #define DANUBE_ASC1_TXFCON              ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0044))
81
82 /* rx fifo */
83 #define DANUBE_ASC1_RXFCON              ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0040))
84
85 /* control */
86 #define DANUBE_ASC1_CON                 ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0010))
87
88 /* timer reload */
89 #define DANUBE_ASC1_BG                  ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x0050))
90
91 /* int enable */
92 #define DANUBE_ASC1_IRNREN              ((u32*)(DANUBE_ASC1_BASE_ADDR + 0x00F4))
93
94 #define ASC_IRNREN_RX_BUF               0x8
95 #define ASC_IRNREN_TX_BUF               0x4
96 #define ASC_IRNREN_ERR                  0x2
97 #define ASC_IRNREN_TX                   0x1
98
99
100 /*------------ RCU */
101
102 #define DANUBE_RCU_BASE_ADDR    0xBF203000
103
104 /* reset request */
105 #define DANUBE_RCU_REQ                  ((u32*)(DANUBE_RCU_BASE_ADDR + 0x0010))
106 #define DANUBE_RST_ALL                  0x40000000
107
108
109 /*------------ MCD */
110
111 #define DANUBE_MCD_BASE_ADDR    (KSEG1 + 0x1F106000)
112
113 /* chip id */
114 #define DANUBE_MCD_CHIPID               ((u32*)(DANUBE_MCD_BASE_ADDR + 0x0028))
115
116
117 /*------------ GPTU */
118
119 #define DANUBE_GPTU_BASE_ADDR   0xB8000300
120
121 /* clock control register */
122 #define DANUBE_GPTU_GPT_CLC             ((u32*)(DANUBE_GPTU_BASE_ADDR + 0x0000))
123
124 /* captur reload register */
125 #define DANUBE_GPTU_GPT_CAPREL  ((u32*)(DANUBE_GPTU_BASE_ADDR + 0x0030))
126
127 /* timer 6 control register */
128 #define DANUBE_GPTU_GPT_T6CON   ((u32*)(DANUBE_GPTU_BASE_ADDR + 0x0020))
129
130
131 /*------------ EBU */
132
133 #define DANUBE_EBU_BASE_ADDR    0xBE105300
134
135 /* bus configuration register */
136 #define DANUBE_EBU_BUSCON0              ((u32*)(DANUBE_EBU_BASE_ADDR + 0x0060))
137 #define DANUBE_EBU_PCC_CON              ((u32*)(DANUBE_EBU_BASE_ADDR + 0x0090))
138 #define DANUBE_EBU_PCC_IEN              ((u32*)(DANUBE_EBU_BASE_ADDR + 0x00A4))
139 #define DANUBE_EBU_PCC_ISTAT    ((u32*)(DANUBE_EBU_BASE_ADDR + 0x00A0))
140
141
142 /*------------ CGU */
143
144 #define DANUBE_CGU_BASE_ADDR    0xBF103000
145
146 /* clock mux */
147 #define DANUBE_CGU_SYS                  ((u32*)(DANUBE_CGU_BASE_ADDR + 0x0010))
148 #define DANUBE_CGU_IFCCR                ((u32*)(DANUBE_CGU_BASE_ADDR + 0x0018))
149 #define DANUBE_CGU_PCICR                ((u32*)(DANUBE_CGU_BASE_ADDR + 0x0034))
150
151 #define CLOCK_60M                               60000000
152 #define CLOCK_83M                               83333333
153 #define CLOCK_111M                              111111111
154 #define CLOCK_133M                              133333333
155 #define CLOCK_167M                              166666667
156 #define CLOCK_333M                              333333333
157
158
159 /*------------ CGU */
160
161 #define DANUBE_PMU_BASE_ADDR    (KSEG1 + 0x1F102000)
162
163 #define DANUBE_PMU_PWDCR                ((u32*)(DANUBE_PMU_BASE_ADDR + 0x001C))
164 #define DANUBE_PMU_PWDSR                ((u32*)(DANUBE_PMU_BASE_ADDR + 0x0020))
165
166 #define DANUBE_PMU_PWDCR_DMA    0x20
167 #define DANUBE_PMU_PWDCR_LED    0x800
168 #define DANUBE_PMU_PWDCR_GPT    0x1000
169 #define DANUBE_PMU_PWDCR_PPE    0x2000
170 #define DANUBE_PMU_PWDCR_FPI    0x4000
171
172
173 /*------------ ICU */
174
175 #define DANUBE_ICU_BASE_ADDR    0xBF880200
176
177
178 #define DANUBE_ICU_IM0_ISR              ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0000))
179 #define DANUBE_ICU_IM0_IER              ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0008))
180 #define DANUBE_ICU_IM0_IOSR             ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0010))
181 #define DANUBE_ICU_IM0_IRSR             ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0018))
182 #define DANUBE_ICU_IM0_IMR              ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0020))
183
184 #define DANUBE_ICU_IM1_ISR              ((u32*)(DANUBE_ICU_BASE_ADDR + 0x0028))
185
186 #define DANUBE_ICU_OFFSET               (DANUBE_ICU_IM1_ISR - DANUBE_ICU_IM0_ISR)
187
188
189 /*------------ ETOP */
190
191 #define DANUBE_PPE32_BASE_ADDR  0xBE180000
192
193 #define ETHERNET_PACKET_DMA_BUFFER_SIZE         0x600
194
195 #define DANUBE_PPE32_MEM_MAP    (DANUBE_PPE32_BASE_ADDR + 0x10000 )
196
197 #define MII_MODE 1
198
199 #define REV_MII_MODE 2
200
201 /* mdio access */
202 #define DANUBE_PPE32_MDIO_ACC   ((u32*)(DANUBE_PPE32_MEM_MAP + 0x1804))
203
204 #define MDIO_ACC_REQUEST                0x80000000
205 #define MDIO_ACC_READ                   0x40000000
206 #define MDIO_ACC_ADDR_MASK              0x1f
207 #define MDIO_ACC_ADDR_OFFSET    0x15
208 #define MDIO_ACC_REG_MASK               0xff
209 #define MDIO_ACC_REG_OFFSET             0x10
210 #define MDIO_ACC_VAL_MASK               0xffff
211
212 /* configuration */
213 #define DANUBE_PPE32_CFG                ((u32*)(DANUBE_PPE32_MEM_MAP + 0x1808))
214
215 #define PPE32_MII_MASK                  0xfffffffc
216 #define PPE32_MII_NORMAL                0x8
217 #define PPE32_MII_REVERSE               0xe
218
219 /* packet length */
220 #define DANUBE_PPE32_IG_PLEN_CTRL       ((u32*)(DANUBE_PPE32_MEM_MAP + 0x1820))
221
222 #define PPE32_PLEN_OVER                 0x5ee
223 #define PPE32_PLEN_UNDER                0x400000
224
225 /* enet */
226 #define DANUBE_PPE32_ENET_MAC_CFG       ((u32*)(DANUBE_PPE32_MEM_MAP + 0x1840))
227
228 #define PPE32_CGEN                              0x800
229
230
231 /*------------ DMA */
232 #define DANUBE_DMA_BASE_ADDR    0xBE104100
233
234 #define DANUBE_DMA_CS                   ((u32*)(DANUBE_DMA_BASE_ADDR + 0x18))
235 #define DANUBE_DMA_CIE                  ((u32*)(DANUBE_DMA_BASE_ADDR + 0x2C))
236 #define DANUBE_DMA_IRNEN                ((u32*)(DANUBE_DMA_BASE_ADDR + 0xf4))
237 #define DANUBE_DMA_CCTRL                ((u32*)(DANUBE_DMA_BASE_ADDR + 0x1C))
238 #define DANUBE_DMA_CIS                  ((u32*)(DANUBE_DMA_BASE_ADDR + 0x28))
239 #define DANUBE_DMA_CDLEN                ((u32*)(DANUBE_DMA_BASE_ADDR + 0x24))
240 #define DANUBE_DMA_PS                   ((u32*)(DANUBE_DMA_BASE_ADDR + 0x40))
241 #define DANUBE_DMA_PCTRL                ((u32*)(DANUBE_DMA_BASE_ADDR + 0x44))
242 #define DANUBE_DMA_CTRL                 ((u32*)(DANUBE_DMA_BASE_ADDR + 0x10))
243 #define DANUBE_DMA_CPOLL                ((u32*)(DANUBE_DMA_BASE_ADDR + 0x14))
244 #define DANUBE_DMA_CDBA                 ((u32*)(DANUBE_DMA_BASE_ADDR + 0x20))
245
246
247 /*------------ PCI */
248 #define PCI_CR_PR_BASE_ADDR             (KSEG1 + 0x1E105400)
249
250 #define PCI_CR_FCI_ADDR_MAP0    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C0))
251 #define PCI_CR_FCI_ADDR_MAP1    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C4))
252 #define PCI_CR_FCI_ADDR_MAP2    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00C8))
253 #define PCI_CR_FCI_ADDR_MAP3    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00CC))
254 #define PCI_CR_FCI_ADDR_MAP4    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D0))
255 #define PCI_CR_FCI_ADDR_MAP5    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D4))
256 #define PCI_CR_FCI_ADDR_MAP6    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00D8))
257 #define PCI_CR_FCI_ADDR_MAP7    ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00DC))
258 #define PCI_CR_CLK_CTRL                 ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0000))
259 #define PCI_CR_PCI_MOD                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0030))
260 #define PCI_CR_PC_ARB                   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0080))
261 #define PCI_CR_FCI_ADDR_MAP11hg ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E4))
262 #define PCI_CR_BAR11MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0044))
263 #define PCI_CR_BAR12MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0048))
264 #define PCI_CR_BAR13MASK                ((u32*)(PCI_CR_PR_BASE_ADDR + 0x004C))
265 #define PCI_CS_BASE_ADDR1               ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0010))
266 #define PCI_CR_PCI_ADDR_MAP11   ((u32*)(PCI_CR_PR_BASE_ADDR + 0x0064))
267 #define PCI_CR_FCI_BURST_LENGTH ((u32*)(PCI_CR_PR_BASE_ADDR + 0x00E8))
268 #define PCI_CR_PCI_EOI                  ((u32*)(PCI_CR_PR_BASE_ADDR + 0x002C))
269
270 #define PCI_CS_PR_BASE_ADDR             (KSEG1 + 0x17000000)
271
272 #define PCI_CS_STS_CMD                  ((u32*)(PCI_CS_PR_BASE_ADDR + 0x0004))
273
274 #define PCI_MASTER0_REQ_MASK_2BITS      8
275 #define PCI_MASTER1_REQ_MASK_2BITS      10
276 #define PCI_MASTER2_REQ_MASK_2BITS      12
277 #define INTERNAL_ARB_ENABLE_BIT         0
278
279
280 /*------------ WDT */
281
282 #define DANUBE_WDT_BASE_ADDR    (KSEG1 + 0x1F880000)
283
284 #define DANUBE_BIU_WDT_CR               ((u32*)(DANUBE_WDT_BASE_ADDR + 0x03F0))
285 #define DANUBE_BIU_WDT_SR               ((u32*)(DANUBE_WDT_BASE_ADDR + 0x03F8))
286
287 #define DANUBE_BIU_WDT_CR_GEN                           (1 << 31)
288 #define DANUBE_BIU_WDT_CR_DSEN                          (1 << 30)
289 #define DANUBE_BIU_WDT_CR_LPEN                          (1 << 29)
290
291 #define DANUBE_BIU_WDT_CR_CLKDIV_GET(value) (((value) >> 24) & ((1 << 2) - 1))
292 #define DANUBE_BIU_WDT_CR_PWL_GET(value)        (((value) >> 26) & ((1 << 2) - 1))
293 #define DANUBE_BIU_WDT_CR_PWL_SET(value)        ((((1 << 2) - 1) & (value)) << 26)
294 #define DANUBE_BIU_WDT_CR_PW_SET(value)         (((( 1 << 8) - 1) & (value)) << 16)
295 #define DANUBE_BIU_WDT_CR_CLKDIV_SET(value)     (((( 1 << 2) - 1) & (value)) << 24)
296 #define DANUBE_BIU_WDT_CR_RELOAD_SET(value)     (((( 1 << 16) - 1) & (value)) << 0)
297
298
299 /*------------ LED */
300
301 #define DANUBE_LED_BASE_ADDR    (KSEG1 + 0x1E100BB0)
302 #define DANUBE_LED_CON0                 ((u32*)(DANUBE_LED_BASE_ADDR + 0x0000))
303 #define DANUBE_LED_CON1                 ((u32*)(DANUBE_LED_BASE_ADDR + 0x0004))
304 #define DANUBE_LED_CPU0                 ((u32*)(DANUBE_LED_BASE_ADDR + 0x0008))
305 #define DANUBE_LED_CPU1                 ((u32*)(DANUBE_LED_BASE_ADDR + 0x000C))
306 #define DANUBE_LED_AR                   ((u32*)(DANUBE_LED_BASE_ADDR + 0x0010))
307
308 #define LED_CON0_SWU                    (1 << 31)
309 #define LED_CON0_AD1                    (1 << 25)
310 #define LED_CON0_AD0                    (1 << 24)
311
312
313 /*------------ GPIO */
314
315 #define DANUBE_GPIO_BASE_ADDR   (0xBE100B00)
316
317 #define DANUBE_GPIO_P0_OUT              ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0010))
318 #define DANUBE_GPIO_P1_OUT              ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0040))
319 #define DANUBE_GPIO_P0_IN               ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0014))
320 #define DANUBE_GPIO_P1_IN               ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0044))
321 #define DANUBE_GPIO_P0_DIR              ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0018))
322 #define DANUBE_GPIO_P1_DIR              ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0048))
323 #define DANUBE_GPIO_P0_ALTSEL0  ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x001C))
324 #define DANUBE_GPIO_P1_ALTSEL0  ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x004C))
325 #define DANUBE_GPIO_P0_ALTSEL1  ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0020))
326 #define DANUBE_GPIO_P1_ALTSEL1  ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0050))
327 #define DANUBE_GPIO_P0_OD               ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0024))
328 #define DANUBE_GPIO_P1_OD               ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0054))
329 #define DANUBE_GPIO_P0_STOFF    ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0028))
330 #define DANUBE_GPIO_P1_STOFF    ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0058))
331 #define DANUBE_GPIO_P0_PUDSEL   ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x002C))
332 #define DANUBE_GPIO_P1_PUDSEL   ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x005C))
333 #define DANUBE_GPIO_P0_PUDEN    ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0030))
334 #define DANUBE_GPIO_P1_PUDEN    ((u32*)(DANUBE_GPIO_BASE_ADDR + 0x0060))
335
336 #endif