ARM: 7611/1: VIC: fix bug in VIC irqdomain code
The VIC irqdomain code added in commit
07c9249f1f
"ARM: 7554/1: VIC: use irq_domain_add_simple()"
Had two bugs:
1) It didn't call irq_create_mapping() once on each
valid irq source in the slowpath when registering
the controller.
2) It passed a -1 as IRQ offset for the DT case, whereas
0 should be passed as invalid IRQ instead.
Cc: Grant Likely <grant.likely@secretlab.ca>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
f556529589
commit
5ced33bc06
|
@ -206,6 +206,7 @@ static void __init vic_register(void __iomem *base, unsigned int irq,
|
||||||
struct device_node *node)
|
struct device_node *node)
|
||||||
{
|
{
|
||||||
struct vic_device *v;
|
struct vic_device *v;
|
||||||
|
int i;
|
||||||
|
|
||||||
if (vic_id >= ARRAY_SIZE(vic_devices)) {
|
if (vic_id >= ARRAY_SIZE(vic_devices)) {
|
||||||
printk(KERN_ERR "%s: too few VICs, increase CONFIG_ARM_VIC_NR\n", __func__);
|
printk(KERN_ERR "%s: too few VICs, increase CONFIG_ARM_VIC_NR\n", __func__);
|
||||||
|
@ -220,6 +221,10 @@ static void __init vic_register(void __iomem *base, unsigned int 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,
|
||||||
&vic_irqdomain_ops, v);
|
&vic_irqdomain_ops, v);
|
||||||
|
/* create an IRQ mapping for each valid IRQ */
|
||||||
|
for (i = 0; i < fls(valid_sources); i++)
|
||||||
|
if (valid_sources & (1 << i))
|
||||||
|
irq_create_mapping(v->domain, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vic_ack_irq(struct irq_data *d)
|
static void vic_ack_irq(struct irq_data *d)
|
||||||
|
@ -416,9 +421,9 @@ int __init vic_of_init(struct device_node *node, struct device_node *parent)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Passing -1 as first IRQ makes the simple domain allocate descriptors
|
* Passing 0 as first IRQ makes the simple domain allocate descriptors
|
||||||
*/
|
*/
|
||||||
__vic_init(regs, -1, ~0, ~0, node);
|
__vic_init(regs, 0, ~0, ~0, node);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue