diff options
-rw-r--r-- | drivers/sh/intc.c | 14 | ||||
-rw-r--r-- | include/linux/sh_intc.h | 4 |
2 files changed, 1 insertions, 17 deletions
diff --git a/drivers/sh/intc.c b/drivers/sh/intc.c index 559b5fe9dc0f..94e6e46ff82c 100644 --- a/drivers/sh/intc.c +++ b/drivers/sh/intc.c | |||
@@ -70,9 +70,7 @@ static LIST_HEAD(intc_list); | |||
70 | #endif | 70 | #endif |
71 | 71 | ||
72 | static unsigned int intc_prio_level[NR_IRQS]; /* for now */ | 72 | static unsigned int intc_prio_level[NR_IRQS]; /* for now */ |
73 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
74 | static unsigned long ack_handle[NR_IRQS]; | 73 | static unsigned long ack_handle[NR_IRQS]; |
75 | #endif | ||
76 | 74 | ||
77 | static inline struct intc_desc_int *get_intc_desc(unsigned int irq) | 75 | static inline struct intc_desc_int *get_intc_desc(unsigned int irq) |
78 | { | 76 | { |
@@ -250,7 +248,6 @@ static int intc_set_wake(unsigned int irq, unsigned int on) | |||
250 | return 0; /* allow wakeup, but setup hardware in intc_suspend() */ | 248 | return 0; /* allow wakeup, but setup hardware in intc_suspend() */ |
251 | } | 249 | } |
252 | 250 | ||
253 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
254 | static void intc_mask_ack(unsigned int irq) | 251 | static void intc_mask_ack(unsigned int irq) |
255 | { | 252 | { |
256 | struct intc_desc_int *d = get_intc_desc(irq); | 253 | struct intc_desc_int *d = get_intc_desc(irq); |
@@ -282,7 +279,6 @@ static void intc_mask_ack(unsigned int irq) | |||
282 | } | 279 | } |
283 | } | 280 | } |
284 | } | 281 | } |
285 | #endif | ||
286 | 282 | ||
287 | static struct intc_handle_int *intc_find_irq(struct intc_handle_int *hp, | 283 | static struct intc_handle_int *intc_find_irq(struct intc_handle_int *hp, |
288 | unsigned int nr_hp, | 284 | unsigned int nr_hp, |
@@ -501,7 +497,6 @@ static unsigned int __init intc_prio_data(struct intc_desc *desc, | |||
501 | return 0; | 497 | return 0; |
502 | } | 498 | } |
503 | 499 | ||
504 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
505 | static unsigned int __init intc_ack_data(struct intc_desc *desc, | 500 | static unsigned int __init intc_ack_data(struct intc_desc *desc, |
506 | struct intc_desc_int *d, | 501 | struct intc_desc_int *d, |
507 | intc_enum enum_id) | 502 | intc_enum enum_id) |
@@ -533,7 +528,6 @@ static unsigned int __init intc_ack_data(struct intc_desc *desc, | |||
533 | 528 | ||
534 | return 0; | 529 | return 0; |
535 | } | 530 | } |
536 | #endif | ||
537 | 531 | ||
538 | static unsigned int __init intc_sense_data(struct intc_desc *desc, | 532 | static unsigned int __init intc_sense_data(struct intc_desc *desc, |
539 | struct intc_desc_int *d, | 533 | struct intc_desc_int *d, |
@@ -641,10 +635,8 @@ static void __init intc_register_irq(struct intc_desc *desc, | |||
641 | /* irq should be disabled by default */ | 635 | /* irq should be disabled by default */ |
642 | d->chip.mask(irq); | 636 | d->chip.mask(irq); |
643 | 637 | ||
644 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
645 | if (desc->ack_regs) | 638 | if (desc->ack_regs) |
646 | ack_handle[irq] = intc_ack_data(desc, d, enum_id); | 639 | ack_handle[irq] = intc_ack_data(desc, d, enum_id); |
647 | #endif | ||
648 | } | 640 | } |
649 | 641 | ||
650 | static unsigned int __init save_reg(struct intc_desc_int *d, | 642 | static unsigned int __init save_reg(struct intc_desc_int *d, |
@@ -681,10 +673,8 @@ void __init register_intc_controller(struct intc_desc *desc) | |||
681 | d->nr_reg = desc->mask_regs ? desc->nr_mask_regs * 2 : 0; | 673 | d->nr_reg = desc->mask_regs ? desc->nr_mask_regs * 2 : 0; |
682 | d->nr_reg += desc->prio_regs ? desc->nr_prio_regs * 2 : 0; | 674 | d->nr_reg += desc->prio_regs ? desc->nr_prio_regs * 2 : 0; |
683 | d->nr_reg += desc->sense_regs ? desc->nr_sense_regs : 0; | 675 | d->nr_reg += desc->sense_regs ? desc->nr_sense_regs : 0; |
684 | |||
685 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
686 | d->nr_reg += desc->ack_regs ? desc->nr_ack_regs : 0; | 676 | d->nr_reg += desc->ack_regs ? desc->nr_ack_regs : 0; |
687 | #endif | 677 | |
688 | d->reg = kzalloc(d->nr_reg * sizeof(*d->reg), GFP_NOWAIT); | 678 | d->reg = kzalloc(d->nr_reg * sizeof(*d->reg), GFP_NOWAIT); |
689 | #ifdef CONFIG_SMP | 679 | #ifdef CONFIG_SMP |
690 | d->smp = kzalloc(d->nr_reg * sizeof(*d->smp), GFP_NOWAIT); | 680 | d->smp = kzalloc(d->nr_reg * sizeof(*d->smp), GFP_NOWAIT); |
@@ -727,14 +717,12 @@ void __init register_intc_controller(struct intc_desc *desc) | |||
727 | d->chip.set_type = intc_set_sense; | 717 | d->chip.set_type = intc_set_sense; |
728 | d->chip.set_wake = intc_set_wake; | 718 | d->chip.set_wake = intc_set_wake; |
729 | 719 | ||
730 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
731 | if (desc->ack_regs) { | 720 | if (desc->ack_regs) { |
732 | for (i = 0; i < desc->nr_ack_regs; i++) | 721 | for (i = 0; i < desc->nr_ack_regs; i++) |
733 | k += save_reg(d, k, desc->ack_regs[i].set_reg, 0); | 722 | k += save_reg(d, k, desc->ack_regs[i].set_reg, 0); |
734 | 723 | ||
735 | d->chip.mask_ack = intc_mask_ack; | 724 | d->chip.mask_ack = intc_mask_ack; |
736 | } | 725 | } |
737 | #endif | ||
738 | 726 | ||
739 | BUG_ON(k > 256); /* _INTC_ADDR_E() and _INTC_ADDR_D() are 8 bits */ | 727 | BUG_ON(k > 256); /* _INTC_ADDR_E() and _INTC_ADDR_D() are 8 bits */ |
740 | 728 | ||
diff --git a/include/linux/sh_intc.h b/include/linux/sh_intc.h index 68e212ff9dde..4e4b22d50164 100644 --- a/include/linux/sh_intc.h +++ b/include/linux/sh_intc.h | |||
@@ -57,10 +57,8 @@ struct intc_desc { | |||
57 | struct intc_sense_reg *sense_regs; | 57 | struct intc_sense_reg *sense_regs; |
58 | unsigned int nr_sense_regs; | 58 | unsigned int nr_sense_regs; |
59 | char *name; | 59 | char *name; |
60 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
61 | struct intc_mask_reg *ack_regs; | 60 | struct intc_mask_reg *ack_regs; |
62 | unsigned int nr_ack_regs; | 61 | unsigned int nr_ack_regs; |
63 | #endif | ||
64 | }; | 62 | }; |
65 | 63 | ||
66 | #define _INTC_ARRAY(a) a, sizeof(a)/sizeof(*a) | 64 | #define _INTC_ARRAY(a) a, sizeof(a)/sizeof(*a) |
@@ -73,7 +71,6 @@ struct intc_desc symbol __initdata = { \ | |||
73 | chipname, \ | 71 | chipname, \ |
74 | } | 72 | } |
75 | 73 | ||
76 | #if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH4A) | ||
77 | #define DECLARE_INTC_DESC_ACK(symbol, chipname, vectors, groups, \ | 74 | #define DECLARE_INTC_DESC_ACK(symbol, chipname, vectors, groups, \ |
78 | mask_regs, prio_regs, sense_regs, ack_regs) \ | 75 | mask_regs, prio_regs, sense_regs, ack_regs) \ |
79 | struct intc_desc symbol __initdata = { \ | 76 | struct intc_desc symbol __initdata = { \ |
@@ -83,7 +80,6 @@ struct intc_desc symbol __initdata = { \ | |||
83 | chipname, \ | 80 | chipname, \ |
84 | _INTC_ARRAY(ack_regs), \ | 81 | _INTC_ARRAY(ack_regs), \ |
85 | } | 82 | } |
86 | #endif | ||
87 | 83 | ||
88 | void __init register_intc_controller(struct intc_desc *desc); | 84 | void __init register_intc_controller(struct intc_desc *desc); |
89 | int intc_set_priority(unsigned int irq, unsigned int prio); | 85 | int intc_set_priority(unsigned int irq, unsigned int prio); |