diff options
Diffstat (limited to 'arch/arm/mach-omap2/board-generic.c')
-rw-r--r-- | arch/arm/mach-omap2/board-generic.c | 58 |
1 files changed, 42 insertions, 16 deletions
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 202934657867..6f93a20536ea 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
@@ -25,23 +25,12 @@ | |||
25 | #include "common-board-devices.h" | 25 | #include "common-board-devices.h" |
26 | 26 | ||
27 | #if !(defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3)) | 27 | #if !(defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3)) |
28 | #define omap_intc_of_init NULL | 28 | #define intc_of_init NULL |
29 | #endif | 29 | #endif |
30 | #ifndef CONFIG_ARCH_OMAP4 | 30 | #ifndef CONFIG_ARCH_OMAP4 |
31 | #define gic_of_init NULL | 31 | #define gic_of_init NULL |
32 | #endif | 32 | #endif |
33 | 33 | ||
34 | static struct of_device_id irq_match[] __initdata = { | ||
35 | { .compatible = "ti,omap2-intc", .data = omap_intc_of_init, }, | ||
36 | { .compatible = "arm,cortex-a9-gic", .data = gic_of_init, }, | ||
37 | { } | ||
38 | }; | ||
39 | |||
40 | static void __init omap_init_irq(void) | ||
41 | { | ||
42 | of_irq_init(irq_match); | ||
43 | } | ||
44 | |||
45 | static struct of_device_id omap_dt_match_table[] __initdata = { | 34 | static struct of_device_id omap_dt_match_table[] __initdata = { |
46 | { .compatible = "simple-bus", }, | 35 | { .compatible = "simple-bus", }, |
47 | { .compatible = "ti,omap-infra", }, | 36 | { .compatible = "ti,omap-infra", }, |
@@ -65,7 +54,7 @@ DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)") | |||
65 | .reserve = omap_reserve, | 54 | .reserve = omap_reserve, |
66 | .map_io = omap242x_map_io, | 55 | .map_io = omap242x_map_io, |
67 | .init_early = omap2420_init_early, | 56 | .init_early = omap2420_init_early, |
68 | .init_irq = omap_init_irq, | 57 | .init_irq = omap_intc_of_init, |
69 | .handle_irq = omap2_intc_handle_irq, | 58 | .handle_irq = omap2_intc_handle_irq, |
70 | .init_machine = omap_generic_init, | 59 | .init_machine = omap_generic_init, |
71 | .timer = &omap2_timer, | 60 | .timer = &omap2_timer, |
@@ -84,7 +73,7 @@ DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)") | |||
84 | .reserve = omap_reserve, | 73 | .reserve = omap_reserve, |
85 | .map_io = omap243x_map_io, | 74 | .map_io = omap243x_map_io, |
86 | .init_early = omap2430_init_early, | 75 | .init_early = omap2430_init_early, |
87 | .init_irq = omap_init_irq, | 76 | .init_irq = omap_intc_of_init, |
88 | .handle_irq = omap2_intc_handle_irq, | 77 | .handle_irq = omap2_intc_handle_irq, |
89 | .init_machine = omap_generic_init, | 78 | .init_machine = omap_generic_init, |
90 | .timer = &omap2_timer, | 79 | .timer = &omap2_timer, |
@@ -103,7 +92,7 @@ DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)") | |||
103 | .reserve = omap_reserve, | 92 | .reserve = omap_reserve, |
104 | .map_io = omap3_map_io, | 93 | .map_io = omap3_map_io, |
105 | .init_early = omap3430_init_early, | 94 | .init_early = omap3430_init_early, |
106 | .init_irq = omap_init_irq, | 95 | .init_irq = omap_intc_of_init, |
107 | .handle_irq = omap3_intc_handle_irq, | 96 | .handle_irq = omap3_intc_handle_irq, |
108 | .init_machine = omap_generic_init, | 97 | .init_machine = omap_generic_init, |
109 | .timer = &omap3_timer, | 98 | .timer = &omap3_timer, |
@@ -112,6 +101,24 @@ DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)") | |||
112 | MACHINE_END | 101 | MACHINE_END |
113 | #endif | 102 | #endif |
114 | 103 | ||
104 | #ifdef CONFIG_SOC_AM33XX | ||
105 | static const char *am33xx_boards_compat[] __initdata = { | ||
106 | "ti,am33xx", | ||
107 | NULL, | ||
108 | }; | ||
109 | |||
110 | DT_MACHINE_START(AM33XX_DT, "Generic AM33XX (Flattened Device Tree)") | ||
111 | .reserve = omap_reserve, | ||
112 | .map_io = am33xx_map_io, | ||
113 | .init_early = am33xx_init_early, | ||
114 | .init_irq = omap_intc_of_init, | ||
115 | .handle_irq = omap3_intc_handle_irq, | ||
116 | .init_machine = omap_generic_init, | ||
117 | .timer = &omap3_am33xx_timer, | ||
118 | .dt_compat = am33xx_boards_compat, | ||
119 | MACHINE_END | ||
120 | #endif | ||
121 | |||
115 | #ifdef CONFIG_ARCH_OMAP4 | 122 | #ifdef CONFIG_ARCH_OMAP4 |
116 | static const char *omap4_boards_compat[] __initdata = { | 123 | static const char *omap4_boards_compat[] __initdata = { |
117 | "ti,omap4", | 124 | "ti,omap4", |
@@ -122,7 +129,7 @@ DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)") | |||
122 | .reserve = omap_reserve, | 129 | .reserve = omap_reserve, |
123 | .map_io = omap4_map_io, | 130 | .map_io = omap4_map_io, |
124 | .init_early = omap4430_init_early, | 131 | .init_early = omap4430_init_early, |
125 | .init_irq = omap_init_irq, | 132 | .init_irq = omap_gic_of_init, |
126 | .handle_irq = gic_handle_irq, | 133 | .handle_irq = gic_handle_irq, |
127 | .init_machine = omap_generic_init, | 134 | .init_machine = omap_generic_init, |
128 | .init_late = omap4430_init_late, | 135 | .init_late = omap4430_init_late, |
@@ -131,3 +138,22 @@ DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)") | |||
131 | .restart = omap_prcm_restart, | 138 | .restart = omap_prcm_restart, |
132 | MACHINE_END | 139 | MACHINE_END |
133 | #endif | 140 | #endif |
141 | |||
142 | #ifdef CONFIG_SOC_OMAP5 | ||
143 | static const char *omap5_boards_compat[] __initdata = { | ||
144 | "ti,omap5", | ||
145 | NULL, | ||
146 | }; | ||
147 | |||
148 | DT_MACHINE_START(OMAP5_DT, "Generic OMAP5 (Flattened Device Tree)") | ||
149 | .reserve = omap_reserve, | ||
150 | .map_io = omap5_map_io, | ||
151 | .init_early = omap5_init_early, | ||
152 | .init_irq = omap_gic_of_init, | ||
153 | .handle_irq = gic_handle_irq, | ||
154 | .init_machine = omap_generic_init, | ||
155 | .timer = &omap5_timer, | ||
156 | .dt_compat = omap5_boards_compat, | ||
157 | .restart = omap_prcm_restart, | ||
158 | MACHINE_END | ||
159 | #endif | ||