diff options
author | Linus Walleij <linus.walleij@linaro.org> | 2013-11-24 14:18:57 -0500 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2014-02-13 05:21:13 -0500 |
commit | 3b4df9dbd9bf27a35d5c7d36684d245518e5a939 (patch) | |
tree | 5ca32ca2bda8d226233798c14aceb2ed65bf2a9b /drivers/irqchip/irq-vic.c | |
parent | a183da637c52c74ae4634355187d3fbaa1ba9763 (diff) |
irqchip: vic: update the base IRQ member correctly
When passing 0 as the irq base the VIC driver will dynamically
allocate a number of consecutive interrupt descriptors at some
available number range. Make sure this number is recorded in
the state container rather than the passed-in zero argument
in this case.
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/irqchip/irq-vic.c')
-rw-r--r-- | drivers/irqchip/irq-vic.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/irqchip/irq-vic.c b/drivers/irqchip/irq-vic.c index 8e21ae0bab46..70108c1491bc 100644 --- a/drivers/irqchip/irq-vic.c +++ b/drivers/irqchip/irq-vic.c | |||
@@ -273,7 +273,6 @@ static void __init vic_register(void __iomem *base, unsigned int irq, | |||
273 | v->base = base; | 273 | v->base = base; |
274 | v->valid_sources = valid_sources; | 274 | v->valid_sources = valid_sources; |
275 | v->resume_sources = resume_sources; | 275 | v->resume_sources = resume_sources; |
276 | v->irq = irq; | ||
277 | set_handle_irq(vic_handle_irq); | 276 | set_handle_irq(vic_handle_irq); |
278 | vic_id++; | 277 | vic_id++; |
279 | v->domain = irq_domain_add_simple(node, fls(valid_sources), irq, | 278 | v->domain = irq_domain_add_simple(node, fls(valid_sources), irq, |
@@ -282,6 +281,11 @@ static void __init vic_register(void __iomem *base, unsigned int irq, | |||
282 | for (i = 0; i < fls(valid_sources); i++) | 281 | for (i = 0; i < fls(valid_sources); i++) |
283 | if (valid_sources & (1 << i)) | 282 | if (valid_sources & (1 << i)) |
284 | irq_create_mapping(v->domain, i); | 283 | irq_create_mapping(v->domain, i); |
284 | /* If no base IRQ was passed, figure out our allocated base */ | ||
285 | if (irq) | ||
286 | v->irq = irq; | ||
287 | else | ||
288 | v->irq = irq_find_mapping(v->domain, 0); | ||
285 | } | 289 | } |
286 | 290 | ||
287 | static void vic_ack_irq(struct irq_data *d) | 291 | static void vic_ack_irq(struct irq_data *d) |