diff options
-rw-r--r-- | arch/sh/kernel/cpu/irq/ipr.c | 8 | ||||
-rw-r--r-- | drivers/sh/intc.c | 12 |
2 files changed, 18 insertions, 2 deletions
diff --git a/arch/sh/kernel/cpu/irq/ipr.c b/arch/sh/kernel/cpu/irq/ipr.c index 3eb17ee5540e..fa0c8467a280 100644 --- a/arch/sh/kernel/cpu/irq/ipr.c +++ b/arch/sh/kernel/cpu/irq/ipr.c | |||
@@ -59,10 +59,18 @@ void register_ipr_controller(struct ipr_desc *desc) | |||
59 | 59 | ||
60 | for (i = 0; i < desc->nr_irqs; i++) { | 60 | for (i = 0; i < desc->nr_irqs; i++) { |
61 | struct ipr_data *p = desc->ipr_data + i; | 61 | struct ipr_data *p = desc->ipr_data + i; |
62 | struct irq_desc *irq_desc; | ||
62 | 63 | ||
63 | BUG_ON(p->ipr_idx >= desc->nr_offsets); | 64 | BUG_ON(p->ipr_idx >= desc->nr_offsets); |
64 | BUG_ON(!desc->ipr_offsets[p->ipr_idx]); | 65 | BUG_ON(!desc->ipr_offsets[p->ipr_idx]); |
65 | 66 | ||
67 | irq_desc = irq_to_desc_alloc_cpu(p->irq, smp_processor_id()); | ||
68 | if (unlikely(!irq_desc)) { | ||
69 | printk(KERN_INFO "can not get irq_desc for %d\n", | ||
70 | p->irq); | ||
71 | continue; | ||
72 | } | ||
73 | |||
66 | disable_irq_nosync(p->irq); | 74 | disable_irq_nosync(p->irq); |
67 | set_irq_chip_and_handler_name(p->irq, &desc->chip, | 75 | set_irq_chip_and_handler_name(p->irq, &desc->chip, |
68 | handle_level_irq, "level"); | 76 | handle_level_irq, "level"); |
diff --git a/drivers/sh/intc.c b/drivers/sh/intc.c index 12d13d99b6f0..098b767e9afd 100644 --- a/drivers/sh/intc.c +++ b/drivers/sh/intc.c | |||
@@ -671,7 +671,7 @@ unsigned int intc_evt2irq(unsigned int vector) | |||
671 | 671 | ||
672 | void __init register_intc_controller(struct intc_desc *desc) | 672 | void __init register_intc_controller(struct intc_desc *desc) |
673 | { | 673 | { |
674 | unsigned int i, k, smp; | 674 | unsigned int i, k, smp, cpu = smp_processor_id(); |
675 | struct intc_desc_int *d; | 675 | struct intc_desc_int *d; |
676 | 676 | ||
677 | d = alloc_bootmem(sizeof(*d)); | 677 | d = alloc_bootmem(sizeof(*d)); |
@@ -770,11 +770,19 @@ void __init register_intc_controller(struct intc_desc *desc) | |||
770 | /* register the vectors one by one */ | 770 | /* register the vectors one by one */ |
771 | for (i = 0; i < desc->nr_vectors; i++) { | 771 | for (i = 0; i < desc->nr_vectors; i++) { |
772 | struct intc_vect *vect = desc->vectors + i; | 772 | struct intc_vect *vect = desc->vectors + i; |
773 | unsigned int irq = evt2irq(vect->vect); | ||
774 | struct irq_desc *irq_desc; | ||
773 | 775 | ||
774 | if (!vect->enum_id) | 776 | if (!vect->enum_id) |
775 | continue; | 777 | continue; |
776 | 778 | ||
777 | intc_register_irq(desc, d, vect->enum_id, evt2irq(vect->vect)); | 779 | irq_desc = irq_to_desc_alloc_cpu(irq, cpu); |
780 | if (unlikely(!irq_desc)) { | ||
781 | printk(KERN_INFO "can not get irq_desc for %d\n", irq); | ||
782 | continue; | ||
783 | } | ||
784 | |||
785 | intc_register_irq(desc, d, vect->enum_id, irq); | ||
778 | } | 786 | } |
779 | } | 787 | } |
780 | 788 | ||