Commit 3b4df9db authored by Linus Walleij's avatar Linus Walleij

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: default avatarLinus Walleij <linus.walleij@linaro.org>
parent a183da63
...@@ -273,7 +273,6 @@ static void __init vic_register(void __iomem *base, unsigned int irq, ...@@ -273,7 +273,6 @@ static void __init vic_register(void __iomem *base, unsigned int irq,
v->base = base; v->base = base;
v->valid_sources = valid_sources; v->valid_sources = valid_sources;
v->resume_sources = resume_sources; v->resume_sources = resume_sources;
v->irq = irq;
set_handle_irq(vic_handle_irq); set_handle_irq(vic_handle_irq);
vic_id++; vic_id++;
v->domain = irq_domain_add_simple(node, fls(valid_sources), irq, 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,6 +281,11 @@ static void __init vic_register(void __iomem *base, unsigned int irq,
for (i = 0; i < fls(valid_sources); i++) for (i = 0; i < fls(valid_sources); i++)
if (valid_sources & (1 << i)) if (valid_sources & (1 << i))
irq_create_mapping(v->domain, i); irq_create_mapping(v->domain, i);
/* If no base IRQ was passed, figure out our allocated base */
if (irq)
v->irq = irq;
else
v->irq = irq_find_mapping(v->domain, 0);
} }
static void vic_ack_irq(struct irq_data *d) static void vic_ack_irq(struct irq_data *d)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment