diff options
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/mach-davinci/Kconfig | 14 | ||||
-rw-r--r-- | arch/arm/mach-davinci/Makefile | 11 | ||||
-rw-r--r-- | arch/arm/mach-davinci/Makefile.boot | 10 | ||||
-rw-r--r-- | arch/arm/mach-davinci/da830.c | 1247 | ||||
-rw-r--r-- | arch/arm/mach-davinci/devices-da8xx.c | 287 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/cputype.h | 8 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/da8xx.h | 69 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/edma.h | 48 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/irqs.h | 109 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/memory.h | 9 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/mux.h | 404 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/psc.h | 41 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/serial.h | 4 |
13 files changed, 2252 insertions, 9 deletions
diff --git a/arch/arm/mach-davinci/Kconfig b/arch/arm/mach-davinci/Kconfig index b16f5e31c08a..312228ed8489 100644 --- a/arch/arm/mach-davinci/Kconfig +++ b/arch/arm/mach-davinci/Kconfig | |||
@@ -6,6 +6,9 @@ config AINTC | |||
6 | config CP_INTC | 6 | config CP_INTC |
7 | bool | 7 | bool |
8 | 8 | ||
9 | config ARCH_DAVINCI_DMx | ||
10 | bool | ||
11 | |||
9 | menu "TI DaVinci Implementations" | 12 | menu "TI DaVinci Implementations" |
10 | 13 | ||
11 | comment "DaVinci Core Type" | 14 | comment "DaVinci Core Type" |
@@ -13,14 +16,25 @@ comment "DaVinci Core Type" | |||
13 | config ARCH_DAVINCI_DM644x | 16 | config ARCH_DAVINCI_DM644x |
14 | bool "DaVinci 644x based system" | 17 | bool "DaVinci 644x based system" |
15 | select AINTC | 18 | select AINTC |
19 | select ARCH_DAVINCI_DMx | ||
16 | 20 | ||
17 | config ARCH_DAVINCI_DM355 | 21 | config ARCH_DAVINCI_DM355 |
18 | bool "DaVinci 355 based system" | 22 | bool "DaVinci 355 based system" |
19 | select AINTC | 23 | select AINTC |
24 | select ARCH_DAVINCI_DMx | ||
20 | 25 | ||
21 | config ARCH_DAVINCI_DM646x | 26 | config ARCH_DAVINCI_DM646x |
22 | bool "DaVinci 646x based system" | 27 | bool "DaVinci 646x based system" |
23 | select AINTC | 28 | select AINTC |
29 | select ARCH_DAVINCI_DMx | ||
30 | |||
31 | config ARCH_DAVINCI_DA830 | ||
32 | bool "DA830/OMAP-L137 based system" | ||
33 | select CP_INTC | ||
34 | select ARCH_DAVINCI_DA8XX | ||
35 | |||
36 | config ARCH_DAVINCI_DA8XX | ||
37 | bool | ||
24 | 38 | ||
25 | config ARCH_DAVINCI_DM365 | 39 | config ARCH_DAVINCI_DM365 |
26 | bool "DaVinci 365 based system" | 40 | bool "DaVinci 365 based system" |
diff --git a/arch/arm/mach-davinci/Makefile b/arch/arm/mach-davinci/Makefile index bea7ba65b3f4..385638c0a711 100644 --- a/arch/arm/mach-davinci/Makefile +++ b/arch/arm/mach-davinci/Makefile | |||
@@ -5,15 +5,16 @@ | |||
5 | 5 | ||
6 | # Common objects | 6 | # Common objects |
7 | obj-y := time.o clock.o serial.o io.o psc.o \ | 7 | obj-y := time.o clock.o serial.o io.o psc.o \ |
8 | gpio.o devices.o dma.o usb.o common.o sram.o | 8 | gpio.o dma.o usb.o common.o sram.o |
9 | 9 | ||
10 | obj-$(CONFIG_DAVINCI_MUX) += mux.o | 10 | obj-$(CONFIG_DAVINCI_MUX) += mux.o |
11 | 11 | ||
12 | # Chip specific | 12 | # Chip specific |
13 | obj-$(CONFIG_ARCH_DAVINCI_DM644x) += dm644x.o | 13 | obj-$(CONFIG_ARCH_DAVINCI_DM644x) += dm644x.o devices.o |
14 | obj-$(CONFIG_ARCH_DAVINCI_DM355) += dm355.o | 14 | obj-$(CONFIG_ARCH_DAVINCI_DM355) += dm355.o devices.o |
15 | obj-$(CONFIG_ARCH_DAVINCI_DM646x) += dm646x.o | 15 | obj-$(CONFIG_ARCH_DAVINCI_DM646x) += dm646x.o devices.o |
16 | obj-$(CONFIG_ARCH_DAVINCI_DM365) += dm365.o | 16 | obj-$(CONFIG_ARCH_DAVINCI_DM365) += dm365.o devices.o |
17 | obj-$(CONFIG_ARCH_DAVINCI_DA830) += da830.o devices-da8xx.o | ||
17 | 18 | ||
18 | obj-$(CONFIG_AINTC) += irq.o | 19 | obj-$(CONFIG_AINTC) += irq.o |
19 | obj-$(CONFIG_CP_INTC) += cp_intc.o | 20 | obj-$(CONFIG_CP_INTC) += cp_intc.o |
diff --git a/arch/arm/mach-davinci/Makefile.boot b/arch/arm/mach-davinci/Makefile.boot index e1dd366f836b..db97ef2c6477 100644 --- a/arch/arm/mach-davinci/Makefile.boot +++ b/arch/arm/mach-davinci/Makefile.boot | |||
@@ -1,3 +1,13 @@ | |||
1 | ifeq ($(CONFIG_ARCH_DAVINCI_DA8XX),y) | ||
2 | ifeq ($(CONFIG_ARCH_DAVINCI_DMx),y) | ||
3 | $(error Cannot enable DaVinci and DA8XX platforms concurrently) | ||
4 | else | ||
5 | zreladdr-y := 0xc0008000 | ||
6 | params_phys-y := 0xc0000100 | ||
7 | initrd_phys-y := 0xc0800000 | ||
8 | endif | ||
9 | else | ||
1 | zreladdr-y := 0x80008000 | 10 | zreladdr-y := 0x80008000 |
2 | params_phys-y := 0x80000100 | 11 | params_phys-y := 0x80000100 |
3 | initrd_phys-y := 0x80800000 | 12 | initrd_phys-y := 0x80800000 |
13 | endif | ||
diff --git a/arch/arm/mach-davinci/da830.c b/arch/arm/mach-davinci/da830.c new file mode 100644 index 000000000000..ab4242869b66 --- /dev/null +++ b/arch/arm/mach-davinci/da830.c | |||
@@ -0,0 +1,1247 @@ | |||
1 | /* | ||
2 | * TI DA830/OMAP L137 chip specific setup | ||
3 | * | ||
4 | * Author: Mark A. Greer <mgreer@mvista.com> | ||
5 | * | ||
6 | * 2009 (c) MontaVista Software, Inc. This file is licensed under | ||
7 | * the terms of the GNU General Public License version 2. This program | ||
8 | * is licensed "as is" without any warranty of any kind, whether express | ||
9 | * or implied. | ||
10 | */ | ||
11 | #include <linux/kernel.h> | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/clk.h> | ||
14 | #include <linux/platform_device.h> | ||
15 | |||
16 | #include <asm/mach/map.h> | ||
17 | |||
18 | #include <mach/clock.h> | ||
19 | #include <mach/psc.h> | ||
20 | #include <mach/mux.h> | ||
21 | #include <mach/irqs.h> | ||
22 | #include <mach/cputype.h> | ||
23 | #include <mach/common.h> | ||
24 | #include <mach/time.h> | ||
25 | #include <mach/da8xx.h> | ||
26 | |||
27 | #include "clock.h" | ||
28 | #include "mux.h" | ||
29 | |||
30 | #define DA830_PSC0_BASE 0x01c10000 | ||
31 | #define DA830_PLL0_BASE 0x01c11000 | ||
32 | #define DA830_JTAG_ID_REG 0x01c14018 | ||
33 | #define DA830_TIMER64P0_BASE 0x01c20000 | ||
34 | #define DA830_TIMER64P1_BASE 0x01c21000 | ||
35 | #define DA830_GPIO_BASE 0x01e26000 | ||
36 | #define DA830_PSC1_BASE 0x01e27000 | ||
37 | |||
38 | /* Offsets of the 8 compare registers on the da830 */ | ||
39 | #define DA830_CMP12_0 0x60 | ||
40 | #define DA830_CMP12_1 0x64 | ||
41 | #define DA830_CMP12_2 0x68 | ||
42 | #define DA830_CMP12_3 0x6c | ||
43 | #define DA830_CMP12_4 0x70 | ||
44 | #define DA830_CMP12_5 0x74 | ||
45 | #define DA830_CMP12_6 0x78 | ||
46 | #define DA830_CMP12_7 0x7c | ||
47 | |||
48 | #define DA830_REF_FREQ 24000000 | ||
49 | |||
50 | static struct pll_data pll0_data = { | ||
51 | .num = 1, | ||
52 | .phys_base = DA830_PLL0_BASE, | ||
53 | .flags = PLL_HAS_PREDIV | PLL_HAS_POSTDIV, | ||
54 | }; | ||
55 | |||
56 | static struct clk ref_clk = { | ||
57 | .name = "ref_clk", | ||
58 | .rate = DA830_REF_FREQ, | ||
59 | }; | ||
60 | |||
61 | static struct clk pll0_clk = { | ||
62 | .name = "pll0", | ||
63 | .parent = &ref_clk, | ||
64 | .pll_data = &pll0_data, | ||
65 | .flags = CLK_PLL, | ||
66 | }; | ||
67 | |||
68 | static struct clk pll0_aux_clk = { | ||
69 | .name = "pll0_aux_clk", | ||
70 | .parent = &pll0_clk, | ||
71 | .flags = CLK_PLL | PRE_PLL, | ||
72 | }; | ||
73 | |||
74 | static struct clk pll0_sysclk2 = { | ||
75 | .name = "pll0_sysclk2", | ||
76 | .parent = &pll0_clk, | ||
77 | .flags = CLK_PLL, | ||
78 | .div_reg = PLLDIV2, | ||
79 | }; | ||
80 | |||
81 | static struct clk pll0_sysclk3 = { | ||
82 | .name = "pll0_sysclk3", | ||
83 | .parent = &pll0_clk, | ||
84 | .flags = CLK_PLL, | ||
85 | .div_reg = PLLDIV3, | ||
86 | }; | ||
87 | |||
88 | static struct clk pll0_sysclk4 = { | ||
89 | .name = "pll0_sysclk4", | ||
90 | .parent = &pll0_clk, | ||
91 | .flags = CLK_PLL, | ||
92 | .div_reg = PLLDIV4, | ||
93 | }; | ||
94 | |||
95 | static struct clk pll0_sysclk5 = { | ||
96 | .name = "pll0_sysclk5", | ||
97 | .parent = &pll0_clk, | ||
98 | .flags = CLK_PLL, | ||
99 | .div_reg = PLLDIV5, | ||
100 | }; | ||
101 | |||
102 | static struct clk pll0_sysclk6 = { | ||
103 | .name = "pll0_sysclk6", | ||
104 | .parent = &pll0_clk, | ||
105 | .flags = CLK_PLL, | ||
106 | .div_reg = PLLDIV6, | ||
107 | }; | ||
108 | |||
109 | static struct clk pll0_sysclk7 = { | ||
110 | .name = "pll0_sysclk7", | ||
111 | .parent = &pll0_clk, | ||
112 | .flags = CLK_PLL, | ||
113 | .div_reg = PLLDIV7, | ||
114 | }; | ||
115 | |||
116 | static struct clk i2c0_clk = { | ||
117 | .name = "i2c0", | ||
118 | .parent = &pll0_aux_clk, | ||
119 | }; | ||
120 | |||
121 | static struct clk timerp64_0_clk = { | ||
122 | .name = "timer0", | ||
123 | .parent = &pll0_aux_clk, | ||
124 | }; | ||
125 | |||
126 | static struct clk timerp64_1_clk = { | ||
127 | .name = "timer1", | ||
128 | .parent = &pll0_aux_clk, | ||
129 | }; | ||
130 | |||
131 | static struct clk arm_rom_clk = { | ||
132 | .name = "arm_rom", | ||
133 | .parent = &pll0_sysclk2, | ||
134 | .lpsc = DA8XX_LPSC0_ARM_RAM_ROM, | ||
135 | .flags = ALWAYS_ENABLED, | ||
136 | }; | ||
137 | |||
138 | static struct clk scr0_ss_clk = { | ||
139 | .name = "scr0_ss", | ||
140 | .parent = &pll0_sysclk2, | ||
141 | .lpsc = DA8XX_LPSC0_SCR0_SS, | ||
142 | .flags = ALWAYS_ENABLED, | ||
143 | }; | ||
144 | |||
145 | static struct clk scr1_ss_clk = { | ||
146 | .name = "scr1_ss", | ||
147 | .parent = &pll0_sysclk2, | ||
148 | .lpsc = DA8XX_LPSC0_SCR1_SS, | ||
149 | .flags = ALWAYS_ENABLED, | ||
150 | }; | ||
151 | |||
152 | static struct clk scr2_ss_clk = { | ||
153 | .name = "scr2_ss", | ||
154 | .parent = &pll0_sysclk2, | ||
155 | .lpsc = DA8XX_LPSC0_SCR2_SS, | ||
156 | .flags = ALWAYS_ENABLED, | ||
157 | }; | ||
158 | |||
159 | static struct clk dmax_clk = { | ||
160 | .name = "dmax", | ||
161 | .parent = &pll0_sysclk2, | ||
162 | .lpsc = DA8XX_LPSC0_DMAX, | ||
163 | .flags = ALWAYS_ENABLED, | ||
164 | }; | ||
165 | |||
166 | static struct clk tpcc_clk = { | ||
167 | .name = "tpcc", | ||
168 | .parent = &pll0_sysclk2, | ||
169 | .lpsc = DA8XX_LPSC0_TPCC, | ||
170 | .flags = ALWAYS_ENABLED | CLK_PSC, | ||
171 | }; | ||
172 | |||
173 | static struct clk tptc0_clk = { | ||
174 | .name = "tptc0", | ||
175 | .parent = &pll0_sysclk2, | ||
176 | .lpsc = DA8XX_LPSC0_TPTC0, | ||
177 | .flags = ALWAYS_ENABLED, | ||
178 | }; | ||
179 | |||
180 | static struct clk tptc1_clk = { | ||
181 | .name = "tptc1", | ||
182 | .parent = &pll0_sysclk2, | ||
183 | .lpsc = DA8XX_LPSC0_TPTC1, | ||
184 | .flags = ALWAYS_ENABLED, | ||
185 | }; | ||
186 | |||
187 | static struct clk mmcsd_clk = { | ||
188 | .name = "mmcsd", | ||
189 | .parent = &pll0_sysclk2, | ||
190 | .lpsc = DA8XX_LPSC0_MMC_SD, | ||
191 | }; | ||
192 | |||
193 | static struct clk uart0_clk = { | ||
194 | .name = "uart0", | ||
195 | .parent = &pll0_sysclk2, | ||
196 | .lpsc = DA8XX_LPSC0_UART0, | ||
197 | }; | ||
198 | |||
199 | static struct clk uart1_clk = { | ||
200 | .name = "uart1", | ||
201 | .parent = &pll0_sysclk2, | ||
202 | .lpsc = DA8XX_LPSC1_UART1, | ||
203 | .psc_ctlr = 1, | ||
204 | }; | ||
205 | |||
206 | static struct clk uart2_clk = { | ||
207 | .name = "uart2", | ||
208 | .parent = &pll0_sysclk2, | ||
209 | .lpsc = DA8XX_LPSC1_UART2, | ||
210 | .psc_ctlr = 1, | ||
211 | }; | ||
212 | |||
213 | static struct clk spi0_clk = { | ||
214 | .name = "spi0", | ||
215 | .parent = &pll0_sysclk2, | ||
216 | .lpsc = DA8XX_LPSC0_SPI0, | ||
217 | }; | ||
218 | |||
219 | static struct clk spi1_clk = { | ||
220 | .name = "spi1", | ||
221 | .parent = &pll0_sysclk2, | ||
222 | .lpsc = DA8XX_LPSC1_SPI1, | ||
223 | .psc_ctlr = 1, | ||
224 | }; | ||
225 | |||
226 | static struct clk ecap0_clk = { | ||
227 | .name = "ecap0", | ||
228 | .parent = &pll0_sysclk2, | ||
229 | .lpsc = DA8XX_LPSC1_ECAP, | ||
230 | .psc_ctlr = 1, | ||
231 | }; | ||
232 | |||
233 | static struct clk ecap1_clk = { | ||
234 | .name = "ecap1", | ||
235 | .parent = &pll0_sysclk2, | ||
236 | .lpsc = DA8XX_LPSC1_ECAP, | ||
237 | .psc_ctlr = 1, | ||
238 | }; | ||
239 | |||
240 | static struct clk ecap2_clk = { | ||
241 | .name = "ecap2", | ||
242 | .parent = &pll0_sysclk2, | ||
243 | .lpsc = DA8XX_LPSC1_ECAP, | ||
244 | .psc_ctlr = 1, | ||
245 | }; | ||
246 | |||
247 | static struct clk pwm0_clk = { | ||
248 | .name = "pwm0", | ||
249 | .parent = &pll0_sysclk2, | ||
250 | .lpsc = DA8XX_LPSC1_PWM, | ||
251 | .psc_ctlr = 1, | ||
252 | }; | ||
253 | |||
254 | static struct clk pwm1_clk = { | ||
255 | .name = "pwm1", | ||
256 | .parent = &pll0_sysclk2, | ||
257 | .lpsc = DA8XX_LPSC1_PWM, | ||
258 | .psc_ctlr = 1, | ||
259 | }; | ||
260 | |||
261 | static struct clk pwm2_clk = { | ||
262 | .name = "pwm2", | ||
263 | .parent = &pll0_sysclk2, | ||
264 | .lpsc = DA8XX_LPSC1_PWM, | ||
265 | .psc_ctlr = 1, | ||
266 | }; | ||
267 | |||
268 | static struct clk eqep0_clk = { | ||
269 | .name = "eqep0", | ||
270 | .parent = &pll0_sysclk2, | ||
271 | .lpsc = DA830_LPSC1_EQEP, | ||
272 | .psc_ctlr = 1, | ||
273 | }; | ||
274 | |||
275 | static struct clk eqep1_clk = { | ||
276 | .name = "eqep1", | ||
277 | .parent = &pll0_sysclk2, | ||
278 | .lpsc = DA830_LPSC1_EQEP, | ||
279 | .psc_ctlr = 1, | ||
280 | }; | ||
281 | |||
282 | static struct clk lcdc_clk = { | ||
283 | .name = "lcdc", | ||
284 | .parent = &pll0_sysclk2, | ||
285 | .lpsc = DA8XX_LPSC1_LCDC, | ||
286 | .psc_ctlr = 1, | ||
287 | }; | ||
288 | |||
289 | static struct clk mcasp0_clk = { | ||
290 | .name = "mcasp0", | ||
291 | .parent = &pll0_sysclk2, | ||
292 | .lpsc = DA8XX_LPSC1_McASP0, | ||
293 | .psc_ctlr = 1, | ||
294 | }; | ||
295 | |||
296 | static struct clk mcasp1_clk = { | ||
297 | .name = "mcasp1", | ||
298 | .parent = &pll0_sysclk2, | ||
299 | .lpsc = DA830_LPSC1_McASP1, | ||
300 | .psc_ctlr = 1, | ||
301 | }; | ||
302 | |||
303 | static struct clk mcasp2_clk = { | ||
304 | .name = "mcasp2", | ||
305 | .parent = &pll0_sysclk2, | ||
306 | .lpsc = DA830_LPSC1_McASP2, | ||
307 | .psc_ctlr = 1, | ||
308 | }; | ||
309 | |||
310 | static struct clk usb20_clk = { | ||
311 | .name = "usb20", | ||
312 | .parent = &pll0_sysclk2, | ||
313 | .lpsc = DA8XX_LPSC1_USB20, | ||
314 | .psc_ctlr = 1, | ||
315 | }; | ||
316 | |||
317 | static struct clk aemif_clk = { | ||
318 | .name = "aemif", | ||
319 | .parent = &pll0_sysclk3, | ||
320 | .lpsc = DA8XX_LPSC0_EMIF25, | ||
321 | .flags = ALWAYS_ENABLED, | ||
322 | }; | ||
323 | |||
324 | static struct clk aintc_clk = { | ||
325 | .name = "aintc", | ||
326 | .parent = &pll0_sysclk4, | ||
327 | .lpsc = DA8XX_LPSC0_AINTC, | ||
328 | .flags = ALWAYS_ENABLED, | ||
329 | }; | ||
330 | |||
331 | static struct clk secu_mgr_clk = { | ||
332 | .name = "secu_mgr", | ||
333 | .parent = &pll0_sysclk4, | ||
334 | .lpsc = DA8XX_LPSC0_SECU_MGR, | ||
335 | .flags = ALWAYS_ENABLED, | ||
336 | }; | ||
337 | |||
338 | static struct clk emac_clk = { | ||
339 | .name = "emac", | ||
340 | .parent = &pll0_sysclk4, | ||
341 | .lpsc = DA8XX_LPSC1_CPGMAC, | ||
342 | .psc_ctlr = 1, | ||
343 | }; | ||
344 | |||
345 | static struct clk gpio_clk = { | ||
346 | .name = "gpio", | ||
347 | .parent = &pll0_sysclk4, | ||
348 | .lpsc = DA8XX_LPSC1_GPIO, | ||
349 | .psc_ctlr = 1, | ||
350 | }; | ||
351 | |||
352 | static struct clk i2c1_clk = { | ||
353 | .name = "i2c1", | ||
354 | .parent = &pll0_sysclk4, | ||
355 | .lpsc = DA8XX_LPSC1_I2C, | ||
356 | .psc_ctlr = 1, | ||
357 | }; | ||
358 | |||
359 | static struct clk usb11_clk = { | ||
360 | .name = "usb11", | ||
361 | .parent = &pll0_sysclk4, | ||
362 | .lpsc = DA8XX_LPSC1_USB11, | ||
363 | .psc_ctlr = 1, | ||
364 | }; | ||
365 | |||
366 | static struct clk emif3_clk = { | ||
367 | .name = "emif3", | ||
368 | .parent = &pll0_sysclk5, | ||
369 | .lpsc = DA8XX_LPSC1_EMIF3C, | ||
370 | .flags = ALWAYS_ENABLED, | ||
371 | .psc_ctlr = 1, | ||
372 | }; | ||
373 | |||
374 | static struct clk arm_clk = { | ||
375 | .name = "arm", | ||
376 | .parent = &pll0_sysclk6, | ||
377 | .lpsc = DA8XX_LPSC0_ARM, | ||
378 | .flags = ALWAYS_ENABLED, | ||
379 | }; | ||
380 | |||
381 | static struct clk rmii_clk = { | ||
382 | .name = "rmii", | ||
383 | .parent = &pll0_sysclk7, | ||
384 | }; | ||
385 | |||
386 | static struct davinci_clk da830_clks[] = { | ||
387 | CLK(NULL, "ref", &ref_clk), | ||
388 | CLK(NULL, "pll0", &pll0_clk), | ||
389 | CLK(NULL, "pll0_aux", &pll0_aux_clk), | ||
390 | CLK(NULL, "pll0_sysclk2", &pll0_sysclk2), | ||
391 | CLK(NULL, "pll0_sysclk3", &pll0_sysclk3), | ||
392 | CLK(NULL, "pll0_sysclk4", &pll0_sysclk4), | ||
393 | CLK(NULL, "pll0_sysclk5", &pll0_sysclk5), | ||
394 | CLK(NULL, "pll0_sysclk6", &pll0_sysclk6), | ||
395 | CLK(NULL, "pll0_sysclk7", &pll0_sysclk7), | ||
396 | CLK("i2c_davinci.1", NULL, &i2c0_clk), | ||
397 | CLK(NULL, "timer0", &timerp64_0_clk), | ||
398 | CLK("watchdog", NULL, &timerp64_1_clk), | ||
399 | CLK(NULL, "arm_rom", &arm_rom_clk), | ||
400 | CLK(NULL, "scr0_ss", &scr0_ss_clk), | ||
401 | CLK(NULL, "scr1_ss", &scr1_ss_clk), | ||
402 | CLK(NULL, "scr2_ss", &scr2_ss_clk), | ||
403 | CLK(NULL, "dmax", &dmax_clk), | ||
404 | CLK(NULL, "tpcc", &tpcc_clk), | ||
405 | CLK(NULL, "tptc0", &tptc0_clk), | ||
406 | CLK(NULL, "tptc1", &tptc1_clk), | ||
407 | CLK("davinci_mmc.0", NULL, &mmcsd_clk), | ||
408 | CLK(NULL, "uart0", &uart0_clk), | ||
409 | CLK(NULL, "uart1", &uart1_clk), | ||
410 | CLK(NULL, "uart2", &uart2_clk), | ||
411 | CLK("dm_spi.0", NULL, &spi0_clk), | ||
412 | CLK("dm_spi.1", NULL, &spi1_clk), | ||
413 | CLK(NULL, "ecap0", &ecap0_clk), | ||
414 | CLK(NULL, "ecap1", &ecap1_clk), | ||
415 | CLK(NULL, "ecap2", &ecap2_clk), | ||
416 | CLK(NULL, "pwm0", &pwm0_clk), | ||
417 | CLK(NULL, "pwm1", &pwm1_clk), | ||
418 | CLK(NULL, "pwm2", &pwm2_clk), | ||
419 | CLK("eqep.0", NULL, &eqep0_clk), | ||
420 | CLK("eqep.1", NULL, &eqep1_clk), | ||
421 | CLK("da830_lcdc", NULL, &lcdc_clk), | ||
422 | CLK("soc-audio.0", NULL, &mcasp0_clk), | ||
423 | CLK("soc-audio.1", NULL, &mcasp1_clk), | ||
424 | CLK("soc-audio.2", NULL, &mcasp2_clk), | ||
425 | CLK("musb_hdrc", NULL, &usb20_clk), | ||
426 | CLK(NULL, "aemif", &aemif_clk), | ||
427 | CLK(NULL, "aintc", &aintc_clk), | ||
428 | CLK(NULL, "secu_mgr", &secu_mgr_clk), | ||
429 | CLK("davinci_emac.1", NULL, &emac_clk), | ||
430 | CLK(NULL, "gpio", &gpio_clk), | ||
431 | CLK("i2c_davinci.2", NULL, &i2c1_clk), | ||
432 | CLK(NULL, "usb11", &usb11_clk), | ||
433 | CLK(NULL, "emif3", &emif3_clk), | ||
434 | CLK(NULL, "arm", &arm_clk), | ||
435 | CLK(NULL, "rmii", &rmii_clk), | ||
436 | CLK(NULL, NULL, NULL), | ||
437 | }; | ||
438 | |||
439 | #define PINMUX0 0x00 | ||
440 | #define PINMUX1 0x04 | ||
441 | #define PINMUX2 0x08 | ||
442 | #define PINMUX3 0x0c | ||
443 | #define PINMUX4 0x10 | ||
444 | #define PINMUX5 0x14 | ||
445 | #define PINMUX6 0x18 | ||
446 | #define PINMUX7 0x1c | ||
447 | #define PINMUX8 0x20 | ||
448 | #define PINMUX9 0x24 | ||
449 | #define PINMUX10 0x28 | ||
450 | #define PINMUX11 0x2c | ||
451 | #define PINMUX12 0x30 | ||
452 | #define PINMUX13 0x34 | ||
453 | #define PINMUX14 0x38 | ||
454 | #define PINMUX15 0x3c | ||
455 | #define PINMUX16 0x40 | ||
456 | #define PINMUX17 0x44 | ||
457 | #define PINMUX18 0x48 | ||
458 | #define PINMUX19 0x4c | ||
459 | |||
460 | /* | ||
461 | * Device specific mux setup | ||
462 | * | ||
463 | * soc description mux mode mode mux dbg | ||
464 | * reg offset mask mode | ||
465 | */ | ||
466 | static const struct mux_config da830_pins[] = { | ||
467 | #ifdef CONFIG_DAVINCI_MUX | ||
468 | MUX_CFG(DA830, GPIO7_14, 0, 0, 0xf, 1, false) | ||
469 | MUX_CFG(DA830, RTCK, 0, 0, 0xf, 8, false) | ||
470 | MUX_CFG(DA830, GPIO7_15, 0, 4, 0xf, 1, false) | ||
471 | MUX_CFG(DA830, EMU_0, 0, 4, 0xf, 8, false) | ||
472 | MUX_CFG(DA830, EMB_SDCKE, 0, 8, 0xf, 1, false) | ||
473 | MUX_CFG(DA830, EMB_CLK_GLUE, 0, 12, 0xf, 1, false) | ||
474 | MUX_CFG(DA830, EMB_CLK, 0, 12, 0xf, 2, false) | ||
475 | MUX_CFG(DA830, NEMB_CS_0, 0, 16, 0xf, 1, false) | ||
476 | MUX_CFG(DA830, NEMB_CAS, 0, 20, 0xf, 1, false) | ||
477 | MUX_CFG(DA830, NEMB_RAS, 0, 24, 0xf, 1, false) | ||
478 | MUX_CFG(DA830, NEMB_WE, 0, 28, 0xf, 1, false) | ||
479 | MUX_CFG(DA830, EMB_BA_1, 1, 0, 0xf, 1, false) | ||
480 | MUX_CFG(DA830, EMB_BA_0, 1, 4, 0xf, 1, false) | ||
481 | MUX_CFG(DA830, EMB_A_0, 1, 8, 0xf, 1, false) | ||
482 | MUX_CFG(DA830, EMB_A_1, 1, 12, 0xf, 1, false) | ||
483 | MUX_CFG(DA830, EMB_A_2, 1, 16, 0xf, 1, false) | ||
484 | MUX_CFG(DA830, EMB_A_3, 1, 20, 0xf, 1, false) | ||
485 | MUX_CFG(DA830, EMB_A_4, 1, 24, 0xf, 1, false) | ||
486 | MUX_CFG(DA830, EMB_A_5, 1, 28, 0xf, 1, false) | ||
487 | MUX_CFG(DA830, GPIO7_0, 1, 0, 0xf, 8, false) | ||
488 | MUX_CFG(DA830, GPIO7_1, 1, 4, 0xf, 8, false) | ||
489 | MUX_CFG(DA830, GPIO7_2, 1, 8, 0xf, 8, false) | ||
490 | MUX_CFG(DA830, GPIO7_3, 1, 12, 0xf, 8, false) | ||
491 | MUX_CFG(DA830, GPIO7_4, 1, 16, 0xf, 8, false) | ||
492 | MUX_CFG(DA830, GPIO7_5, 1, 20, 0xf, 8, false) | ||
493 | MUX_CFG(DA830, GPIO7_6, 1, 24, 0xf, 8, false) | ||
494 | MUX_CFG(DA830, GPIO7_7, 1, 28, 0xf, 8, false) | ||
495 | MUX_CFG(DA830, EMB_A_6, 2, 0, 0xf, 1, false) | ||
496 | MUX_CFG(DA830, EMB_A_7, 2, 4, 0xf, 1, false) | ||
497 | MUX_CFG(DA830, EMB_A_8, 2, 8, 0xf, 1, false) | ||
498 | MUX_CFG(DA830, EMB_A_9, 2, 12, 0xf, 1, false) | ||
499 | MUX_CFG(DA830, EMB_A_10, 2, 16, 0xf, 1, false) | ||
500 | MUX_CFG(DA830, EMB_A_11, 2, 20, 0xf, 1, false) | ||
501 | MUX_CFG(DA830, EMB_A_12, 2, 24, 0xf, 1, false) | ||
502 | MUX_CFG(DA830, EMB_D_31, 2, 28, 0xf, 1, false) | ||
503 | MUX_CFG(DA830, GPIO7_8, 2, 0, 0xf, 8, false) | ||
504 | MUX_CFG(DA830, GPIO7_9, 2, 4, 0xf, 8, false) | ||
505 | MUX_CFG(DA830, GPIO7_10, 2, 8, 0xf, 8, false) | ||
506 | MUX_CFG(DA830, GPIO7_11, 2, 12, 0xf, 8, false) | ||
507 | MUX_CFG(DA830, GPIO7_12, 2, 16, 0xf, 8, false) | ||
508 | MUX_CFG(DA830, GPIO7_13, 2, 20, 0xf, 8, false) | ||
509 | MUX_CFG(DA830, GPIO3_13, 2, 24, 0xf, 8, false) | ||
510 | MUX_CFG(DA830, EMB_D_30, 3, 0, 0xf, 1, false) | ||
511 | MUX_CFG(DA830, EMB_D_29, 3, 4, 0xf, 1, false) | ||
512 | MUX_CFG(DA830, EMB_D_28, 3, 8, 0xf, 1, false) | ||
513 | MUX_CFG(DA830, EMB_D_27, 3, 12, 0xf, 1, false) | ||
514 | MUX_CFG(DA830, EMB_D_26, 3, 16, 0xf, 1, false) | ||
515 | MUX_CFG(DA830, EMB_D_25, 3, 20, 0xf, 1, false) | ||
516 | MUX_CFG(DA830, EMB_D_24, 3, 24, 0xf, 1, false) | ||
517 | MUX_CFG(DA830, EMB_D_23, 3, 28, 0xf, 1, false) | ||
518 | MUX_CFG(DA830, EMB_D_22, 4, 0, 0xf, 1, false) | ||
519 | MUX_CFG(DA830, EMB_D_21, 4, 4, 0xf, 1, false) | ||
520 | MUX_CFG(DA830, EMB_D_20, 4, 8, 0xf, 1, false) | ||
521 | MUX_CFG(DA830, EMB_D_19, 4, 12, 0xf, 1, false) | ||
522 | MUX_CFG(DA830, EMB_D_18, 4, 16, 0xf, 1, false) | ||
523 | MUX_CFG(DA830, EMB_D_17, 4, 20, 0xf, 1, false) | ||
524 | MUX_CFG(DA830, EMB_D_16, 4, 24, 0xf, 1, false) | ||
525 | MUX_CFG(DA830, NEMB_WE_DQM_3, 4, 28, 0xf, 1, false) | ||
526 | MUX_CFG(DA830, NEMB_WE_DQM_2, 5, 0, 0xf, 1, false) | ||
527 | MUX_CFG(DA830, EMB_D_0, 5, 4, 0xf, 1, false) | ||
528 | MUX_CFG(DA830, EMB_D_1, 5, 8, 0xf, 1, false) | ||
529 | MUX_CFG(DA830, EMB_D_2, 5, 12, 0xf, 1, false) | ||
530 | MUX_CFG(DA830, EMB_D_3, 5, 16, 0xf, 1, false) | ||
531 | MUX_CFG(DA830, EMB_D_4, 5, 20, 0xf, 1, false) | ||
532 | MUX_CFG(DA830, EMB_D_5, 5, 24, 0xf, 1, false) | ||
533 | MUX_CFG(DA830, EMB_D_6, 5, 28, 0xf, 1, false) | ||
534 | MUX_CFG(DA830, GPIO6_0, 5, 4, 0xf, 8, false) | ||
535 | MUX_CFG(DA830, GPIO6_1, 5, 8, 0xf, 8, false) | ||
536 | MUX_CFG(DA830, GPIO6_2, 5, 12, 0xf, 8, false) | ||
537 | MUX_CFG(DA830, GPIO6_3, 5, 16, 0xf, 8, false) | ||
538 | MUX_CFG(DA830, GPIO6_4, 5, 20, 0xf, 8, false) | ||
539 | MUX_CFG(DA830, GPIO6_5, 5, 24, 0xf, 8, false) | ||
540 | MUX_CFG(DA830, GPIO6_6, 5, 28, 0xf, 8, false) | ||
541 | MUX_CFG(DA830, EMB_D_7, 6, 0, 0xf, 1, false) | ||
542 | MUX_CFG(DA830, EMB_D_8, 6, 4, 0xf, 1, false) | ||
543 | MUX_CFG(DA830, EMB_D_9, 6, 8, 0xf, 1, false) | ||
544 | MUX_CFG(DA830, EMB_D_10, 6, 12, 0xf, 1, false) | ||
545 | MUX_CFG(DA830, EMB_D_11, 6, 16, 0xf, 1, false) | ||
546 | MUX_CFG(DA830, EMB_D_12, 6, 20, 0xf, 1, false) | ||
547 | MUX_CFG(DA830, EMB_D_13, 6, 24, 0xf, 1, false) | ||
548 | MUX_CFG(DA830, EMB_D_14, 6, 28, 0xf, 1, false) | ||
549 | MUX_CFG(DA830, GPIO6_7, 6, 0, 0xf, 8, false) | ||
550 | MUX_CFG(DA830, GPIO6_8, 6, 4, 0xf, 8, false) | ||
551 | MUX_CFG(DA830, GPIO6_9, 6, 8, 0xf, 8, false) | ||
552 | MUX_CFG(DA830, GPIO6_10, 6, 12, 0xf, 8, false) | ||
553 | MUX_CFG(DA830, GPIO6_11, 6, 16, 0xf, 8, false) | ||
554 | MUX_CFG(DA830, GPIO6_12, 6, 20, 0xf, 8, false) | ||
555 | MUX_CFG(DA830, GPIO6_13, 6, 24, 0xf, 8, false) | ||
556 | MUX_CFG(DA830, GPIO6_14, 6, 28, 0xf, 8, false) | ||
557 | MUX_CFG(DA830, EMB_D_15, 7, 0, 0xf, 1, false) | ||
558 | MUX_CFG(DA830, NEMB_WE_DQM_1, 7, 4, 0xf, 1, false) | ||
559 | MUX_CFG(DA830, NEMB_WE_DQM_0, 7, 8, 0xf, 1, false) | ||
560 | MUX_CFG(DA830, SPI0_SOMI_0, 7, 12, 0xf, 1, false) | ||
561 | MUX_CFG(DA830, SPI0_SIMO_0, 7, 16, 0xf, 1, false) | ||
562 | MUX_CFG(DA830, SPI0_CLK, 7, 20, 0xf, 1, false) | ||
563 | MUX_CFG(DA830, NSPI0_ENA, 7, 24, 0xf, 1, false) | ||
564 | MUX_CFG(DA830, NSPI0_SCS_0, 7, 28, 0xf, 1, false) | ||
565 | MUX_CFG(DA830, EQEP0I, 7, 12, 0xf, 2, false) | ||
566 | MUX_CFG(DA830, EQEP0S, 7, 16, 0xf, 2, false) | ||
567 | MUX_CFG(DA830, EQEP1I, 7, 20, 0xf, 2, false) | ||
568 | MUX_CFG(DA830, NUART0_CTS, 7, 24, 0xf, 2, false) | ||
569 | MUX_CFG(DA830, NUART0_RTS, 7, 28, 0xf, 2, false) | ||
570 | MUX_CFG(DA830, EQEP0A, 7, 24, 0xf, 4, false) | ||
571 | MUX_CFG(DA830, EQEP0B, 7, 28, 0xf, 4, false) | ||
572 | MUX_CFG(DA830, GPIO6_15, 7, 0, 0xf, 8, false) | ||
573 | MUX_CFG(DA830, GPIO5_14, 7, 4, 0xf, 8, false) | ||
574 | MUX_CFG(DA830, GPIO5_15, 7, 8, 0xf, 8, false) | ||
575 | MUX_CFG(DA830, GPIO5_0, 7, 12, 0xf, 8, false) | ||
576 | MUX_CFG(DA830, GPIO5_1, 7, 16, 0xf, 8, false) | ||
577 | MUX_CFG(DA830, GPIO5_2, 7, 20, 0xf, 8, false) | ||
578 | MUX_CFG(DA830, GPIO5_3, 7, 24, 0xf, 8, false) | ||
579 | MUX_CFG(DA830, GPIO5_4, 7, 28, 0xf, 8, false) | ||
580 | MUX_CFG(DA830, SPI1_SOMI_0, 8, 0, 0xf, 1, false) | ||
581 | MUX_CFG(DA830, SPI1_SIMO_0, 8, 4, 0xf, 1, false) | ||
582 | MUX_CFG(DA830, SPI1_CLK, 8, 8, 0xf, 1, false) | ||
583 | MUX_CFG(DA830, UART0_RXD, 8, 12, 0xf, 1, false) | ||
584 | MUX_CFG(DA830, UART0_TXD, 8, 16, 0xf, 1, false) | ||
585 | MUX_CFG(DA830, AXR1_10, 8, 20, 0xf, 1, false) | ||
586 | MUX_CFG(DA830, AXR1_11, 8, 24, 0xf, 1, false) | ||
587 | MUX_CFG(DA830, NSPI1_ENA, 8, 28, 0xf, 1, false) | ||
588 | MUX_CFG(DA830, I2C1_SCL, 8, 0, 0xf, 2, false) | ||
589 | MUX_CFG(DA830, I2C1_SDA, 8, 4, 0xf, 2, false) | ||
590 | MUX_CFG(DA830, EQEP1S, 8, 8, 0xf, 2, false) | ||
591 | MUX_CFG(DA830, I2C0_SDA, 8, 12, 0xf, 2, false) | ||
592 | MUX_CFG(DA830, I2C0_SCL, 8, 16, 0xf, 2, false) | ||
593 | MUX_CFG(DA830, UART2_RXD, 8, 28, 0xf, 2, false) | ||
594 | MUX_CFG(DA830, TM64P0_IN12, 8, 12, 0xf, 4, false) | ||
595 | MUX_CFG(DA830, TM64P0_OUT12, 8, 16, 0xf, 4, false) | ||
596 | MUX_CFG(DA830, GPIO5_5, 8, 0, 0xf, 8, false) | ||
597 | MUX_CFG(DA830, GPIO5_6, 8, 4, 0xf, 8, false) | ||
598 | MUX_CFG(DA830, GPIO5_7, 8, 8, 0xf, 8, false) | ||
599 | MUX_CFG(DA830, GPIO5_8, 8, 12, 0xf, 8, false) | ||
600 | MUX_CFG(DA830, GPIO5_9, 8, 16, 0xf, 8, false) | ||
601 | MUX_CFG(DA830, GPIO5_10, 8, 20, 0xf, 8, false) | ||
602 | MUX_CFG(DA830, GPIO5_11, 8, 24, 0xf, 8, false) | ||
603 | MUX_CFG(DA830, GPIO5_12, 8, 28, 0xf, 8, false) | ||
604 | MUX_CFG(DA830, NSPI1_SCS_0, 9, 0, 0xf, 1, false) | ||
605 | MUX_CFG(DA830, USB0_DRVVBUS, 9, 4, 0xf, 1, false) | ||
606 | MUX_CFG(DA830, AHCLKX0, 9, 8, 0xf, 1, false) | ||
607 | MUX_CFG(DA830, ACLKX0, 9, 12, 0xf, 1, false) | ||
608 | MUX_CFG(DA830, AFSX0, 9, 16, 0xf, 1, false) | ||
609 | MUX_CFG(DA830, AHCLKR0, 9, 20, 0xf, 1, false) | ||
610 | MUX_CFG(DA830, ACLKR0, 9, 24, 0xf, 1, false) | ||
611 | MUX_CFG(DA830, AFSR0, 9, 28, 0xf, 1, false) | ||
612 | MUX_CFG(DA830, UART2_TXD, 9, 0, 0xf, 2, false) | ||
613 | MUX_CFG(DA830, AHCLKX2, 9, 8, 0xf, 2, false) | ||
614 | MUX_CFG(DA830, ECAP0_APWM0, 9, 12, 0xf, 2, false) | ||
615 | MUX_CFG(DA830, RMII_MHZ_50_CLK, 9, 20, 0xf, 2, false) | ||
616 | MUX_CFG(DA830, ECAP1_APWM1, 9, 24, 0xf, 2, false) | ||
617 | MUX_CFG(DA830, USB_REFCLKIN, 9, 8, 0xf, 4, false) | ||
618 | MUX_CFG(DA830, GPIO5_13, 9, 0, 0xf, 8, false) | ||
619 | MUX_CFG(DA830, GPIO4_15, 9, 4, 0xf, 8, false) | ||
620 | MUX_CFG(DA830, GPIO2_11, 9, 8, 0xf, 8, false) | ||
621 | MUX_CFG(DA830, GPIO2_12, 9, 12, 0xf, 8, false) | ||
622 | MUX_CFG(DA830, GPIO2_13, 9, 16, 0xf, 8, false) | ||
623 | MUX_CFG(DA830, GPIO2_14, 9, 20, 0xf, 8, false) | ||
624 | MUX_CFG(DA830, GPIO2_15, 9, 24, 0xf, 8, false) | ||
625 | MUX_CFG(DA830, GPIO3_12, 9, 28, 0xf, 8, false) | ||
626 | MUX_CFG(DA830, AMUTE0, 10, 0, 0xf, 1, false) | ||
627 | MUX_CFG(DA830, AXR0_0, 10, 4, 0xf, 1, false) | ||
628 | MUX_CFG(DA830, AXR0_1, 10, 8, 0xf, 1, false) | ||
629 | MUX_CFG(DA830, AXR0_2, 10, 12, 0xf, 1, false) | ||
630 | MUX_CFG(DA830, AXR0_3, 10, 16, 0xf, 1, false) | ||
631 | MUX_CFG(DA830, AXR0_4, 10, 20, 0xf, 1, false) | ||
632 | MUX_CFG(DA830, AXR0_5, 10, 24, 0xf, 1, false) | ||
633 | MUX_CFG(DA830, AXR0_6, 10, 28, 0xf, 1, false) | ||
634 | MUX_CFG(DA830, RMII_TXD_0, 10, 4, 0xf, 2, false) | ||
635 | MUX_CFG(DA830, RMII_TXD_1, 10, 8, 0xf, 2, false) | ||
636 | MUX_CFG(DA830, RMII_TXEN, 10, 12, 0xf, 2, false) | ||
637 | MUX_CFG(DA830, RMII_CRS_DV, 10, 16, 0xf, 2, false) | ||
638 | MUX_CFG(DA830, RMII_RXD_0, 10, 20, 0xf, 2, false) | ||
639 | MUX_CFG(DA830, RMII_RXD_1, 10, 24, 0xf, 2, false) | ||
640 | MUX_CFG(DA830, RMII_RXER, 10, 28, 0xf, 2, false) | ||
641 | MUX_CFG(DA830, AFSR2, 10, 4, 0xf, 4, false) | ||
642 | MUX_CFG(DA830, ACLKX2, 10, 8, 0xf, 4, false) | ||
643 | MUX_CFG(DA830, AXR2_3, 10, 12, 0xf, 4, false) | ||
644 | MUX_CFG(DA830, AXR2_2, 10, 16, 0xf, 4, false) | ||
645 | MUX_CFG(DA830, AXR2_1, 10, 20, 0xf, 4, false) | ||
646 | MUX_CFG(DA830, AFSX2, 10, 24, 0xf, 4, false) | ||
647 | MUX_CFG(DA830, ACLKR2, 10, 28, 0xf, 4, false) | ||
648 | MUX_CFG(DA830, NRESETOUT, 10, 0, 0xf, 8, false) | ||
649 | MUX_CFG(DA830, GPIO3_0, 10, 4, 0xf, 8, false) | ||
650 | MUX_CFG(DA830, GPIO3_1, 10, 8, 0xf, 8, false) | ||
651 | MUX_CFG(DA830, GPIO3_2, 10, 12, 0xf, 8, false) | ||
652 | MUX_CFG(DA830, GPIO3_3, 10, 16, 0xf, 8, false) | ||
653 | MUX_CFG(DA830, GPIO3_4, 10, 20, 0xf, 8, false) | ||
654 | MUX_CFG(DA830, GPIO3_5, 10, 24, 0xf, 8, false) | ||
655 | MUX_CFG(DA830, GPIO3_6, 10, 28, 0xf, 8, false) | ||
656 | MUX_CFG(DA830, AXR0_7, 11, 0, 0xf, 1, false) | ||
657 | MUX_CFG(DA830, AXR0_8, 11, 4, 0xf, 1, false) | ||
658 | MUX_CFG(DA830, UART1_RXD, 11, 8, 0xf, 1, false) | ||
659 | MUX_CFG(DA830, UART1_TXD, 11, 12, 0xf, 1, false) | ||
660 | MUX_CFG(DA830, AXR0_11, 11, 16, 0xf, 1, false) | ||
661 | MUX_CFG(DA830, AHCLKX1, 11, 20, 0xf, 1, false) | ||
662 | MUX_CFG(DA830, ACLKX1, 11, 24, 0xf, 1, false) | ||
663 | MUX_CFG(DA830, AFSX1, 11, 28, 0xf, 1, false) | ||
664 | MUX_CFG(DA830, MDIO_CLK, 11, 0, 0xf, 2, false) | ||
665 | MUX_CFG(DA830, MDIO_D, 11, 4, 0xf, 2, false) | ||
666 | MUX_CFG(DA830, AXR0_9, 11, 8, 0xf, 2, false) | ||
667 | MUX_CFG(DA830, AXR0_10, 11, 12, 0xf, 2, false) | ||
668 | MUX_CFG(DA830, EPWM0B, 11, 20, 0xf, 2, false) | ||
669 | MUX_CFG(DA830, EPWM0A, 11, 24, 0xf, 2, false) | ||
670 | MUX_CFG(DA830, EPWMSYNCI, 11, 28, 0xf, 2, false) | ||
671 | MUX_CFG(DA830, AXR2_0, 11, 16, 0xf, 4, false) | ||
672 | MUX_CFG(DA830, EPWMSYNC0, 11, 28, 0xf, 4, false) | ||
673 | MUX_CFG(DA830, GPIO3_7, 11, 0, 0xf, 8, false) | ||
674 | MUX_CFG(DA830, GPIO3_8, 11, 4, 0xf, 8, false) | ||
675 | MUX_CFG(DA830, GPIO3_9, 11, 8, 0xf, 8, false) | ||
676 | MUX_CFG(DA830, GPIO3_10, 11, 12, 0xf, 8, false) | ||
677 | MUX_CFG(DA830, GPIO3_11, 11, 16, 0xf, 8, false) | ||
678 | MUX_CFG(DA830, GPIO3_14, 11, 20, 0xf, 8, false) | ||
679 | MUX_CFG(DA830, GPIO3_15, 11, 24, 0xf, 8, false) | ||
680 | MUX_CFG(DA830, GPIO4_10, 11, 28, 0xf, 8, false) | ||
681 | MUX_CFG(DA830, AHCLKR1, 12, 0, 0xf, 1, false) | ||
682 | MUX_CFG(DA830, ACLKR1, 12, 4, 0xf, 1, false) | ||
683 | MUX_CFG(DA830, AFSR1, 12, 8, 0xf, 1, false) | ||
684 | MUX_CFG(DA830, AMUTE1, 12, 12, 0xf, 1, false) | ||
685 | MUX_CFG(DA830, AXR1_0, 12, 16, 0xf, 1, false) | ||
686 | MUX_CFG(DA830, AXR1_1, 12, 20, 0xf, 1, false) | ||
687 | MUX_CFG(DA830, AXR1_2, 12, 24, 0xf, 1, false) | ||
688 | MUX_CFG(DA830, AXR1_3, 12, 28, 0xf, 1, false) | ||
689 | MUX_CFG(DA830, ECAP2_APWM2, 12, 4, 0xf, 2, false) | ||
690 | MUX_CFG(DA830, EHRPWMGLUETZ, 12, 12, 0xf, 2, false) | ||
691 | MUX_CFG(DA830, EQEP1A, 12, 28, 0xf, 2, false) | ||
692 | MUX_CFG(DA830, GPIO4_11, 12, 0, 0xf, 8, false) | ||
693 | MUX_CFG(DA830, GPIO4_12, 12, 4, 0xf, 8, false) | ||
694 | MUX_CFG(DA830, GPIO4_13, 12, 8, 0xf, 8, false) | ||
695 | MUX_CFG(DA830, GPIO4_14, 12, 12, 0xf, 8, false) | ||
696 | MUX_CFG(DA830, GPIO4_0, 12, 16, 0xf, 8, false) | ||
697 | MUX_CFG(DA830, GPIO4_1, 12, 20, 0xf, 8, false) | ||
698 | MUX_CFG(DA830, GPIO4_2, 12, 24, 0xf, 8, false) | ||
699 | MUX_CFG(DA830, GPIO4_3, 12, 28, 0xf, 8, false) | ||
700 | MUX_CFG(DA830, AXR1_4, 13, 0, 0xf, 1, false) | ||
701 | MUX_CFG(DA830, AXR1_5, 13, 4, 0xf, 1, false) | ||
702 | MUX_CFG(DA830, AXR1_6, 13, 8, 0xf, 1, false) | ||
703 | MUX_CFG(DA830, AXR1_7, 13, 12, 0xf, 1, false) | ||
704 | MUX_CFG(DA830, AXR1_8, 13, 16, 0xf, 1, false) | ||
705 | MUX_CFG(DA830, AXR1_9, 13, 20, 0xf, 1, false) | ||
706 | MUX_CFG(DA830, EMA_D_0, 13, 24, 0xf, 1, false) | ||
707 | MUX_CFG(DA830, EMA_D_1, 13, 28, 0xf, 1, false) | ||
708 | MUX_CFG(DA830, EQEP1B, 13, 0, 0xf, 2, false) | ||
709 | MUX_CFG(DA830, EPWM2B, 13, 4, 0xf, 2, false) | ||
710 | MUX_CFG(DA830, EPWM2A, 13, 8, 0xf, 2, false) | ||
711 | MUX_CFG(DA830, EPWM1B, 13, 12, 0xf, 2, false) | ||
712 | MUX_CFG(DA830, EPWM1A, 13, 16, 0xf, 2, false) | ||
713 | MUX_CFG(DA830, MMCSD_DAT_0, 13, 24, 0xf, 2, false) | ||
714 | MUX_CFG(DA830, MMCSD_DAT_1, 13, 28, 0xf, 2, false) | ||
715 | MUX_CFG(DA830, UHPI_HD_0, 13, 24, 0xf, 4, false) | ||
716 | MUX_CFG(DA830, UHPI_HD_1, 13, 28, 0xf, 4, false) | ||
717 | MUX_CFG(DA830, GPIO4_4, 13, 0, 0xf, 8, false) | ||
718 | MUX_CFG(DA830, GPIO4_5, 13, 4, 0xf, 8, false) | ||
719 | MUX_CFG(DA830, GPIO4_6, 13, 8, 0xf, 8, false) | ||
720 | MUX_CFG(DA830, GPIO4_7, 13, 12, 0xf, 8, false) | ||
721 | MUX_CFG(DA830, GPIO4_8, 13, 16, 0xf, 8, false) | ||
722 | MUX_CFG(DA830, GPIO4_9, 13, 20, 0xf, 8, false) | ||
723 | MUX_CFG(DA830, GPIO0_0, 13, 24, 0xf, 8, false) | ||
724 | MUX_CFG(DA830, GPIO0_1, 13, 28, 0xf, 8, false) | ||
725 | MUX_CFG(DA830, EMA_D_2, 14, 0, 0xf, 1, false) | ||
726 | MUX_CFG(DA830, EMA_D_3, 14, 4, 0xf, 1, false) | ||
727 | MUX_CFG(DA830, EMA_D_4, 14, 8, 0xf, 1, false) | ||
728 | MUX_CFG(DA830, EMA_D_5, 14, 12, 0xf, 1, false) | ||
729 | MUX_CFG(DA830, EMA_D_6, 14, 16, 0xf, 1, false) | ||
730 | MUX_CFG(DA830, EMA_D_7, 14, 20, 0xf, 1, false) | ||
731 | MUX_CFG(DA830, EMA_D_8, 14, 24, 0xf, 1, false) | ||
732 | MUX_CFG(DA830, EMA_D_9, 14, 28, 0xf, 1, false) | ||
733 | MUX_CFG(DA830, MMCSD_DAT_2, 14, 0, 0xf, 2, false) | ||
734 | MUX_CFG(DA830, MMCSD_DAT_3, 14, 4, 0xf, 2, false) | ||
735 | MUX_CFG(DA830, MMCSD_DAT_4, 14, 8, 0xf, 2, false) | ||
736 | MUX_CFG(DA830, MMCSD_DAT_5, 14, 12, 0xf, 2, false) | ||
737 | MUX_CFG(DA830, MMCSD_DAT_6, 14, 16, 0xf, 2, false) | ||
738 | MUX_CFG(DA830, MMCSD_DAT_7, 14, 20, 0xf, 2, false) | ||
739 | MUX_CFG(DA830, UHPI_HD_8, 14, 24, 0xf, 2, false) | ||
740 | MUX_CFG(DA830, UHPI_HD_9, 14, 28, 0xf, 2, false) | ||
741 | MUX_CFG(DA830, UHPI_HD_2, 14, 0, 0xf, 4, false) | ||
742 | MUX_CFG(DA830, UHPI_HD_3, 14, 4, 0xf, 4, false) | ||
743 | MUX_CFG(DA830, UHPI_HD_4, 14, 8, 0xf, 4, false) | ||
744 | MUX_CFG(DA830, UHPI_HD_5, 14, 12, 0xf, 4, false) | ||
745 | MUX_CFG(DA830, UHPI_HD_6, 14, 16, 0xf, 4, false) | ||
746 | MUX_CFG(DA830, UHPI_HD_7, 14, 20, 0xf, 4, false) | ||
747 | MUX_CFG(DA830, LCD_D_8, 14, 24, 0xf, 4, false) | ||
748 | MUX_CFG(DA830, LCD_D_9, 14, 28, 0xf, 4, false) | ||
749 | MUX_CFG(DA830, GPIO0_2, 14, 0, 0xf, 8, false) | ||
750 | MUX_CFG(DA830, GPIO0_3, 14, 4, 0xf, 8, false) | ||
751 | MUX_CFG(DA830, GPIO0_4, 14, 8, 0xf, 8, false) | ||
752 | MUX_CFG(DA830, GPIO0_5, 14, 12, 0xf, 8, false) | ||
753 | MUX_CFG(DA830, GPIO0_6, 14, 16, 0xf, 8, false) | ||
754 | MUX_CFG(DA830, GPIO0_7, 14, 20, 0xf, 8, false) | ||
755 | MUX_CFG(DA830, GPIO0_8, 14, 24, 0xf, 8, false) | ||
756 | MUX_CFG(DA830, GPIO0_9, 14, 28, 0xf, 8, false) | ||
757 | MUX_CFG(DA830, EMA_D_10, 15, 0, 0xf, 1, false) | ||
758 | MUX_CFG(DA830, EMA_D_11, 15, 4, 0xf, 1, false) | ||
759 | MUX_CFG(DA830, EMA_D_12, 15, 8, 0xf, 1, false) | ||
760 | MUX_CFG(DA830, EMA_D_13, 15, 12, 0xf, 1, false) | ||
761 | MUX_CFG(DA830, EMA_D_14, 15, 16, 0xf, 1, false) | ||
762 | MUX_CFG(DA830, EMA_D_15, 15, 20, 0xf, 1, false) | ||
763 | MUX_CFG(DA830, EMA_A_0, 15, 24, 0xf, 1, false) | ||
764 | MUX_CFG(DA830, EMA_A_1, 15, 28, 0xf, 1, false) | ||
765 | MUX_CFG(DA830, UHPI_HD_10, 15, 0, 0xf, 2, false) | ||
766 | MUX_CFG(DA830, UHPI_HD_11, 15, 4, 0xf, 2, false) | ||
767 | MUX_CFG(DA830, UHPI_HD_12, 15, 8, 0xf, 2, false) | ||
768 | MUX_CFG(DA830, UHPI_HD_13, 15, 12, 0xf, 2, false) | ||
769 | MUX_CFG(DA830, UHPI_HD_14, 15, 16, 0xf, 2, false) | ||
770 | MUX_CFG(DA830, UHPI_HD_15, 15, 20, 0xf, 2, false) | ||
771 | MUX_CFG(DA830, LCD_D_7, 15, 24, 0xf, 2, false) | ||
772 | MUX_CFG(DA830, MMCSD_CLK, 15, 28, 0xf, 2, false) | ||
773 | MUX_CFG(DA830, LCD_D_10, 15, 0, 0xf, 4, false) | ||
774 | MUX_CFG(DA830, LCD_D_11, 15, 4, 0xf, 4, false) | ||
775 | MUX_CFG(DA830, LCD_D_12, 15, 8, 0xf, 4, false) | ||
776 | MUX_CFG(DA830, LCD_D_13, 15, 12, 0xf, 4, false) | ||
777 | MUX_CFG(DA830, LCD_D_14, 15, 16, 0xf, 4, false) | ||
778 | MUX_CFG(DA830, LCD_D_15, 15, 20, 0xf, 4, false) | ||
779 | MUX_CFG(DA830, UHPI_HCNTL0, 15, 28, 0xf, 4, false) | ||
780 | MUX_CFG(DA830, GPIO0_10, 15, 0, 0xf, 8, false) | ||
781 | MUX_CFG(DA830, GPIO0_11, 15, 4, 0xf, 8, false) | ||
782 | MUX_CFG(DA830, GPIO0_12, 15, 8, 0xf, 8, false) | ||
783 | MUX_CFG(DA830, GPIO0_13, 15, 12, 0xf, 8, false) | ||
784 | MUX_CFG(DA830, GPIO0_14, 15, 16, 0xf, 8, false) | ||
785 | MUX_CFG(DA830, GPIO0_15, 15, 20, 0xf, 8, false) | ||
786 | MUX_CFG(DA830, GPIO1_0, 15, 24, 0xf, 8, false) | ||
787 | MUX_CFG(DA830, GPIO1_1, 15, 28, 0xf, 8, false) | ||
788 | MUX_CFG(DA830, EMA_A_2, 16, 0, 0xf, 1, false) | ||
789 | MUX_CFG(DA830, EMA_A_3, 16, 4, 0xf, 1, false) | ||
790 | MUX_CFG(DA830, EMA_A_4, 16, 8, 0xf, 1, false) | ||
791 | MUX_CFG(DA830, EMA_A_5, 16, 12, 0xf, 1, false) | ||
792 | MUX_CFG(DA830, EMA_A_6, 16, 16, 0xf, 1, false) | ||
793 | MUX_CFG(DA830, EMA_A_7, 16, 20, 0xf, 1, false) | ||
794 | MUX_CFG(DA830, EMA_A_8, 16, 24, 0xf, 1, false) | ||
795 | MUX_CFG(DA830, EMA_A_9, 16, 28, 0xf, 1, false) | ||
796 | MUX_CFG(DA830, MMCSD_CMD, 16, 0, 0xf, 2, false) | ||
797 | MUX_CFG(DA830, LCD_D_6, 16, 4, 0xf, 2, false) | ||
798 | MUX_CFG(DA830, LCD_D_3, 16, 8, 0xf, 2, false) | ||
799 | MUX_CFG(DA830, LCD_D_2, 16, 12, 0xf, 2, false) | ||
800 | MUX_CFG(DA830, LCD_D_1, 16, 16, 0xf, 2, false) | ||
801 | MUX_CFG(DA830, LCD_D_0, 16, 20, 0xf, 2, false) | ||
802 | MUX_CFG(DA830, LCD_PCLK, 16, 24, 0xf, 2, false) | ||
803 | MUX_CFG(DA830, LCD_HSYNC, 16, 28, 0xf, 2, false) | ||
804 | MUX_CFG(DA830, UHPI_HCNTL1, 16, 0, 0xf, 4, false) | ||
805 | MUX_CFG(DA830, GPIO1_2, 16, 0, 0xf, 8, false) | ||
806 | MUX_CFG(DA830, GPIO1_3, 16, 4, 0xf, 8, false) | ||
807 | MUX_CFG(DA830, GPIO1_4, 16, 8, 0xf, 8, false) | ||
808 | MUX_CFG(DA830, GPIO1_5, 16, 12, 0xf, 8, false) | ||
809 | MUX_CFG(DA830, GPIO1_6, 16, 16, 0xf, 8, false) | ||
810 | MUX_CFG(DA830, GPIO1_7, 16, 20, 0xf, 8, false) | ||
811 | MUX_CFG(DA830, GPIO1_8, 16, 24, 0xf, 8, false) | ||
812 | MUX_CFG(DA830, GPIO1_9, 16, 28, 0xf, 8, false) | ||
813 | MUX_CFG(DA830, EMA_A_10, 17, 0, 0xf, 1, false) | ||
814 | MUX_CFG(DA830, EMA_A_11, 17, 4, 0xf, 1, false) | ||
815 | MUX_CFG(DA830, EMA_A_12, 17, 8, 0xf, 1, false) | ||
816 | MUX_CFG(DA830, EMA_BA_1, 17, 12, 0xf, 1, false) | ||
817 | MUX_CFG(DA830, EMA_BA_0, 17, 16, 0xf, 1, false) | ||
818 | MUX_CFG(DA830, EMA_CLK, 17, 20, 0xf, 1, false) | ||
819 | MUX_CFG(DA830, EMA_SDCKE, 17, 24, 0xf, 1, false) | ||
820 | MUX_CFG(DA830, NEMA_CAS, 17, 28, 0xf, 1, false) | ||
821 | MUX_CFG(DA830, LCD_VSYNC, 17, 0, 0xf, 2, false) | ||
822 | MUX_CFG(DA830, NLCD_AC_ENB_CS, 17, 4, 0xf, 2, false) | ||
823 | MUX_CFG(DA830, LCD_MCLK, 17, 8, 0xf, 2, false) | ||
824 | MUX_CFG(DA830, LCD_D_5, 17, 12, 0xf, 2, false) | ||
825 | MUX_CFG(DA830, LCD_D_4, 17, 16, 0xf, 2, false) | ||
826 | MUX_CFG(DA830, OBSCLK, 17, 20, 0xf, 2, false) | ||
827 | MUX_CFG(DA830, NEMA_CS_4, 17, 28, 0xf, 2, false) | ||
828 | MUX_CFG(DA830, UHPI_HHWIL, 17, 12, 0xf, 4, false) | ||
829 | MUX_CFG(DA830, AHCLKR2, 17, 20, 0xf, 4, false) | ||
830 | MUX_CFG(DA830, GPIO1_10, 17, 0, 0xf, 8, false) | ||
831 | MUX_CFG(DA830, GPIO1_11, 17, 4, 0xf, 8, false) | ||
832 | MUX_CFG(DA830, GPIO1_12, 17, 8, 0xf, 8, false) | ||
833 | MUX_CFG(DA830, GPIO1_13, 17, 12, 0xf, 8, false) | ||
834 | MUX_CFG(DA830, GPIO1_14, 17, 16, 0xf, 8, false) | ||
835 | MUX_CFG(DA830, GPIO1_15, 17, 20, 0xf, 8, false) | ||
836 | MUX_CFG(DA830, GPIO2_0, 17, 24, 0xf, 8, false) | ||
837 | MUX_CFG(DA830, GPIO2_1, 17, 28, 0xf, 8, false) | ||
838 | MUX_CFG(DA830, NEMA_RAS, 18, 0, 0xf, 1, false) | ||
839 | MUX_CFG(DA830, NEMA_WE, 18, 4, 0xf, 1, false) | ||
840 | MUX_CFG(DA830, NEMA_CS_0, 18, 8, 0xf, 1, false) | ||
841 | MUX_CFG(DA830, NEMA_CS_2, 18, 12, 0xf, 1, false) | ||
842 | MUX_CFG(DA830, NEMA_CS_3, 18, 16, 0xf, 1, false) | ||
843 | MUX_CFG(DA830, NEMA_OE, 18, 20, 0xf, 1, false) | ||
844 | MUX_CFG(DA830, NEMA_WE_DQM_1, 18, 24, 0xf, 1, false) | ||
845 | MUX_CFG(DA830, NEMA_WE_DQM_0, 18, 28, 0xf, 1, false) | ||
846 | MUX_CFG(DA830, NEMA_CS_5, 18, 0, 0xf, 2, false) | ||
847 | MUX_CFG(DA830, UHPI_HRNW, 18, 4, 0xf, 2, false) | ||
848 | MUX_CFG(DA830, NUHPI_HAS, 18, 8, 0xf, 2, false) | ||
849 | MUX_CFG(DA830, NUHPI_HCS, 18, 12, 0xf, 2, false) | ||
850 | MUX_CFG(DA830, NUHPI_HDS1, 18, 20, 0xf, 2, false) | ||
851 | MUX_CFG(DA830, NUHPI_HDS2, 18, 24, 0xf, 2, false) | ||
852 | MUX_CFG(DA830, NUHPI_HINT, 18, 28, 0xf, 2, false) | ||
853 | MUX_CFG(DA830, AXR0_12, 18, 4, 0xf, 4, false) | ||
854 | MUX_CFG(DA830, AMUTE2, 18, 16, 0xf, 4, false) | ||
855 | MUX_CFG(DA830, AXR0_13, 18, 20, 0xf, 4, false) | ||
856 | MUX_CFG(DA830, AXR0_14, 18, 24, 0xf, 4, false) | ||
857 | MUX_CFG(DA830, AXR0_15, 18, 28, 0xf, 4, false) | ||
858 | MUX_CFG(DA830, GPIO2_2, 18, 0, 0xf, 8, false) | ||
859 | MUX_CFG(DA830, GPIO2_3, 18, 4, 0xf, 8, false) | ||
860 | MUX_CFG(DA830, GPIO2_4, 18, 8, 0xf, 8, false) | ||
861 | MUX_CFG(DA830, GPIO2_5, 18, 12, 0xf, 8, false) | ||
862 | MUX_CFG(DA830, GPIO2_6, 18, 16, 0xf, 8, false) | ||
863 | MUX_CFG(DA830, GPIO2_7, 18, 20, 0xf, 8, false) | ||
864 | MUX_CFG(DA830, GPIO2_8, 18, 24, 0xf, 8, false) | ||
865 | MUX_CFG(DA830, GPIO2_9, 18, 28, 0xf, 8, false) | ||
866 | MUX_CFG(DA830, EMA_WAIT_0, 19, 0, 0xf, 1, false) | ||
867 | MUX_CFG(DA830, NUHPI_HRDY, 19, 0, 0xf, 2, false) | ||
868 | MUX_CFG(DA830, GPIO2_10, 19, 0, 0xf, 8, false) | ||
869 | #endif | ||
870 | }; | ||
871 | |||
872 | const short da830_emif25_pins[] __initdata = { | ||
873 | DA830_EMA_D_0, DA830_EMA_D_1, DA830_EMA_D_2, DA830_EMA_D_3, | ||
874 | DA830_EMA_D_4, DA830_EMA_D_5, DA830_EMA_D_6, DA830_EMA_D_7, | ||
875 | DA830_EMA_D_8, DA830_EMA_D_9, DA830_EMA_D_10, DA830_EMA_D_11, | ||
876 | DA830_EMA_D_12, DA830_EMA_D_13, DA830_EMA_D_14, DA830_EMA_D_15, | ||
877 | DA830_EMA_A_0, DA830_EMA_A_1, DA830_EMA_A_2, DA830_EMA_A_3, | ||
878 | DA830_EMA_A_4, DA830_EMA_A_5, DA830_EMA_A_6, DA830_EMA_A_7, | ||
879 | DA830_EMA_A_8, DA830_EMA_A_9, DA830_EMA_A_10, DA830_EMA_A_11, | ||
880 | DA830_EMA_A_12, DA830_EMA_BA_0, DA830_EMA_BA_1, DA830_EMA_CLK, | ||
881 | DA830_EMA_SDCKE, DA830_NEMA_CS_4, DA830_NEMA_CS_5, DA830_NEMA_WE, | ||
882 | DA830_NEMA_CS_0, DA830_NEMA_CS_2, DA830_NEMA_CS_3, DA830_NEMA_OE, | ||
883 | DA830_NEMA_WE_DQM_1, DA830_NEMA_WE_DQM_0, DA830_EMA_WAIT_0, | ||
884 | -1 | ||
885 | }; | ||
886 | |||
887 | const short da830_spi0_pins[] __initdata = { | ||
888 | DA830_SPI0_SOMI_0, DA830_SPI0_SIMO_0, DA830_SPI0_CLK, DA830_NSPI0_ENA, | ||
889 | DA830_NSPI0_SCS_0, | ||
890 | -1 | ||
891 | }; | ||
892 | |||
893 | const short da830_spi1_pins[] __initdata = { | ||
894 | DA830_SPI1_SOMI_0, DA830_SPI1_SIMO_0, DA830_SPI1_CLK, DA830_NSPI1_ENA, | ||
895 | DA830_NSPI1_SCS_0, | ||
896 | -1 | ||
897 | }; | ||
898 | |||
899 | const short da830_mmc_sd_pins[] __initdata = { | ||
900 | DA830_MMCSD_DAT_0, DA830_MMCSD_DAT_1, DA830_MMCSD_DAT_2, | ||
901 | DA830_MMCSD_DAT_3, DA830_MMCSD_DAT_4, DA830_MMCSD_DAT_5, | ||
902 | DA830_MMCSD_DAT_6, DA830_MMCSD_DAT_7, DA830_MMCSD_CLK, | ||
903 | DA830_MMCSD_CMD, | ||
904 | -1 | ||
905 | }; | ||
906 | |||
907 | const short da830_uart0_pins[] __initdata = { | ||
908 | DA830_NUART0_CTS, DA830_NUART0_RTS, DA830_UART0_RXD, DA830_UART0_TXD, | ||
909 | -1 | ||
910 | }; | ||
911 | |||
912 | const short da830_uart1_pins[] __initdata = { | ||
913 | DA830_UART1_RXD, DA830_UART1_TXD, | ||
914 | -1 | ||
915 | }; | ||
916 | |||
917 | const short da830_uart2_pins[] __initdata = { | ||
918 | DA830_UART2_RXD, DA830_UART2_TXD, | ||
919 | -1 | ||
920 | }; | ||
921 | |||
922 | const short da830_usb20_pins[] __initdata = { | ||
923 | DA830_USB0_DRVVBUS, DA830_USB_REFCLKIN, | ||
924 | -1 | ||
925 | }; | ||
926 | |||
927 | const short da830_usb11_pins[] __initdata = { | ||
928 | DA830_USB_REFCLKIN, | ||
929 | -1 | ||
930 | }; | ||
931 | |||
932 | const short da830_uhpi_pins[] __initdata = { | ||
933 | DA830_UHPI_HD_0, DA830_UHPI_HD_1, DA830_UHPI_HD_2, DA830_UHPI_HD_3, | ||
934 | DA830_UHPI_HD_4, DA830_UHPI_HD_5, DA830_UHPI_HD_6, DA830_UHPI_HD_7, | ||
935 | DA830_UHPI_HD_8, DA830_UHPI_HD_9, DA830_UHPI_HD_10, DA830_UHPI_HD_11, | ||
936 | DA830_UHPI_HD_12, DA830_UHPI_HD_13, DA830_UHPI_HD_14, DA830_UHPI_HD_15, | ||
937 | DA830_UHPI_HCNTL0, DA830_UHPI_HCNTL1, DA830_UHPI_HHWIL, DA830_UHPI_HRNW, | ||
938 | DA830_NUHPI_HAS, DA830_NUHPI_HCS, DA830_NUHPI_HDS1, DA830_NUHPI_HDS2, | ||
939 | DA830_NUHPI_HINT, DA830_NUHPI_HRDY, | ||
940 | -1 | ||
941 | }; | ||
942 | |||
943 | const short da830_cpgmac_pins[] __initdata = { | ||
944 | DA830_RMII_TXD_0, DA830_RMII_TXD_1, DA830_RMII_TXEN, DA830_RMII_CRS_DV, | ||
945 | DA830_RMII_RXD_0, DA830_RMII_RXD_1, DA830_RMII_RXER, DA830_MDIO_CLK, | ||
946 | DA830_MDIO_D, | ||
947 | -1 | ||
948 | }; | ||
949 | |||
950 | const short da830_emif3c_pins[] __initdata = { | ||
951 | DA830_EMB_SDCKE, DA830_EMB_CLK_GLUE, DA830_EMB_CLK, DA830_NEMB_CS_0, | ||
952 | DA830_NEMB_CAS, DA830_NEMB_RAS, DA830_NEMB_WE, DA830_EMB_BA_1, | ||
953 | DA830_EMB_BA_0, DA830_EMB_A_0, DA830_EMB_A_1, DA830_EMB_A_2, | ||
954 | DA830_EMB_A_3, DA830_EMB_A_4, DA830_EMB_A_5, DA830_EMB_A_6, | ||
955 | DA830_EMB_A_7, DA830_EMB_A_8, DA830_EMB_A_9, DA830_EMB_A_10, | ||
956 | DA830_EMB_A_11, DA830_EMB_A_12, DA830_NEMB_WE_DQM_3, | ||
957 | DA830_NEMB_WE_DQM_2, DA830_EMB_D_0, DA830_EMB_D_1, DA830_EMB_D_2, | ||
958 | DA830_EMB_D_3, DA830_EMB_D_4, DA830_EMB_D_5, DA830_EMB_D_6, | ||
959 | DA830_EMB_D_7, DA830_EMB_D_8, DA830_EMB_D_9, DA830_EMB_D_10, | ||
960 | DA830_EMB_D_11, DA830_EMB_D_12, DA830_EMB_D_13, DA830_EMB_D_14, | ||
961 | DA830_EMB_D_15, DA830_EMB_D_16, DA830_EMB_D_17, DA830_EMB_D_18, | ||
962 | DA830_EMB_D_19, DA830_EMB_D_20, DA830_EMB_D_21, DA830_EMB_D_22, | ||
963 | DA830_EMB_D_23, DA830_EMB_D_24, DA830_EMB_D_25, DA830_EMB_D_26, | ||
964 | DA830_EMB_D_27, DA830_EMB_D_28, DA830_EMB_D_29, DA830_EMB_D_30, | ||
965 | DA830_EMB_D_31, DA830_NEMB_WE_DQM_1, DA830_NEMB_WE_DQM_0, | ||
966 | -1 | ||
967 | }; | ||
968 | |||
969 | const short da830_mcasp0_pins[] __initdata = { | ||
970 | DA830_AHCLKX0, DA830_ACLKX0, DA830_AFSX0, | ||
971 | DA830_AHCLKR0, DA830_ACLKR0, DA830_AFSR0, DA830_AMUTE0, | ||
972 | DA830_AXR0_0, DA830_AXR0_1, DA830_AXR0_2, DA830_AXR0_3, | ||
973 | DA830_AXR0_4, DA830_AXR0_5, DA830_AXR0_6, DA830_AXR0_7, | ||
974 | DA830_AXR0_8, DA830_AXR0_9, DA830_AXR0_10, DA830_AXR0_11, | ||
975 | DA830_AXR0_12, DA830_AXR0_13, DA830_AXR0_14, DA830_AXR0_15, | ||
976 | -1 | ||
977 | }; | ||
978 | |||
979 | const short da830_mcasp1_pins[] __initdata = { | ||
980 | DA830_AHCLKX1, DA830_ACLKX1, DA830_AFSX1, | ||
981 | DA830_AHCLKR1, DA830_ACLKR1, DA830_AFSR1, DA830_AMUTE1, | ||
982 | DA830_AXR1_0, DA830_AXR1_1, DA830_AXR1_2, DA830_AXR1_3, | ||
983 | DA830_AXR1_4, DA830_AXR1_5, DA830_AXR1_6, DA830_AXR1_7, | ||
984 | DA830_AXR1_8, DA830_AXR1_9, DA830_AXR1_10, DA830_AXR1_11, | ||
985 | -1 | ||
986 | }; | ||
987 | |||
988 | const short da830_mcasp2_pins[] __initdata = { | ||
989 | DA830_AHCLKX2, DA830_ACLKX2, DA830_AFSX2, | ||
990 | DA830_AHCLKR2, DA830_ACLKR2, DA830_AFSR2, DA830_AMUTE2, | ||
991 | DA830_AXR2_0, DA830_AXR2_1, DA830_AXR2_2, DA830_AXR2_3, | ||
992 | -1 | ||
993 | }; | ||
994 | |||
995 | const short da830_i2c0_pins[] __initdata = { | ||
996 | DA830_I2C0_SDA, DA830_I2C0_SCL, | ||
997 | -1 | ||
998 | }; | ||
999 | |||
1000 | const short da830_i2c1_pins[] __initdata = { | ||
1001 | DA830_I2C1_SCL, DA830_I2C1_SDA, | ||
1002 | -1 | ||
1003 | }; | ||
1004 | |||
1005 | const short da830_lcdcntl_pins[] __initdata = { | ||
1006 | DA830_LCD_D_0, DA830_LCD_D_1, DA830_LCD_D_2, DA830_LCD_D_3, | ||
1007 | DA830_LCD_D_4, DA830_LCD_D_5, DA830_LCD_D_6, DA830_LCD_D_7, | ||
1008 | DA830_LCD_D_8, DA830_LCD_D_9, DA830_LCD_D_10, DA830_LCD_D_11, | ||
1009 | DA830_LCD_D_12, DA830_LCD_D_13, DA830_LCD_D_14, DA830_LCD_D_15, | ||
1010 | DA830_LCD_PCLK, DA830_LCD_HSYNC, DA830_LCD_VSYNC, DA830_NLCD_AC_ENB_CS, | ||
1011 | DA830_LCD_MCLK, | ||
1012 | -1 | ||
1013 | }; | ||
1014 | |||
1015 | const short da830_pwm_pins[] __initdata = { | ||
1016 | DA830_ECAP0_APWM0, DA830_ECAP1_APWM1, DA830_EPWM0B, DA830_EPWM0A, | ||
1017 | DA830_EPWMSYNCI, DA830_EPWMSYNC0, DA830_ECAP2_APWM2, DA830_EHRPWMGLUETZ, | ||
1018 | DA830_EPWM2B, DA830_EPWM2A, DA830_EPWM1B, DA830_EPWM1A, | ||
1019 | -1 | ||
1020 | }; | ||
1021 | |||
1022 | const short da830_ecap0_pins[] __initdata = { | ||
1023 | DA830_ECAP0_APWM0, | ||
1024 | -1 | ||
1025 | }; | ||
1026 | |||
1027 | const short da830_ecap1_pins[] __initdata = { | ||
1028 | DA830_ECAP1_APWM1, | ||
1029 | -1 | ||
1030 | }; | ||
1031 | |||
1032 | const short da830_ecap2_pins[] __initdata = { | ||
1033 | DA830_ECAP2_APWM2, | ||
1034 | -1 | ||
1035 | }; | ||
1036 | |||
1037 | const short da830_eqep0_pins[] __initdata = { | ||
1038 | DA830_EQEP0I, DA830_EQEP0S, DA830_EQEP0A, DA830_EQEP0B, | ||
1039 | -1 | ||
1040 | }; | ||
1041 | |||
1042 | const short da830_eqep1_pins[] __initdata = { | ||
1043 | DA830_EQEP1I, DA830_EQEP1S, DA830_EQEP1A, DA830_EQEP1B, | ||
1044 | -1 | ||
1045 | }; | ||
1046 | |||
1047 | int da830_pinmux_setup(const short pins[]) | ||
1048 | { | ||
1049 | int i, error = -EINVAL; | ||
1050 | |||
1051 | if (pins) | ||
1052 | for (i = 0; pins[i] >= 0; i++) { | ||
1053 | error = davinci_cfg_reg(pins[i]); | ||
1054 | if (error) | ||
1055 | break; | ||
1056 | } | ||
1057 | |||
1058 | return error; | ||
1059 | } | ||
1060 | |||
1061 | /* FIQ are pri 0-1; otherwise 2-7, with 7 lowest priority */ | ||
1062 | static u8 da830_default_priorities[DA830_N_CP_INTC_IRQ] = { | ||
1063 | [IRQ_DA8XX_COMMTX] = 7, | ||
1064 | [IRQ_DA8XX_COMMRX] = 7, | ||
1065 | [IRQ_DA8XX_NINT] = 7, | ||
1066 | [IRQ_DA8XX_EVTOUT0] = 7, | ||
1067 | [IRQ_DA8XX_EVTOUT1] = 7, | ||
1068 | [IRQ_DA8XX_EVTOUT2] = 7, | ||
1069 | [IRQ_DA8XX_EVTOUT3] = 7, | ||
1070 | [IRQ_DA8XX_EVTOUT4] = 7, | ||
1071 | [IRQ_DA8XX_EVTOUT5] = 7, | ||
1072 | [IRQ_DA8XX_EVTOUT6] = 7, | ||
1073 | [IRQ_DA8XX_EVTOUT6] = 7, | ||
1074 | [IRQ_DA8XX_EVTOUT7] = 7, | ||
1075 | [IRQ_DA8XX_CCINT0] = 7, | ||
1076 | [IRQ_DA8XX_CCERRINT] = 7, | ||
1077 | [IRQ_DA8XX_TCERRINT0] = 7, | ||
1078 | [IRQ_DA8XX_AEMIFINT] = 7, | ||
1079 | [IRQ_DA8XX_I2CINT0] = 7, | ||
1080 | [IRQ_DA8XX_MMCSDINT0] = 7, | ||
1081 | [IRQ_DA8XX_MMCSDINT1] = 7, | ||
1082 | [IRQ_DA8XX_ALLINT0] = 7, | ||
1083 | [IRQ_DA8XX_RTC] = 7, | ||
1084 | [IRQ_DA8XX_SPINT0] = 7, | ||
1085 | [IRQ_DA8XX_TINT12_0] = 7, | ||
1086 | [IRQ_DA8XX_TINT34_0] = 7, | ||
1087 | [IRQ_DA8XX_TINT12_1] = 7, | ||
1088 | [IRQ_DA8XX_TINT34_1] = 7, | ||
1089 | [IRQ_DA8XX_UARTINT0] = 7, | ||
1090 | [IRQ_DA8XX_KEYMGRINT] = 7, | ||
1091 | [IRQ_DA8XX_SECINT] = 7, | ||
1092 | [IRQ_DA8XX_SECKEYERR] = 7, | ||
1093 | [IRQ_DA830_MPUERR] = 7, | ||
1094 | [IRQ_DA830_IOPUERR] = 7, | ||
1095 | [IRQ_DA830_BOOTCFGERR] = 7, | ||
1096 | [IRQ_DA8XX_CHIPINT0] = 7, | ||
1097 | [IRQ_DA8XX_CHIPINT1] = 7, | ||
1098 | [IRQ_DA8XX_CHIPINT2] = 7, | ||
1099 | [IRQ_DA8XX_CHIPINT3] = 7, | ||
1100 | [IRQ_DA8XX_TCERRINT1] = 7, | ||
1101 | [IRQ_DA8XX_C0_RX_THRESH_PULSE] = 7, | ||
1102 | [IRQ_DA8XX_C0_RX_PULSE] = 7, | ||
1103 | [IRQ_DA8XX_C0_TX_PULSE] = 7, | ||
1104 | [IRQ_DA8XX_C0_MISC_PULSE] = 7, | ||
1105 | [IRQ_DA8XX_C1_RX_THRESH_PULSE] = 7, | ||
1106 | [IRQ_DA8XX_C1_RX_PULSE] = 7, | ||
1107 | [IRQ_DA8XX_C1_TX_PULSE] = 7, | ||
1108 | [IRQ_DA8XX_C1_MISC_PULSE] = 7, | ||
1109 | [IRQ_DA8XX_MEMERR] = 7, | ||
1110 | [IRQ_DA8XX_GPIO0] = 7, | ||
1111 | [IRQ_DA8XX_GPIO1] = 7, | ||
1112 | [IRQ_DA8XX_GPIO2] = 7, | ||
1113 | [IRQ_DA8XX_GPIO3] = 7, | ||
1114 | [IRQ_DA8XX_GPIO4] = 7, | ||
1115 | [IRQ_DA8XX_GPIO5] = 7, | ||
1116 | [IRQ_DA8XX_GPIO6] = 7, | ||
1117 | [IRQ_DA8XX_GPIO7] = 7, | ||
1118 | [IRQ_DA8XX_GPIO8] = 7, | ||
1119 | [IRQ_DA8XX_I2CINT1] = 7, | ||
1120 | [IRQ_DA8XX_LCDINT] = 7, | ||
1121 | [IRQ_DA8XX_UARTINT1] = 7, | ||
1122 | [IRQ_DA8XX_MCASPINT] = 7, | ||
1123 | [IRQ_DA8XX_ALLINT1] = 7, | ||
1124 | [IRQ_DA8XX_SPINT1] = 7, | ||
1125 | [IRQ_DA8XX_UHPI_INT1] = 7, | ||
1126 | [IRQ_DA8XX_USB_INT] = 7, | ||
1127 | [IRQ_DA8XX_IRQN] = 7, | ||
1128 | [IRQ_DA8XX_RWAKEUP] = 7, | ||
1129 | [IRQ_DA8XX_UARTINT2] = 7, | ||
1130 | [IRQ_DA8XX_DFTSSINT] = 7, | ||
1131 | [IRQ_DA8XX_EHRPWM0] = 7, | ||
1132 | [IRQ_DA8XX_EHRPWM0TZ] = 7, | ||
1133 | [IRQ_DA8XX_EHRPWM1] = 7, | ||
1134 | [IRQ_DA8XX_EHRPWM1TZ] = 7, | ||
1135 | [IRQ_DA830_EHRPWM2] = 7, | ||
1136 | [IRQ_DA830_EHRPWM2TZ] = 7, | ||
1137 | [IRQ_DA8XX_ECAP0] = 7, | ||
1138 | [IRQ_DA8XX_ECAP1] = 7, | ||
1139 | [IRQ_DA8XX_ECAP2] = 7, | ||
1140 | [IRQ_DA830_EQEP0] = 7, | ||
1141 | [IRQ_DA830_EQEP1] = 7, | ||
1142 | [IRQ_DA830_T12CMPINT0_0] = 7, | ||
1143 | [IRQ_DA830_T12CMPINT1_0] = 7, | ||
1144 | [IRQ_DA830_T12CMPINT2_0] = 7, | ||
1145 | [IRQ_DA830_T12CMPINT3_0] = 7, | ||
1146 | [IRQ_DA830_T12CMPINT4_0] = 7, | ||
1147 | [IRQ_DA830_T12CMPINT5_0] = 7, | ||
1148 | [IRQ_DA830_T12CMPINT6_0] = 7, | ||
1149 | [IRQ_DA830_T12CMPINT7_0] = 7, | ||
1150 | [IRQ_DA830_T12CMPINT0_1] = 7, | ||
1151 | [IRQ_DA830_T12CMPINT1_1] = 7, | ||
1152 | [IRQ_DA830_T12CMPINT2_1] = 7, | ||
1153 | [IRQ_DA830_T12CMPINT3_1] = 7, | ||
1154 | [IRQ_DA830_T12CMPINT4_1] = 7, | ||
1155 | [IRQ_DA830_T12CMPINT5_1] = 7, | ||
1156 | [IRQ_DA830_T12CMPINT6_1] = 7, | ||
1157 | [IRQ_DA830_T12CMPINT7_1] = 7, | ||
1158 | [IRQ_DA8XX_ARMCLKSTOPREQ] = 7, | ||
1159 | }; | ||
1160 | |||
1161 | static struct map_desc da830_io_desc[] = { | ||
1162 | { | ||
1163 | .virtual = IO_VIRT, | ||
1164 | .pfn = __phys_to_pfn(IO_PHYS), | ||
1165 | .length = IO_SIZE, | ||
1166 | .type = MT_DEVICE | ||
1167 | }, | ||
1168 | { | ||
1169 | .virtual = DA8XX_CP_INTC_VIRT, | ||
1170 | .pfn = __phys_to_pfn(DA8XX_CP_INTC_BASE), | ||
1171 | .length = DA8XX_CP_INTC_SIZE, | ||
1172 | .type = MT_DEVICE | ||
1173 | }, | ||
1174 | }; | ||
1175 | |||
1176 | static void __iomem *da830_psc_bases[] = { | ||
1177 | IO_ADDRESS(DA830_PSC0_BASE), | ||
1178 | IO_ADDRESS(DA830_PSC1_BASE), | ||
1179 | }; | ||
1180 | |||
1181 | /* Contents of JTAG ID register used to identify exact cpu type */ | ||
1182 | static struct davinci_id da830_ids[] = { | ||
1183 | { | ||
1184 | .variant = 0x0, | ||
1185 | .part_no = 0xb7df, | ||
1186 | .manufacturer = 0x017, /* 0x02f >> 1 */ | ||
1187 | .cpu_id = DAVINCI_CPU_ID_DA830, | ||
1188 | .name = "da830/omap l137", | ||
1189 | }, | ||
1190 | }; | ||
1191 | |||
1192 | static struct davinci_timer_instance da830_timer_instance[2] = { | ||
1193 | { | ||
1194 | .base = IO_ADDRESS(DA830_TIMER64P0_BASE), | ||
1195 | .bottom_irq = IRQ_DA8XX_TINT12_0, | ||
1196 | .top_irq = IRQ_DA8XX_TINT34_0, | ||
1197 | .cmp_off = DA830_CMP12_0, | ||
1198 | .cmp_irq = IRQ_DA830_T12CMPINT0_0, | ||
1199 | }, | ||
1200 | { | ||
1201 | .base = IO_ADDRESS(DA830_TIMER64P1_BASE), | ||
1202 | .bottom_irq = IRQ_DA8XX_TINT12_1, | ||
1203 | .top_irq = IRQ_DA8XX_TINT34_1, | ||
1204 | .cmp_off = DA830_CMP12_0, | ||
1205 | .cmp_irq = IRQ_DA830_T12CMPINT0_1, | ||
1206 | }, | ||
1207 | }; | ||
1208 | |||
1209 | /* | ||
1210 | * T0_BOT: Timer 0, bottom : Used for clock_event & clocksource | ||
1211 | * T0_TOP: Timer 0, top : Used by DSP | ||
1212 | * T1_BOT, T1_TOP: Timer 1, bottom & top: Used for watchdog timer | ||
1213 | */ | ||
1214 | static struct davinci_timer_info da830_timer_info = { | ||
1215 | .timers = da830_timer_instance, | ||
1216 | .clockevent_id = T0_BOT, | ||
1217 | .clocksource_id = T0_BOT, | ||
1218 | }; | ||
1219 | |||
1220 | static struct davinci_soc_info davinci_soc_info_da830 = { | ||
1221 | .io_desc = da830_io_desc, | ||
1222 | .io_desc_num = ARRAY_SIZE(da830_io_desc), | ||
1223 | .jtag_id_base = IO_ADDRESS(DA830_JTAG_ID_REG), | ||
1224 | .ids = da830_ids, | ||
1225 | .ids_num = ARRAY_SIZE(da830_ids), | ||
1226 | .cpu_clks = da830_clks, | ||
1227 | .psc_bases = da830_psc_bases, | ||
1228 | .psc_bases_num = ARRAY_SIZE(da830_psc_bases), | ||
1229 | .pinmux_base = IO_ADDRESS(DA8XX_BOOT_CFG_BASE + 0x120), | ||
1230 | .pinmux_pins = da830_pins, | ||
1231 | .pinmux_pins_num = ARRAY_SIZE(da830_pins), | ||
1232 | .intc_base = (void __iomem *)DA8XX_CP_INTC_VIRT, | ||
1233 | .intc_type = DAVINCI_INTC_TYPE_CP_INTC, | ||
1234 | .intc_irq_prios = da830_default_priorities, | ||
1235 | .intc_irq_num = DA830_N_CP_INTC_IRQ, | ||
1236 | .timer_info = &da830_timer_info, | ||
1237 | .gpio_base = IO_ADDRESS(DA830_GPIO_BASE), | ||
1238 | .gpio_num = 128, | ||
1239 | .gpio_irq = IRQ_DA8XX_GPIO0, | ||
1240 | .serial_dev = &da8xx_serial_device, | ||
1241 | .emac_pdata = &da8xx_emac_pdata, | ||
1242 | }; | ||
1243 | |||
1244 | void __init da830_init(void) | ||
1245 | { | ||
1246 | davinci_common_init(&davinci_soc_info_da830); | ||
1247 | } | ||
diff --git a/arch/arm/mach-davinci/devices-da8xx.c b/arch/arm/mach-davinci/devices-da8xx.c new file mode 100644 index 000000000000..c367055ae9b9 --- /dev/null +++ b/arch/arm/mach-davinci/devices-da8xx.c | |||
@@ -0,0 +1,287 @@ | |||
1 | /* | ||
2 | * DA8XX/OMAP L1XX platform device data | ||
3 | * | ||
4 | * Copyright (c) 2007-2009, MontaVista Software, Inc. <source@mvista.com> | ||
5 | * Derived from code that was: | ||
6 | * Copyright (C) 2006 Komal Shah <komal_shah802003@yahoo.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License as published by | ||
10 | * the Free Software Foundation; either version 2 of the License, or | ||
11 | * (at your option) any later version. | ||
12 | */ | ||
13 | #include <linux/module.h> | ||
14 | #include <linux/kernel.h> | ||
15 | #include <linux/init.h> | ||
16 | #include <linux/platform_device.h> | ||
17 | #include <linux/dma-mapping.h> | ||
18 | #include <linux/serial_8250.h> | ||
19 | |||
20 | #include <mach/cputype.h> | ||
21 | #include <mach/common.h> | ||
22 | #include <mach/time.h> | ||
23 | #include <mach/da8xx.h> | ||
24 | |||
25 | #include "clock.h" | ||
26 | |||
27 | #define DA8XX_TPCC_BASE 0x01c00000 | ||
28 | #define DA8XX_TPTC0_BASE 0x01c08000 | ||
29 | #define DA8XX_TPTC1_BASE 0x01c08400 | ||
30 | #define DA8XX_WDOG_BASE 0x01c21000 /* DA8XX_TIMER64P1_BASE */ | ||
31 | #define DA8XX_I2C0_BASE 0x01c22000 | ||
32 | #define DA8XX_EMAC_CPPI_PORT_BASE 0x01e20000 | ||
33 | #define DA8XX_EMAC_CPGMACSS_BASE 0x01e22000 | ||
34 | #define DA8XX_EMAC_CPGMAC_BASE 0x01e23000 | ||
35 | #define DA8XX_EMAC_MDIO_BASE 0x01e24000 | ||
36 | #define DA8XX_GPIO_BASE 0x01e26000 | ||
37 | #define DA8XX_I2C1_BASE 0x01e28000 | ||
38 | |||
39 | #define DA8XX_EMAC_CTRL_REG_OFFSET 0x3000 | ||
40 | #define DA8XX_EMAC_MOD_REG_OFFSET 0x2000 | ||
41 | #define DA8XX_EMAC_RAM_OFFSET 0x0000 | ||
42 | #define DA8XX_MDIO_REG_OFFSET 0x4000 | ||
43 | #define DA8XX_EMAC_CTRL_RAM_SIZE SZ_8K | ||
44 | |||
45 | static struct plat_serial8250_port da8xx_serial_pdata[] = { | ||
46 | { | ||
47 | .mapbase = DA8XX_UART0_BASE, | ||
48 | .irq = IRQ_DA8XX_UARTINT0, | ||
49 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | | ||
50 | UPF_IOREMAP, | ||
51 | .iotype = UPIO_MEM, | ||
52 | .regshift = 2, | ||
53 | }, | ||
54 | { | ||
55 | .mapbase = DA8XX_UART1_BASE, | ||
56 | .irq = IRQ_DA8XX_UARTINT1, | ||
57 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | | ||
58 | UPF_IOREMAP, | ||
59 | .iotype = UPIO_MEM, | ||
60 | .regshift = 2, | ||
61 | }, | ||
62 | { | ||
63 | .mapbase = DA8XX_UART2_BASE, | ||
64 | .irq = IRQ_DA8XX_UARTINT2, | ||
65 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | | ||
66 | UPF_IOREMAP, | ||
67 | .iotype = UPIO_MEM, | ||
68 | .regshift = 2, | ||
69 | }, | ||
70 | { | ||
71 | .flags = 0, | ||
72 | }, | ||
73 | }; | ||
74 | |||
75 | struct platform_device da8xx_serial_device = { | ||
76 | .name = "serial8250", | ||
77 | .id = PLAT8250_DEV_PLATFORM, | ||
78 | .dev = { | ||
79 | .platform_data = da8xx_serial_pdata, | ||
80 | }, | ||
81 | }; | ||
82 | |||
83 | static const s8 da8xx_dma_chan_no_event[] = { | ||
84 | 20, 21, | ||
85 | -1 | ||
86 | }; | ||
87 | |||
88 | static const s8 da8xx_queue_tc_mapping[][2] = { | ||
89 | /* {event queue no, TC no} */ | ||
90 | {0, 0}, | ||
91 | {1, 1}, | ||
92 | {-1, -1} | ||
93 | }; | ||
94 | |||
95 | static const s8 da8xx_queue_priority_mapping[][2] = { | ||
96 | /* {event queue no, Priority} */ | ||
97 | {0, 3}, | ||
98 | {1, 7}, | ||
99 | {-1, -1} | ||
100 | }; | ||
101 | |||
102 | static struct edma_soc_info da8xx_edma_info[] = { | ||
103 | { | ||
104 | .n_channel = 32, | ||
105 | .n_region = 4, | ||
106 | .n_slot = 128, | ||
107 | .n_tc = 2, | ||
108 | .n_cc = 1, | ||
109 | .noevent = da8xx_dma_chan_no_event, | ||
110 | .queue_tc_mapping = da8xx_queue_tc_mapping, | ||
111 | .queue_priority_mapping = da8xx_queue_priority_mapping, | ||
112 | }, | ||
113 | }; | ||
114 | |||
115 | static struct resource da8xx_edma_resources[] = { | ||
116 | { | ||
117 | .name = "edma_cc0", | ||
118 | .start = DA8XX_TPCC_BASE, | ||
119 | .end = DA8XX_TPCC_BASE + SZ_32K - 1, | ||
120 | .flags = IORESOURCE_MEM, | ||
121 | }, | ||
122 | { | ||
123 | .name = "edma_tc0", | ||
124 | .start = DA8XX_TPTC0_BASE, | ||
125 | .end = DA8XX_TPTC0_BASE + SZ_1K - 1, | ||
126 | .flags = IORESOURCE_MEM, | ||
127 | }, | ||
128 | { | ||
129 | .name = "edma_tc1", | ||
130 | .start = DA8XX_TPTC1_BASE, | ||
131 | .end = DA8XX_TPTC1_BASE + SZ_1K - 1, | ||
132 | .flags = IORESOURCE_MEM, | ||
133 | }, | ||
134 | { | ||
135 | .name = "edma0", | ||
136 | .start = IRQ_DA8XX_TCERRINT0, | ||
137 | .flags = IORESOURCE_IRQ, | ||
138 | }, | ||
139 | { | ||
140 | .name = "edma0_err", | ||
141 | .start = IRQ_DA8XX_CCERRINT, | ||
142 | .flags = IORESOURCE_IRQ, | ||
143 | }, | ||
144 | }; | ||
145 | |||
146 | static struct platform_device da8xx_edma_device = { | ||
147 | .name = "edma", | ||
148 | .id = -1, | ||
149 | .dev = { | ||
150 | .platform_data = da8xx_edma_info, | ||
151 | }, | ||
152 | .num_resources = ARRAY_SIZE(da8xx_edma_resources), | ||
153 | .resource = da8xx_edma_resources, | ||
154 | }; | ||
155 | |||
156 | int __init da8xx_register_edma(void) | ||
157 | { | ||
158 | return platform_device_register(&da8xx_edma_device); | ||
159 | } | ||
160 | |||
161 | static struct resource da8xx_i2c_resources0[] = { | ||
162 | { | ||
163 | .start = DA8XX_I2C0_BASE, | ||
164 | .end = DA8XX_I2C0_BASE + SZ_4K - 1, | ||
165 | .flags = IORESOURCE_MEM, | ||
166 | }, | ||
167 | { | ||
168 | .start = IRQ_DA8XX_I2CINT0, | ||
169 | .end = IRQ_DA8XX_I2CINT0, | ||
170 | .flags = IORESOURCE_IRQ, | ||
171 | }, | ||
172 | }; | ||
173 | |||
174 | static struct platform_device da8xx_i2c_device0 = { | ||
175 | .name = "i2c_davinci", | ||
176 | .id = 1, | ||
177 | .num_resources = ARRAY_SIZE(da8xx_i2c_resources0), | ||
178 | .resource = da8xx_i2c_resources0, | ||
179 | }; | ||
180 | |||
181 | static struct resource da8xx_i2c_resources1[] = { | ||
182 | { | ||
183 | .start = DA8XX_I2C1_BASE, | ||
184 | .end = DA8XX_I2C1_BASE + SZ_4K - 1, | ||
185 | .flags = IORESOURCE_MEM, | ||
186 | }, | ||
187 | { | ||
188 | .start = IRQ_DA8XX_I2CINT1, | ||
189 | .end = IRQ_DA8XX_I2CINT1, | ||
190 | .flags = IORESOURCE_IRQ, | ||
191 | }, | ||
192 | }; | ||
193 | |||
194 | static struct platform_device da8xx_i2c_device1 = { | ||
195 | .name = "i2c_davinci", | ||
196 | .id = 2, | ||
197 | .num_resources = ARRAY_SIZE(da8xx_i2c_resources1), | ||
198 | .resource = da8xx_i2c_resources1, | ||
199 | }; | ||
200 | |||
201 | int __init da8xx_register_i2c(int instance, | ||
202 | struct davinci_i2c_platform_data *pdata) | ||
203 | { | ||
204 | struct platform_device *pdev; | ||
205 | |||
206 | if (instance == 0) | ||
207 | pdev = &da8xx_i2c_device0; | ||
208 | else if (instance == 1) | ||
209 | pdev = &da8xx_i2c_device1; | ||
210 | else | ||
211 | return -EINVAL; | ||
212 | |||
213 | pdev->dev.platform_data = pdata; | ||
214 | return platform_device_register(pdev); | ||
215 | } | ||
216 | |||
217 | static struct resource da8xx_watchdog_resources[] = { | ||
218 | { | ||
219 | .start = DA8XX_WDOG_BASE, | ||
220 | .end = DA8XX_WDOG_BASE + SZ_4K - 1, | ||
221 | .flags = IORESOURCE_MEM, | ||
222 | }, | ||
223 | }; | ||
224 | |||
225 | struct platform_device davinci_wdt_device = { | ||
226 | .name = "watchdog", | ||
227 | .id = -1, | ||
228 | .num_resources = ARRAY_SIZE(da8xx_watchdog_resources), | ||
229 | .resource = da8xx_watchdog_resources, | ||
230 | }; | ||
231 | |||
232 | int __init da8xx_register_watchdog(void) | ||
233 | { | ||
234 | return platform_device_register(&davinci_wdt_device); | ||
235 | } | ||
236 | |||
237 | static struct resource da8xx_emac_resources[] = { | ||
238 | { | ||
239 | .start = DA8XX_EMAC_CPPI_PORT_BASE, | ||
240 | .end = DA8XX_EMAC_CPPI_PORT_BASE + 0x5000 - 1, | ||
241 | .flags = IORESOURCE_MEM, | ||
242 | }, | ||
243 | { | ||
244 | .start = IRQ_DA8XX_C0_RX_THRESH_PULSE, | ||
245 | .end = IRQ_DA8XX_C0_RX_THRESH_PULSE, | ||
246 | .flags = IORESOURCE_IRQ, | ||
247 | }, | ||
248 | { | ||
249 | .start = IRQ_DA8XX_C0_RX_PULSE, | ||
250 | .end = IRQ_DA8XX_C0_RX_PULSE, | ||
251 | .flags = IORESOURCE_IRQ, | ||
252 | }, | ||
253 | { | ||
254 | .start = IRQ_DA8XX_C0_TX_PULSE, | ||
255 | .end = IRQ_DA8XX_C0_TX_PULSE, | ||
256 | .flags = IORESOURCE_IRQ, | ||
257 | }, | ||
258 | { | ||
259 | .start = IRQ_DA8XX_C0_MISC_PULSE, | ||
260 | .end = IRQ_DA8XX_C0_MISC_PULSE, | ||
261 | .flags = IORESOURCE_IRQ, | ||
262 | }, | ||
263 | }; | ||
264 | |||
265 | struct emac_platform_data da8xx_emac_pdata = { | ||
266 | .ctrl_reg_offset = DA8XX_EMAC_CTRL_REG_OFFSET, | ||
267 | .ctrl_mod_reg_offset = DA8XX_EMAC_MOD_REG_OFFSET, | ||
268 | .ctrl_ram_offset = DA8XX_EMAC_RAM_OFFSET, | ||
269 | .mdio_reg_offset = DA8XX_MDIO_REG_OFFSET, | ||
270 | .ctrl_ram_size = DA8XX_EMAC_CTRL_RAM_SIZE, | ||
271 | .version = EMAC_VERSION_2, | ||
272 | }; | ||
273 | |||
274 | static struct platform_device da8xx_emac_device = { | ||
275 | .name = "davinci_emac", | ||
276 | .id = 1, | ||
277 | .dev = { | ||
278 | .platform_data = &da8xx_emac_pdata, | ||
279 | }, | ||
280 | .num_resources = ARRAY_SIZE(da8xx_emac_resources), | ||
281 | .resource = da8xx_emac_resources, | ||
282 | }; | ||
283 | |||
284 | int __init da8xx_register_emac(void) | ||
285 | { | ||
286 | return platform_device_register(&da8xx_emac_device); | ||
287 | } | ||
diff --git a/arch/arm/mach-davinci/include/mach/cputype.h b/arch/arm/mach-davinci/include/mach/cputype.h index 56b92d49e293..fd41189e5c62 100644 --- a/arch/arm/mach-davinci/include/mach/cputype.h +++ b/arch/arm/mach-davinci/include/mach/cputype.h | |||
@@ -31,6 +31,7 @@ struct davinci_id { | |||
31 | #define DAVINCI_CPU_ID_DM6467 0x64670000 | 31 | #define DAVINCI_CPU_ID_DM6467 0x64670000 |
32 | #define DAVINCI_CPU_ID_DM355 0x03550000 | 32 | #define DAVINCI_CPU_ID_DM355 0x03550000 |
33 | #define DAVINCI_CPU_ID_DM365 0x03650000 | 33 | #define DAVINCI_CPU_ID_DM365 0x03650000 |
34 | #define DAVINCI_CPU_ID_DA830 0x08300000 | ||
34 | 35 | ||
35 | #define IS_DAVINCI_CPU(type, id) \ | 36 | #define IS_DAVINCI_CPU(type, id) \ |
36 | static inline int is_davinci_ ##type(void) \ | 37 | static inline int is_davinci_ ##type(void) \ |
@@ -42,6 +43,7 @@ IS_DAVINCI_CPU(dm644x, DAVINCI_CPU_ID_DM6446) | |||
42 | IS_DAVINCI_CPU(dm646x, DAVINCI_CPU_ID_DM6467) | 43 | IS_DAVINCI_CPU(dm646x, DAVINCI_CPU_ID_DM6467) |
43 | IS_DAVINCI_CPU(dm355, DAVINCI_CPU_ID_DM355) | 44 | IS_DAVINCI_CPU(dm355, DAVINCI_CPU_ID_DM355) |
44 | IS_DAVINCI_CPU(dm365, DAVINCI_CPU_ID_DM365) | 45 | IS_DAVINCI_CPU(dm365, DAVINCI_CPU_ID_DM365) |
46 | IS_DAVINCI_CPU(da830, DAVINCI_CPU_ID_DA830) | ||
45 | 47 | ||
46 | #ifdef CONFIG_ARCH_DAVINCI_DM644x | 48 | #ifdef CONFIG_ARCH_DAVINCI_DM644x |
47 | #define cpu_is_davinci_dm644x() is_davinci_dm644x() | 49 | #define cpu_is_davinci_dm644x() is_davinci_dm644x() |
@@ -67,4 +69,10 @@ IS_DAVINCI_CPU(dm365, DAVINCI_CPU_ID_DM365) | |||
67 | #define cpu_is_davinci_dm365() 0 | 69 | #define cpu_is_davinci_dm365() 0 |
68 | #endif | 70 | #endif |
69 | 71 | ||
72 | #ifdef CONFIG_ARCH_DAVINCI_DA830 | ||
73 | #define cpu_is_davinci_da830() is_davinci_da830() | ||
74 | #else | ||
75 | #define cpu_is_davinci_da830() 0 | ||
76 | #endif | ||
77 | |||
70 | #endif | 78 | #endif |
diff --git a/arch/arm/mach-davinci/include/mach/da8xx.h b/arch/arm/mach-davinci/include/mach/da8xx.h new file mode 100644 index 000000000000..084db271c7c4 --- /dev/null +++ b/arch/arm/mach-davinci/include/mach/da8xx.h | |||
@@ -0,0 +1,69 @@ | |||
1 | /* | ||
2 | * Chip specific defines for DA8XX/OMAP L1XX SoC | ||
3 | * | ||
4 | * Author: Mark A. Greer <mgreer@mvista.com> | ||
5 | * | ||
6 | * 2007, 2009 (c) MontaVista Software, Inc. This file is licensed under | ||
7 | * the terms of the GNU General Public License version 2. This program | ||
8 | * is licensed "as is" without any warranty of any kind, whether express | ||
9 | * or implied. | ||
10 | */ | ||
11 | #ifndef __ASM_ARCH_DAVINCI_DA8XX_H | ||
12 | #define __ASM_ARCH_DAVINCI_DA8XX_H | ||
13 | |||
14 | #include <mach/serial.h> | ||
15 | #include <mach/edma.h> | ||
16 | #include <mach/i2c.h> | ||
17 | #include <mach/emac.h> | ||
18 | |||
19 | /* | ||
20 | * The cp_intc interrupt controller for the da8xx isn't in the same | ||
21 | * chunk of physical memory space as the other registers (like it is | ||
22 | * on the davincis) so it needs to be mapped separately. It will be | ||
23 | * mapped early on when the I/O space is mapped and we'll put it just | ||
24 | * before the I/O space in the processor's virtual memory space. | ||
25 | */ | ||
26 | #define DA8XX_CP_INTC_BASE 0xfffee000 | ||
27 | #define DA8XX_CP_INTC_SIZE SZ_8K | ||
28 | #define DA8XX_CP_INTC_VIRT (IO_VIRT - DA8XX_CP_INTC_SIZE - SZ_4K) | ||
29 | |||
30 | #define DA8XX_BOOT_CFG_BASE (IO_PHYS + 0x14000) | ||
31 | |||
32 | void __init da830_init(void); | ||
33 | |||
34 | int da8xx_register_edma(void); | ||
35 | int da8xx_register_i2c(int instance, struct davinci_i2c_platform_data *pdata); | ||
36 | int da8xx_register_watchdog(void); | ||
37 | int da8xx_register_emac(void); | ||
38 | |||
39 | extern struct platform_device da8xx_serial_device; | ||
40 | extern struct emac_platform_data da8xx_emac_pdata; | ||
41 | |||
42 | extern const short da830_emif25_pins[]; | ||
43 | extern const short da830_spi0_pins[]; | ||
44 | extern const short da830_spi1_pins[]; | ||
45 | extern const short da830_mmc_sd_pins[]; | ||
46 | extern const short da830_uart0_pins[]; | ||
47 | extern const short da830_uart1_pins[]; | ||
48 | extern const short da830_uart2_pins[]; | ||
49 | extern const short da830_usb20_pins[]; | ||
50 | extern const short da830_usb11_pins[]; | ||
51 | extern const short da830_uhpi_pins[]; | ||
52 | extern const short da830_cpgmac_pins[]; | ||
53 | extern const short da830_emif3c_pins[]; | ||
54 | extern const short da830_mcasp0_pins[]; | ||
55 | extern const short da830_mcasp1_pins[]; | ||
56 | extern const short da830_mcasp2_pins[]; | ||
57 | extern const short da830_i2c0_pins[]; | ||
58 | extern const short da830_i2c1_pins[]; | ||
59 | extern const short da830_lcdcntl_pins[]; | ||
60 | extern const short da830_pwm_pins[]; | ||
61 | extern const short da830_ecap0_pins[]; | ||
62 | extern const short da830_ecap1_pins[]; | ||
63 | extern const short da830_ecap2_pins[]; | ||
64 | extern const short da830_eqep0_pins[]; | ||
65 | extern const short da830_eqep1_pins[]; | ||
66 | |||
67 | int da830_pinmux_setup(const short pins[]); | ||
68 | |||
69 | #endif /* __ASM_ARCH_DAVINCI_DA8XX_H */ | ||
diff --git a/arch/arm/mach-davinci/include/mach/edma.h b/arch/arm/mach-davinci/include/mach/edma.h index ba2ebdd058a0..a85cbedc9b0a 100644 --- a/arch/arm/mach-davinci/include/mach/edma.h +++ b/arch/arm/mach-davinci/include/mach/edma.h | |||
@@ -139,6 +139,54 @@ struct edmacc_param { | |||
139 | #define DAVINCI_DMA_PWM1 53 | 139 | #define DAVINCI_DMA_PWM1 53 |
140 | #define DAVINCI_DMA_PWM2 54 | 140 | #define DAVINCI_DMA_PWM2 54 |
141 | 141 | ||
142 | /* DA830 specific EDMA3 information */ | ||
143 | #define EDMA_DA830_NUM_DMACH 32 | ||
144 | #define EDMA_DA830_NUM_TCC 32 | ||
145 | #define EDMA_DA830_NUM_PARAMENTRY 128 | ||
146 | #define EDMA_DA830_NUM_EVQUE 2 | ||
147 | #define EDMA_DA830_NUM_TC 2 | ||
148 | #define EDMA_DA830_CHMAP_EXIST 0 | ||
149 | #define EDMA_DA830_NUM_REGIONS 4 | ||
150 | #define DA830_DMACH2EVENT_MAP0 0x000FC03Fu | ||
151 | #define DA830_DMACH2EVENT_MAP1 0x00000000u | ||
152 | #define DA830_EDMA_ARM_OWN 0x30FFCCFFu | ||
153 | |||
154 | /* DA830 specific EDMA3 Events Information */ | ||
155 | enum DA830_edma_ch { | ||
156 | DA830_DMACH_MCASP0_RX, | ||
157 | DA830_DMACH_MCASP0_TX, | ||
158 | DA830_DMACH_MCASP1_RX, | ||
159 | DA830_DMACH_MCASP1_TX, | ||
160 | DA830_DMACH_MCASP2_RX, | ||
161 | DA830_DMACH_MCASP2_TX, | ||
162 | DA830_DMACH_GPIO_BNK0INT, | ||
163 | DA830_DMACH_GPIO_BNK1INT, | ||
164 | DA830_DMACH_UART0_RX, | ||
165 | DA830_DMACH_UART0_TX, | ||
166 | DA830_DMACH_TMR64P0_EVTOUT12, | ||
167 | DA830_DMACH_TMR64P0_EVTOUT34, | ||
168 | DA830_DMACH_UART1_RX, | ||
169 | DA830_DMACH_UART1_TX, | ||
170 | DA830_DMACH_SPI0_RX, | ||
171 | DA830_DMACH_SPI0_TX, | ||
172 | DA830_DMACH_MMCSD_RX, | ||
173 | DA830_DMACH_MMCSD_TX, | ||
174 | DA830_DMACH_SPI1_RX, | ||
175 | DA830_DMACH_SPI1_TX, | ||
176 | DA830_DMACH_DMAX_EVTOUT6, | ||
177 | DA830_DMACH_DMAX_EVTOUT7, | ||
178 | DA830_DMACH_GPIO_BNK2INT, | ||
179 | DA830_DMACH_GPIO_BNK3INT, | ||
180 | DA830_DMACH_I2C0_RX, | ||
181 | DA830_DMACH_I2C0_TX, | ||
182 | DA830_DMACH_I2C1_RX, | ||
183 | DA830_DMACH_I2C1_TX, | ||
184 | DA830_DMACH_GPIO_BNK4INT, | ||
185 | DA830_DMACH_GPIO_BNK5INT, | ||
186 | DA830_DMACH_UART2_RX, | ||
187 | DA830_DMACH_UART2_TX | ||
188 | }; | ||
189 | |||
142 | /*ch_status paramater of callback function possible values*/ | 190 | /*ch_status paramater of callback function possible values*/ |
143 | #define DMA_COMPLETE 1 | 191 | #define DMA_COMPLETE 1 |
144 | #define DMA_CC_ERROR 2 | 192 | #define DMA_CC_ERROR 2 |
diff --git a/arch/arm/mach-davinci/include/mach/irqs.h b/arch/arm/mach-davinci/include/mach/irqs.h index 0d34f2fb0993..735e378d27ee 100644 --- a/arch/arm/mach-davinci/include/mach/irqs.h +++ b/arch/arm/mach-davinci/include/mach/irqs.h | |||
@@ -99,9 +99,6 @@ | |||
99 | #define IRQ_EMUINT 63 | 99 | #define IRQ_EMUINT 63 |
100 | 100 | ||
101 | #define DAVINCI_N_AINTC_IRQ 64 | 101 | #define DAVINCI_N_AINTC_IRQ 64 |
102 | #define DAVINCI_N_GPIO 104 | ||
103 | |||
104 | #define NR_IRQS (DAVINCI_N_AINTC_IRQ + DAVINCI_N_GPIO) | ||
105 | 102 | ||
106 | #define ARCH_TIMER_IRQ IRQ_TINT1_TINT34 | 103 | #define ARCH_TIMER_IRQ IRQ_TINT1_TINT34 |
107 | 104 | ||
@@ -242,4 +239,110 @@ | |||
242 | #define IRQ_DM365_TCERRINT3 62 | 239 | #define IRQ_DM365_TCERRINT3 62 |
243 | #define IRQ_DM365_EMUINT 63 | 240 | #define IRQ_DM365_EMUINT 63 |
244 | 241 | ||
242 | /* DA8XX interrupts */ | ||
243 | #define IRQ_DA8XX_COMMTX 0 | ||
244 | #define IRQ_DA8XX_COMMRX 1 | ||
245 | #define IRQ_DA8XX_NINT 2 | ||
246 | #define IRQ_DA8XX_EVTOUT0 3 | ||
247 | #define IRQ_DA8XX_EVTOUT1 4 | ||
248 | #define IRQ_DA8XX_EVTOUT2 5 | ||
249 | #define IRQ_DA8XX_EVTOUT3 6 | ||
250 | #define IRQ_DA8XX_EVTOUT4 7 | ||
251 | #define IRQ_DA8XX_EVTOUT5 8 | ||
252 | #define IRQ_DA8XX_EVTOUT6 9 | ||
253 | #define IRQ_DA8XX_EVTOUT7 10 | ||
254 | #define IRQ_DA8XX_CCINT0 11 | ||
255 | #define IRQ_DA8XX_CCERRINT 12 | ||
256 | #define IRQ_DA8XX_TCERRINT0 13 | ||
257 | #define IRQ_DA8XX_AEMIFINT 14 | ||
258 | #define IRQ_DA8XX_I2CINT0 15 | ||
259 | #define IRQ_DA8XX_MMCSDINT0 16 | ||
260 | #define IRQ_DA8XX_MMCSDINT1 17 | ||
261 | #define IRQ_DA8XX_ALLINT0 18 | ||
262 | #define IRQ_DA8XX_RTC 19 | ||
263 | #define IRQ_DA8XX_SPINT0 20 | ||
264 | #define IRQ_DA8XX_TINT12_0 21 | ||
265 | #define IRQ_DA8XX_TINT34_0 22 | ||
266 | #define IRQ_DA8XX_TINT12_1 23 | ||
267 | #define IRQ_DA8XX_TINT34_1 24 | ||
268 | #define IRQ_DA8XX_UARTINT0 25 | ||
269 | #define IRQ_DA8XX_KEYMGRINT 26 | ||
270 | #define IRQ_DA8XX_SECINT 26 | ||
271 | #define IRQ_DA8XX_SECKEYERR 26 | ||
272 | #define IRQ_DA8XX_CHIPINT0 28 | ||
273 | #define IRQ_DA8XX_CHIPINT1 29 | ||
274 | #define IRQ_DA8XX_CHIPINT2 30 | ||
275 | #define IRQ_DA8XX_CHIPINT3 31 | ||
276 | #define IRQ_DA8XX_TCERRINT1 32 | ||
277 | #define IRQ_DA8XX_C0_RX_THRESH_PULSE 33 | ||
278 | #define IRQ_DA8XX_C0_RX_PULSE 34 | ||
279 | #define IRQ_DA8XX_C0_TX_PULSE 35 | ||
280 | #define IRQ_DA8XX_C0_MISC_PULSE 36 | ||
281 | #define IRQ_DA8XX_C1_RX_THRESH_PULSE 37 | ||
282 | #define IRQ_DA8XX_C1_RX_PULSE 38 | ||
283 | #define IRQ_DA8XX_C1_TX_PULSE 39 | ||
284 | #define IRQ_DA8XX_C1_MISC_PULSE 40 | ||
285 | #define IRQ_DA8XX_MEMERR 41 | ||
286 | #define IRQ_DA8XX_GPIO0 42 | ||
287 | #define IRQ_DA8XX_GPIO1 43 | ||
288 | #define IRQ_DA8XX_GPIO2 44 | ||
289 | #define IRQ_DA8XX_GPIO3 45 | ||
290 | #define IRQ_DA8XX_GPIO4 46 | ||
291 | #define IRQ_DA8XX_GPIO5 47 | ||
292 | #define IRQ_DA8XX_GPIO6 48 | ||
293 | #define IRQ_DA8XX_GPIO7 49 | ||
294 | #define IRQ_DA8XX_GPIO8 50 | ||
295 | #define IRQ_DA8XX_I2CINT1 51 | ||
296 | #define IRQ_DA8XX_LCDINT 52 | ||
297 | #define IRQ_DA8XX_UARTINT1 53 | ||
298 | #define IRQ_DA8XX_MCASPINT 54 | ||
299 | #define IRQ_DA8XX_ALLINT1 55 | ||
300 | #define IRQ_DA8XX_SPINT1 56 | ||
301 | #define IRQ_DA8XX_UHPI_INT1 57 | ||
302 | #define IRQ_DA8XX_USB_INT 58 | ||
303 | #define IRQ_DA8XX_IRQN 59 | ||
304 | #define IRQ_DA8XX_RWAKEUP 60 | ||
305 | #define IRQ_DA8XX_UARTINT2 61 | ||
306 | #define IRQ_DA8XX_DFTSSINT 62 | ||
307 | #define IRQ_DA8XX_EHRPWM0 63 | ||
308 | #define IRQ_DA8XX_EHRPWM0TZ 64 | ||
309 | #define IRQ_DA8XX_EHRPWM1 65 | ||
310 | #define IRQ_DA8XX_EHRPWM1TZ 66 | ||
311 | #define IRQ_DA8XX_ECAP0 69 | ||
312 | #define IRQ_DA8XX_ECAP1 70 | ||
313 | #define IRQ_DA8XX_ECAP2 71 | ||
314 | #define IRQ_DA8XX_ARMCLKSTOPREQ 90 | ||
315 | |||
316 | /* DA830 specific interrupts */ | ||
317 | #define IRQ_DA830_MPUERR 27 | ||
318 | #define IRQ_DA830_IOPUERR 27 | ||
319 | #define IRQ_DA830_BOOTCFGERR 27 | ||
320 | #define IRQ_DA830_EHRPWM2 67 | ||
321 | #define IRQ_DA830_EHRPWM2TZ 68 | ||
322 | #define IRQ_DA830_EQEP0 72 | ||
323 | #define IRQ_DA830_EQEP1 73 | ||
324 | #define IRQ_DA830_T12CMPINT0_0 74 | ||
325 | #define IRQ_DA830_T12CMPINT1_0 75 | ||
326 | #define IRQ_DA830_T12CMPINT2_0 76 | ||
327 | #define IRQ_DA830_T12CMPINT3_0 77 | ||
328 | #define IRQ_DA830_T12CMPINT4_0 78 | ||
329 | #define IRQ_DA830_T12CMPINT5_0 79 | ||
330 | #define IRQ_DA830_T12CMPINT6_0 80 | ||
331 | #define IRQ_DA830_T12CMPINT7_0 81 | ||
332 | #define IRQ_DA830_T12CMPINT0_1 82 | ||
333 | #define IRQ_DA830_T12CMPINT1_1 83 | ||
334 | #define IRQ_DA830_T12CMPINT2_1 84 | ||
335 | #define IRQ_DA830_T12CMPINT3_1 85 | ||
336 | #define IRQ_DA830_T12CMPINT4_1 86 | ||
337 | #define IRQ_DA830_T12CMPINT5_1 87 | ||
338 | #define IRQ_DA830_T12CMPINT6_1 88 | ||
339 | #define IRQ_DA830_T12CMPINT7_1 89 | ||
340 | |||
341 | #define DA830_N_CP_INTC_IRQ 96 | ||
342 | |||
343 | /* da830 currently has the most gpio pins (128) */ | ||
344 | #define DAVINCI_N_GPIO 128 | ||
345 | /* da830 currently has the most irqs so use DA830_N_CP_INTC_IRQ */ | ||
346 | #define NR_IRQS (DA830_N_CP_INTC_IRQ + DAVINCI_N_GPIO) | ||
347 | |||
245 | #endif /* __ASM_ARCH_IRQS_H */ | 348 | #endif /* __ASM_ARCH_IRQS_H */ |
diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h index c712c7cdf38f..80309aed534a 100644 --- a/arch/arm/mach-davinci/include/mach/memory.h +++ b/arch/arm/mach-davinci/include/mach/memory.h | |||
@@ -20,9 +20,16 @@ | |||
20 | /************************************************************************** | 20 | /************************************************************************** |
21 | * Definitions | 21 | * Definitions |
22 | **************************************************************************/ | 22 | **************************************************************************/ |
23 | #define DAVINCI_DDR_BASE 0x80000000 | 23 | #define DAVINCI_DDR_BASE 0x80000000 |
24 | #define DA8XX_DDR_BASE 0xc0000000 | ||
24 | 25 | ||
26 | #if defined(CONFIG_ARCH_DAVINCI_DA8XX) && defined(CONFIG_ARCH_DAVINCI_DMx) | ||
27 | #error Cannot enable DaVinci and DA8XX platforms concurrently | ||
28 | #elif defined(CONFIG_ARCH_DAVINCI_DA8XX) | ||
29 | #define PHYS_OFFSET DA8XX_DDR_BASE | ||
30 | #else | ||
25 | #define PHYS_OFFSET DAVINCI_DDR_BASE | 31 | #define PHYS_OFFSET DAVINCI_DDR_BASE |
32 | #endif | ||
26 | 33 | ||
27 | /* | 34 | /* |
28 | * Increase size of DMA-consistent memory region | 35 | * Increase size of DMA-consistent memory region |
diff --git a/arch/arm/mach-davinci/include/mach/mux.h b/arch/arm/mach-davinci/include/mach/mux.h index 55765e1fdb78..ae4f6dd3623c 100644 --- a/arch/arm/mach-davinci/include/mach/mux.h +++ b/arch/arm/mach-davinci/include/mach/mux.h | |||
@@ -242,6 +242,410 @@ enum davinci_dm365_index { | |||
242 | DM365_EVT26_MMC0_RX, | 242 | DM365_EVT26_MMC0_RX, |
243 | }; | 243 | }; |
244 | 244 | ||
245 | enum da830_index { | ||
246 | DA830_GPIO7_14, | ||
247 | DA830_RTCK, | ||
248 | DA830_GPIO7_15, | ||
249 | DA830_EMU_0, | ||
250 | DA830_EMB_SDCKE, | ||
251 | DA830_EMB_CLK_GLUE, | ||
252 | DA830_EMB_CLK, | ||
253 | DA830_NEMB_CS_0, | ||
254 | DA830_NEMB_CAS, | ||
255 | DA830_NEMB_RAS, | ||
256 | DA830_NEMB_WE, | ||
257 | DA830_EMB_BA_1, | ||
258 | DA830_EMB_BA_0, | ||
259 | DA830_EMB_A_0, | ||
260 | DA830_EMB_A_1, | ||
261 | DA830_EMB_A_2, | ||
262 | DA830_EMB_A_3, | ||
263 | DA830_EMB_A_4, | ||
264 | DA830_EMB_A_5, | ||
265 | DA830_GPIO7_0, | ||
266 | DA830_GPIO7_1, | ||
267 | DA830_GPIO7_2, | ||
268 | DA830_GPIO7_3, | ||
269 | DA830_GPIO7_4, | ||
270 | DA830_GPIO7_5, | ||
271 | DA830_GPIO7_6, | ||
272 | DA830_GPIO7_7, | ||
273 | DA830_EMB_A_6, | ||
274 | DA830_EMB_A_7, | ||
275 | DA830_EMB_A_8, | ||
276 | DA830_EMB_A_9, | ||
277 | DA830_EMB_A_10, | ||
278 | DA830_EMB_A_11, | ||
279 | DA830_EMB_A_12, | ||
280 | DA830_EMB_D_31, | ||
281 | DA830_GPIO7_8, | ||
282 | DA830_GPIO7_9, | ||
283 | DA830_GPIO7_10, | ||
284 | DA830_GPIO7_11, | ||
285 | DA830_GPIO7_12, | ||
286 | DA830_GPIO7_13, | ||
287 | DA830_GPIO3_13, | ||
288 | DA830_EMB_D_30, | ||
289 | DA830_EMB_D_29, | ||
290 | DA830_EMB_D_28, | ||
291 | DA830_EMB_D_27, | ||
292 | DA830_EMB_D_26, | ||
293 | DA830_EMB_D_25, | ||
294 | DA830_EMB_D_24, | ||
295 | DA830_EMB_D_23, | ||
296 | DA830_EMB_D_22, | ||
297 | DA830_EMB_D_21, | ||
298 | DA830_EMB_D_20, | ||
299 | DA830_EMB_D_19, | ||
300 | DA830_EMB_D_18, | ||
301 | DA830_EMB_D_17, | ||
302 | DA830_EMB_D_16, | ||
303 | DA830_NEMB_WE_DQM_3, | ||
304 | DA830_NEMB_WE_DQM_2, | ||
305 | DA830_EMB_D_0, | ||
306 | DA830_EMB_D_1, | ||
307 | DA830_EMB_D_2, | ||
308 | DA830_EMB_D_3, | ||
309 | DA830_EMB_D_4, | ||
310 | DA830_EMB_D_5, | ||
311 | DA830_EMB_D_6, | ||
312 | DA830_GPIO6_0, | ||
313 | DA830_GPIO6_1, | ||
314 | DA830_GPIO6_2, | ||
315 | DA830_GPIO6_3, | ||
316 | DA830_GPIO6_4, | ||
317 | DA830_GPIO6_5, | ||
318 | DA830_GPIO6_6, | ||
319 | DA830_EMB_D_7, | ||
320 | DA830_EMB_D_8, | ||
321 | DA830_EMB_D_9, | ||
322 | DA830_EMB_D_10, | ||
323 | DA830_EMB_D_11, | ||
324 | DA830_EMB_D_12, | ||
325 | DA830_EMB_D_13, | ||
326 | DA830_EMB_D_14, | ||
327 | DA830_GPIO6_7, | ||
328 | DA830_GPIO6_8, | ||
329 | DA830_GPIO6_9, | ||
330 | DA830_GPIO6_10, | ||
331 | DA830_GPIO6_11, | ||
332 | DA830_GPIO6_12, | ||
333 | DA830_GPIO6_13, | ||
334 | DA830_GPIO6_14, | ||
335 | DA830_EMB_D_15, | ||
336 | DA830_NEMB_WE_DQM_1, | ||
337 | DA830_NEMB_WE_DQM_0, | ||
338 | DA830_SPI0_SOMI_0, | ||
339 | DA830_SPI0_SIMO_0, | ||
340 | DA830_SPI0_CLK, | ||
341 | DA830_NSPI0_ENA, | ||
342 | DA830_NSPI0_SCS_0, | ||
343 | DA830_EQEP0I, | ||
344 | DA830_EQEP0S, | ||
345 | DA830_EQEP1I, | ||
346 | DA830_NUART0_CTS, | ||
347 | DA830_NUART0_RTS, | ||
348 | DA830_EQEP0A, | ||
349 | DA830_EQEP0B, | ||
350 | DA830_GPIO6_15, | ||
351 | DA830_GPIO5_14, | ||
352 | DA830_GPIO5_15, | ||
353 | DA830_GPIO5_0, | ||
354 | DA830_GPIO5_1, | ||
355 | DA830_GPIO5_2, | ||
356 | DA830_GPIO5_3, | ||
357 | DA830_GPIO5_4, | ||
358 | DA830_SPI1_SOMI_0, | ||
359 | DA830_SPI1_SIMO_0, | ||
360 | DA830_SPI1_CLK, | ||
361 | DA830_UART0_RXD, | ||
362 | DA830_UART0_TXD, | ||
363 | DA830_AXR1_10, | ||
364 | DA830_AXR1_11, | ||
365 | DA830_NSPI1_ENA, | ||
366 | DA830_I2C1_SCL, | ||
367 | DA830_I2C1_SDA, | ||
368 | DA830_EQEP1S, | ||
369 | DA830_I2C0_SDA, | ||
370 | DA830_I2C0_SCL, | ||
371 | DA830_UART2_RXD, | ||
372 | DA830_TM64P0_IN12, | ||
373 | DA830_TM64P0_OUT12, | ||
374 | DA830_GPIO5_5, | ||
375 | DA830_GPIO5_6, | ||
376 | DA830_GPIO5_7, | ||
377 | DA830_GPIO5_8, | ||
378 | DA830_GPIO5_9, | ||
379 | DA830_GPIO5_10, | ||
380 | DA830_GPIO5_11, | ||
381 | DA830_GPIO5_12, | ||
382 | DA830_NSPI1_SCS_0, | ||
383 | DA830_USB0_DRVVBUS, | ||
384 | DA830_AHCLKX0, | ||
385 | DA830_ACLKX0, | ||
386 | DA830_AFSX0, | ||
387 | DA830_AHCLKR0, | ||
388 | DA830_ACLKR0, | ||
389 | DA830_AFSR0, | ||
390 | DA830_UART2_TXD, | ||
391 | DA830_AHCLKX2, | ||
392 | DA830_ECAP0_APWM0, | ||
393 | DA830_RMII_MHZ_50_CLK, | ||
394 | DA830_ECAP1_APWM1, | ||
395 | DA830_USB_REFCLKIN, | ||
396 | DA830_GPIO5_13, | ||
397 | DA830_GPIO4_15, | ||
398 | DA830_GPIO2_11, | ||
399 | DA830_GPIO2_12, | ||
400 | DA830_GPIO2_13, | ||
401 | DA830_GPIO2_14, | ||
402 | DA830_GPIO2_15, | ||
403 | DA830_GPIO3_12, | ||
404 | DA830_AMUTE0, | ||
405 | DA830_AXR0_0, | ||
406 | DA830_AXR0_1, | ||
407 | DA830_AXR0_2, | ||
408 | DA830_AXR0_3, | ||
409 | DA830_AXR0_4, | ||
410 | DA830_AXR0_5, | ||
411 | DA830_AXR0_6, | ||
412 | DA830_RMII_TXD_0, | ||
413 | DA830_RMII_TXD_1, | ||
414 | DA830_RMII_TXEN, | ||
415 | DA830_RMII_CRS_DV, | ||
416 | DA830_RMII_RXD_0, | ||
417 | DA830_RMII_RXD_1, | ||
418 | DA830_RMII_RXER, | ||
419 | DA830_AFSR2, | ||
420 | DA830_ACLKX2, | ||
421 | DA830_AXR2_3, | ||
422 | DA830_AXR2_2, | ||
423 | DA830_AXR2_1, | ||
424 | DA830_AFSX2, | ||
425 | DA830_ACLKR2, | ||
426 | DA830_NRESETOUT, | ||
427 | DA830_GPIO3_0, | ||
428 | DA830_GPIO3_1, | ||
429 | DA830_GPIO3_2, | ||
430 | DA830_GPIO3_3, | ||
431 | DA830_GPIO3_4, | ||
432 | DA830_GPIO3_5, | ||
433 | DA830_GPIO3_6, | ||
434 | DA830_AXR0_7, | ||
435 | DA830_AXR0_8, | ||
436 | DA830_UART1_RXD, | ||
437 | DA830_UART1_TXD, | ||
438 | DA830_AXR0_11, | ||
439 | DA830_AHCLKX1, | ||
440 | DA830_ACLKX1, | ||
441 | DA830_AFSX1, | ||
442 | DA830_MDIO_CLK, | ||
443 | DA830_MDIO_D, | ||
444 | DA830_AXR0_9, | ||
445 | DA830_AXR0_10, | ||
446 | DA830_EPWM0B, | ||
447 | DA830_EPWM0A, | ||
448 | DA830_EPWMSYNCI, | ||
449 | DA830_AXR2_0, | ||
450 | DA830_EPWMSYNC0, | ||
451 | DA830_GPIO3_7, | ||
452 | DA830_GPIO3_8, | ||
453 | DA830_GPIO3_9, | ||
454 | DA830_GPIO3_10, | ||
455 | DA830_GPIO3_11, | ||
456 | DA830_GPIO3_14, | ||
457 | DA830_GPIO3_15, | ||
458 | DA830_GPIO4_10, | ||
459 | DA830_AHCLKR1, | ||
460 | DA830_ACLKR1, | ||
461 | DA830_AFSR1, | ||
462 | DA830_AMUTE1, | ||
463 | DA830_AXR1_0, | ||
464 | DA830_AXR1_1, | ||
465 | DA830_AXR1_2, | ||
466 | DA830_AXR1_3, | ||
467 | DA830_ECAP2_APWM2, | ||
468 | DA830_EHRPWMGLUETZ, | ||
469 | DA830_EQEP1A, | ||
470 | DA830_GPIO4_11, | ||
471 | DA830_GPIO4_12, | ||
472 | DA830_GPIO4_13, | ||
473 | DA830_GPIO4_14, | ||
474 | DA830_GPIO4_0, | ||
475 | DA830_GPIO4_1, | ||
476 | DA830_GPIO4_2, | ||
477 | DA830_GPIO4_3, | ||
478 | DA830_AXR1_4, | ||
479 | DA830_AXR1_5, | ||
480 | DA830_AXR1_6, | ||
481 | DA830_AXR1_7, | ||
482 | DA830_AXR1_8, | ||
483 | DA830_AXR1_9, | ||
484 | DA830_EMA_D_0, | ||
485 | DA830_EMA_D_1, | ||
486 | DA830_EQEP1B, | ||
487 | DA830_EPWM2B, | ||
488 | DA830_EPWM2A, | ||
489 | DA830_EPWM1B, | ||
490 | DA830_EPWM1A, | ||
491 | DA830_MMCSD_DAT_0, | ||
492 | DA830_MMCSD_DAT_1, | ||
493 | DA830_UHPI_HD_0, | ||
494 | DA830_UHPI_HD_1, | ||
495 | DA830_GPIO4_4, | ||
496 | DA830_GPIO4_5, | ||
497 | DA830_GPIO4_6, | ||
498 | DA830_GPIO4_7, | ||
499 | DA830_GPIO4_8, | ||
500 | DA830_GPIO4_9, | ||
501 | DA830_GPIO0_0, | ||
502 | DA830_GPIO0_1, | ||
503 | DA830_EMA_D_2, | ||
504 | DA830_EMA_D_3, | ||
505 | DA830_EMA_D_4, | ||
506 | DA830_EMA_D_5, | ||
507 | DA830_EMA_D_6, | ||
508 | DA830_EMA_D_7, | ||
509 | DA830_EMA_D_8, | ||
510 | DA830_EMA_D_9, | ||
511 | DA830_MMCSD_DAT_2, | ||
512 | DA830_MMCSD_DAT_3, | ||
513 | DA830_MMCSD_DAT_4, | ||
514 | DA830_MMCSD_DAT_5, | ||
515 | DA830_MMCSD_DAT_6, | ||
516 | DA830_MMCSD_DAT_7, | ||
517 | DA830_UHPI_HD_8, | ||
518 | DA830_UHPI_HD_9, | ||
519 | DA830_UHPI_HD_2, | ||
520 | DA830_UHPI_HD_3, | ||
521 | DA830_UHPI_HD_4, | ||
522 | DA830_UHPI_HD_5, | ||
523 | DA830_UHPI_HD_6, | ||
524 | DA830_UHPI_HD_7, | ||
525 | DA830_LCD_D_8, | ||
526 | DA830_LCD_D_9, | ||
527 | DA830_GPIO0_2, | ||
528 | DA830_GPIO0_3, | ||
529 | DA830_GPIO0_4, | ||
530 | DA830_GPIO0_5, | ||
531 | DA830_GPIO0_6, | ||
532 | DA830_GPIO0_7, | ||
533 | DA830_GPIO0_8, | ||
534 | DA830_GPIO0_9, | ||
535 | DA830_EMA_D_10, | ||
536 | DA830_EMA_D_11, | ||
537 | DA830_EMA_D_12, | ||
538 | DA830_EMA_D_13, | ||
539 | DA830_EMA_D_14, | ||
540 | DA830_EMA_D_15, | ||
541 | DA830_EMA_A_0, | ||
542 | DA830_EMA_A_1, | ||
543 | DA830_UHPI_HD_10, | ||
544 | DA830_UHPI_HD_11, | ||
545 | DA830_UHPI_HD_12, | ||
546 | DA830_UHPI_HD_13, | ||
547 | DA830_UHPI_HD_14, | ||
548 | DA830_UHPI_HD_15, | ||
549 | DA830_LCD_D_7, | ||
550 | DA830_MMCSD_CLK, | ||
551 | DA830_LCD_D_10, | ||
552 | DA830_LCD_D_11, | ||
553 | DA830_LCD_D_12, | ||
554 | DA830_LCD_D_13, | ||
555 | DA830_LCD_D_14, | ||
556 | DA830_LCD_D_15, | ||
557 | DA830_UHPI_HCNTL0, | ||
558 | DA830_GPIO0_10, | ||
559 | DA830_GPIO0_11, | ||
560 | DA830_GPIO0_12, | ||
561 | DA830_GPIO0_13, | ||
562 | DA830_GPIO0_14, | ||
563 | DA830_GPIO0_15, | ||
564 | DA830_GPIO1_0, | ||
565 | DA830_GPIO1_1, | ||
566 | DA830_EMA_A_2, | ||
567 | DA830_EMA_A_3, | ||
568 | DA830_EMA_A_4, | ||
569 | DA830_EMA_A_5, | ||
570 | DA830_EMA_A_6, | ||
571 | DA830_EMA_A_7, | ||
572 | DA830_EMA_A_8, | ||
573 | DA830_EMA_A_9, | ||
574 | DA830_MMCSD_CMD, | ||
575 | DA830_LCD_D_6, | ||
576 | DA830_LCD_D_3, | ||
577 | DA830_LCD_D_2, | ||
578 | DA830_LCD_D_1, | ||
579 | DA830_LCD_D_0, | ||
580 | DA830_LCD_PCLK, | ||
581 | DA830_LCD_HSYNC, | ||
582 | DA830_UHPI_HCNTL1, | ||
583 | DA830_GPIO1_2, | ||
584 | DA830_GPIO1_3, | ||
585 | DA830_GPIO1_4, | ||
586 | DA830_GPIO1_5, | ||
587 | DA830_GPIO1_6, | ||
588 | DA830_GPIO1_7, | ||
589 | DA830_GPIO1_8, | ||
590 | DA830_GPIO1_9, | ||
591 | DA830_EMA_A_10, | ||
592 | DA830_EMA_A_11, | ||
593 | DA830_EMA_A_12, | ||
594 | DA830_EMA_BA_1, | ||
595 | DA830_EMA_BA_0, | ||
596 | DA830_EMA_CLK, | ||
597 | DA830_EMA_SDCKE, | ||
598 | DA830_NEMA_CAS, | ||
599 | DA830_LCD_VSYNC, | ||
600 | DA830_NLCD_AC_ENB_CS, | ||
601 | DA830_LCD_MCLK, | ||
602 | DA830_LCD_D_5, | ||
603 | DA830_LCD_D_4, | ||
604 | DA830_OBSCLK, | ||
605 | DA830_NEMA_CS_4, | ||
606 | DA830_UHPI_HHWIL, | ||
607 | DA830_AHCLKR2, | ||
608 | DA830_GPIO1_10, | ||
609 | DA830_GPIO1_11, | ||
610 | DA830_GPIO1_12, | ||
611 | DA830_GPIO1_13, | ||
612 | DA830_GPIO1_14, | ||
613 | DA830_GPIO1_15, | ||
614 | DA830_GPIO2_0, | ||
615 | DA830_GPIO2_1, | ||
616 | DA830_NEMA_RAS, | ||
617 | DA830_NEMA_WE, | ||
618 | DA830_NEMA_CS_0, | ||
619 | DA830_NEMA_CS_2, | ||
620 | DA830_NEMA_CS_3, | ||
621 | DA830_NEMA_OE, | ||
622 | DA830_NEMA_WE_DQM_1, | ||
623 | DA830_NEMA_WE_DQM_0, | ||
624 | DA830_NEMA_CS_5, | ||
625 | DA830_UHPI_HRNW, | ||
626 | DA830_NUHPI_HAS, | ||
627 | DA830_NUHPI_HCS, | ||
628 | DA830_NUHPI_HDS1, | ||
629 | DA830_NUHPI_HDS2, | ||
630 | DA830_NUHPI_HINT, | ||
631 | DA830_AXR0_12, | ||
632 | DA830_AMUTE2, | ||
633 | DA830_AXR0_13, | ||
634 | DA830_AXR0_14, | ||
635 | DA830_AXR0_15, | ||
636 | DA830_GPIO2_2, | ||
637 | DA830_GPIO2_3, | ||
638 | DA830_GPIO2_4, | ||
639 | DA830_GPIO2_5, | ||
640 | DA830_GPIO2_6, | ||
641 | DA830_GPIO2_7, | ||
642 | DA830_GPIO2_8, | ||
643 | DA830_GPIO2_9, | ||
644 | DA830_EMA_WAIT_0, | ||
645 | DA830_NUHPI_HRDY, | ||
646 | DA830_GPIO2_10, | ||
647 | }; | ||
648 | |||
245 | #ifdef CONFIG_DAVINCI_MUX | 649 | #ifdef CONFIG_DAVINCI_MUX |
246 | /* setup pin muxing */ | 650 | /* setup pin muxing */ |
247 | extern int davinci_cfg_reg(unsigned long reg_cfg); | 651 | extern int davinci_cfg_reg(unsigned long reg_cfg); |
diff --git a/arch/arm/mach-davinci/include/mach/psc.h b/arch/arm/mach-davinci/include/mach/psc.h index 2bb414b14297..6b9621d88284 100644 --- a/arch/arm/mach-davinci/include/mach/psc.h +++ b/arch/arm/mach-davinci/include/mach/psc.h | |||
@@ -136,6 +136,47 @@ | |||
136 | #define DM646X_LPSC_TIMER1 35 | 136 | #define DM646X_LPSC_TIMER1 35 |
137 | #define DM646X_LPSC_ARM_INTC 45 | 137 | #define DM646X_LPSC_ARM_INTC 45 |
138 | 138 | ||
139 | /* PSC0 defines */ | ||
140 | #define DA8XX_LPSC0_TPCC 0 | ||
141 | #define DA8XX_LPSC0_TPTC0 1 | ||
142 | #define DA8XX_LPSC0_TPTC1 2 | ||
143 | #define DA8XX_LPSC0_EMIF25 3 | ||
144 | #define DA8XX_LPSC0_SPI0 4 | ||
145 | #define DA8XX_LPSC0_MMC_SD 5 | ||
146 | #define DA8XX_LPSC0_AINTC 6 | ||
147 | #define DA8XX_LPSC0_ARM_RAM_ROM 7 | ||
148 | #define DA8XX_LPSC0_SECU_MGR 8 | ||
149 | #define DA8XX_LPSC0_UART0 9 | ||
150 | #define DA8XX_LPSC0_SCR0_SS 10 | ||
151 | #define DA8XX_LPSC0_SCR1_SS 11 | ||
152 | #define DA8XX_LPSC0_SCR2_SS 12 | ||
153 | #define DA8XX_LPSC0_DMAX 13 | ||
154 | #define DA8XX_LPSC0_ARM 14 | ||
155 | #define DA8XX_LPSC0_GEM 15 | ||
156 | |||
157 | /* PSC1 defines */ | ||
158 | #define DA8XX_LPSC1_USB20 1 | ||
159 | #define DA8XX_LPSC1_USB11 2 | ||
160 | #define DA8XX_LPSC1_GPIO 3 | ||
161 | #define DA8XX_LPSC1_UHPI 4 | ||
162 | #define DA8XX_LPSC1_CPGMAC 5 | ||
163 | #define DA8XX_LPSC1_EMIF3C 6 | ||
164 | #define DA8XX_LPSC1_McASP0 7 | ||
165 | #define DA830_LPSC1_McASP1 8 | ||
166 | #define DA830_LPSC1_McASP2 9 | ||
167 | #define DA8XX_LPSC1_SPI1 10 | ||
168 | #define DA8XX_LPSC1_I2C 11 | ||
169 | #define DA8XX_LPSC1_UART1 12 | ||
170 | #define DA8XX_LPSC1_UART2 13 | ||
171 | #define DA8XX_LPSC1_LCDC 16 | ||
172 | #define DA8XX_LPSC1_PWM 17 | ||
173 | #define DA8XX_LPSC1_ECAP 20 | ||
174 | #define DA830_LPSC1_EQEP 21 | ||
175 | #define DA8XX_LPSC1_SCR_P0_SS 24 | ||
176 | #define DA8XX_LPSC1_SCR_P1_SS 25 | ||
177 | #define DA8XX_LPSC1_CR_P3_SS 26 | ||
178 | #define DA8XX_LPSC1_L3_CBA_RAM 31 | ||
179 | |||
139 | extern int davinci_psc_is_clk_active(unsigned int ctlr, unsigned int id); | 180 | extern int davinci_psc_is_clk_active(unsigned int ctlr, unsigned int id); |
140 | extern void davinci_psc_config(unsigned int domain, unsigned int ctlr, | 181 | extern void davinci_psc_config(unsigned int domain, unsigned int ctlr, |
141 | unsigned int id, char enable); | 182 | unsigned int id, char enable); |
diff --git a/arch/arm/mach-davinci/include/mach/serial.h b/arch/arm/mach-davinci/include/mach/serial.h index 794fa5cf93c1..57e68e610ee9 100644 --- a/arch/arm/mach-davinci/include/mach/serial.h +++ b/arch/arm/mach-davinci/include/mach/serial.h | |||
@@ -18,6 +18,10 @@ | |||
18 | #define DAVINCI_UART1_BASE (IO_PHYS + 0x20400) | 18 | #define DAVINCI_UART1_BASE (IO_PHYS + 0x20400) |
19 | #define DAVINCI_UART2_BASE (IO_PHYS + 0x20800) | 19 | #define DAVINCI_UART2_BASE (IO_PHYS + 0x20800) |
20 | 20 | ||
21 | #define DA8XX_UART0_BASE (IO_PHYS + 0x042000) | ||
22 | #define DA8XX_UART1_BASE (IO_PHYS + 0x10c000) | ||
23 | #define DA8XX_UART2_BASE (IO_PHYS + 0x10d000) | ||
24 | |||
21 | /* DaVinci UART register offsets */ | 25 | /* DaVinci UART register offsets */ |
22 | #define UART_DAVINCI_PWREMU 0x0c | 26 | #define UART_DAVINCI_PWREMU 0x0c |
23 | #define UART_DM646X_SCR 0x10 | 27 | #define UART_DM646X_SCR 0x10 |