diff options
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r-- | arch/arm/mach-omap2/irq.c | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/arch/arm/mach-omap2/irq.c b/arch/arm/mach-omap2/irq.c index a405b963c779..44d9cf4e74de 100644 --- a/arch/arm/mach-omap2/irq.c +++ b/arch/arm/mach-omap2/irq.c | |||
@@ -207,8 +207,7 @@ omap_alloc_gc(void __iomem *base, unsigned int irq_start, unsigned int num) | |||
207 | IRQ_NOREQUEST | IRQ_NOPROBE, 0); | 207 | IRQ_NOREQUEST | IRQ_NOPROBE, 0); |
208 | } | 208 | } |
209 | 209 | ||
210 | static void __init omap_init_irq(u32 base, int nr_irqs, | 210 | static void __init omap_init_irq(u32 base, struct device_node *node) |
211 | struct device_node *node) | ||
212 | { | 211 | { |
213 | int j, irq_base; | 212 | int j, irq_base; |
214 | 213 | ||
@@ -216,15 +215,13 @@ static void __init omap_init_irq(u32 base, int nr_irqs, | |||
216 | if (WARN_ON(!omap_irq_base)) | 215 | if (WARN_ON(!omap_irq_base)) |
217 | return; | 216 | return; |
218 | 217 | ||
219 | omap_nr_irqs = nr_irqs; | 218 | irq_base = irq_alloc_descs(-1, 0, omap_nr_irqs, 0); |
220 | |||
221 | irq_base = irq_alloc_descs(-1, 0, nr_irqs, 0); | ||
222 | if (irq_base < 0) { | 219 | if (irq_base < 0) { |
223 | pr_warn("Couldn't allocate IRQ numbers\n"); | 220 | pr_warn("Couldn't allocate IRQ numbers\n"); |
224 | irq_base = 0; | 221 | irq_base = 0; |
225 | } | 222 | } |
226 | 223 | ||
227 | domain = irq_domain_add_legacy(node, nr_irqs, irq_base, 0, | 224 | domain = irq_domain_add_legacy(node, omap_nr_irqs, irq_base, 0, |
228 | &irq_domain_simple_ops, NULL); | 225 | &irq_domain_simple_ops, NULL); |
229 | 226 | ||
230 | omap_irq_soft_reset(); | 227 | omap_irq_soft_reset(); |
@@ -278,19 +275,22 @@ out: | |||
278 | 275 | ||
279 | void __init omap2_init_irq(void) | 276 | void __init omap2_init_irq(void) |
280 | { | 277 | { |
281 | omap_init_irq(OMAP24XX_IC_BASE, 96, NULL); | 278 | omap_nr_irqs = 96; |
279 | omap_init_irq(OMAP24XX_IC_BASE, NULL); | ||
282 | set_handle_irq(omap_intc_handle_irq); | 280 | set_handle_irq(omap_intc_handle_irq); |
283 | } | 281 | } |
284 | 282 | ||
285 | void __init omap3_init_irq(void) | 283 | void __init omap3_init_irq(void) |
286 | { | 284 | { |
287 | omap_init_irq(OMAP34XX_IC_BASE, 96, NULL); | 285 | omap_nr_irqs = 96; |
286 | omap_init_irq(OMAP34XX_IC_BASE, NULL); | ||
288 | set_handle_irq(omap_intc_handle_irq); | 287 | set_handle_irq(omap_intc_handle_irq); |
289 | } | 288 | } |
290 | 289 | ||
291 | void __init ti81xx_init_irq(void) | 290 | void __init ti81xx_init_irq(void) |
292 | { | 291 | { |
293 | omap_init_irq(OMAP34XX_IC_BASE, 128, NULL); | 292 | omap_nr_irqs = 96; |
293 | omap_init_irq(OMAP34XX_IC_BASE, NULL); | ||
294 | set_handle_irq(omap_intc_handle_irq); | 294 | set_handle_irq(omap_intc_handle_irq); |
295 | } | 295 | } |
296 | 296 | ||
@@ -298,7 +298,8 @@ static int __init intc_of_init(struct device_node *node, | |||
298 | struct device_node *parent) | 298 | struct device_node *parent) |
299 | { | 299 | { |
300 | struct resource res; | 300 | struct resource res; |
301 | u32 nr_irq = 96; | 301 | |
302 | omap_nr_irqs = 96; | ||
302 | 303 | ||
303 | if (WARN_ON(!node)) | 304 | if (WARN_ON(!node)) |
304 | return -ENODEV; | 305 | return -ENODEV; |
@@ -309,9 +310,9 @@ static int __init intc_of_init(struct device_node *node, | |||
309 | } | 310 | } |
310 | 311 | ||
311 | if (of_device_is_compatible(node, "ti,am33xx-intc")) | 312 | if (of_device_is_compatible(node, "ti,am33xx-intc")) |
312 | nr_irq = 128; | 313 | omap_nr_irqs = 128; |
313 | 314 | ||
314 | omap_init_irq(res.start, nr_irq, of_node_get(node)); | 315 | omap_init_irq(res.start, of_node_get(node)); |
315 | 316 | ||
316 | set_handle_irq(omap_intc_handle_irq); | 317 | set_handle_irq(omap_intc_handle_irq); |
317 | 318 | ||