diff options
Diffstat (limited to 'arch/blackfin/mach-common')
-rw-r--r-- | arch/blackfin/mach-common/ints-priority.c | 86 |
1 files changed, 39 insertions, 47 deletions
diff --git a/arch/blackfin/mach-common/ints-priority.c b/arch/blackfin/mach-common/ints-priority.c index 01926e5948ba..766e9f6d0627 100644 --- a/arch/blackfin/mach-common/ints-priority.c +++ b/arch/blackfin/mach-common/ints-priority.c | |||
@@ -19,9 +19,6 @@ | |||
19 | #ifdef CONFIG_IPIPE | 19 | #ifdef CONFIG_IPIPE |
20 | #include <linux/ipipe.h> | 20 | #include <linux/ipipe.h> |
21 | #endif | 21 | #endif |
22 | #ifdef CONFIG_KGDB | ||
23 | #include <linux/kgdb.h> | ||
24 | #endif | ||
25 | #include <asm/traps.h> | 22 | #include <asm/traps.h> |
26 | #include <asm/blackfin.h> | 23 | #include <asm/blackfin.h> |
27 | #include <asm/gpio.h> | 24 | #include <asm/gpio.h> |
@@ -153,24 +150,22 @@ static void bfin_core_unmask_irq(struct irq_data *d) | |||
153 | 150 | ||
154 | static void bfin_internal_mask_irq(unsigned int irq) | 151 | static void bfin_internal_mask_irq(unsigned int irq) |
155 | { | 152 | { |
156 | unsigned long flags; | 153 | unsigned long flags = hard_local_irq_save(); |
157 | 154 | ||
158 | #ifdef CONFIG_BF53x | 155 | #ifdef SIC_IMASK0 |
159 | flags = hard_local_irq_save(); | 156 | unsigned mask_bank = SIC_SYSIRQ(irq) / 32; |
160 | bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() & | 157 | unsigned mask_bit = SIC_SYSIRQ(irq) % 32; |
161 | ~(1 << SIC_SYSIRQ(irq))); | ||
162 | #else | ||
163 | unsigned mask_bank, mask_bit; | ||
164 | flags = hard_local_irq_save(); | ||
165 | mask_bank = SIC_SYSIRQ(irq) / 32; | ||
166 | mask_bit = SIC_SYSIRQ(irq) % 32; | ||
167 | bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) & | 158 | bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) & |
168 | ~(1 << mask_bit)); | 159 | ~(1 << mask_bit)); |
169 | #ifdef CONFIG_SMP | 160 | # ifdef CONFIG_SMP |
170 | bfin_write_SICB_IMASK(mask_bank, bfin_read_SICB_IMASK(mask_bank) & | 161 | bfin_write_SICB_IMASK(mask_bank, bfin_read_SICB_IMASK(mask_bank) & |
171 | ~(1 << mask_bit)); | 162 | ~(1 << mask_bit)); |
163 | # endif | ||
164 | #else | ||
165 | bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() & | ||
166 | ~(1 << SIC_SYSIRQ(irq))); | ||
172 | #endif | 167 | #endif |
173 | #endif | 168 | |
174 | hard_local_irq_restore(flags); | 169 | hard_local_irq_restore(flags); |
175 | } | 170 | } |
176 | 171 | ||
@@ -186,30 +181,28 @@ static void bfin_internal_unmask_irq_affinity(unsigned int irq, | |||
186 | static void bfin_internal_unmask_irq(unsigned int irq) | 181 | static void bfin_internal_unmask_irq(unsigned int irq) |
187 | #endif | 182 | #endif |
188 | { | 183 | { |
189 | unsigned long flags; | 184 | unsigned long flags = hard_local_irq_save(); |
190 | 185 | ||
191 | #ifdef CONFIG_BF53x | 186 | #ifdef SIC_IMASK0 |
192 | flags = hard_local_irq_save(); | 187 | unsigned mask_bank = SIC_SYSIRQ(irq) / 32; |
193 | bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() | | 188 | unsigned mask_bit = SIC_SYSIRQ(irq) % 32; |
194 | (1 << SIC_SYSIRQ(irq))); | 189 | # ifdef CONFIG_SMP |
195 | #else | ||
196 | unsigned mask_bank, mask_bit; | ||
197 | flags = hard_local_irq_save(); | ||
198 | mask_bank = SIC_SYSIRQ(irq) / 32; | ||
199 | mask_bit = SIC_SYSIRQ(irq) % 32; | ||
200 | #ifdef CONFIG_SMP | ||
201 | if (cpumask_test_cpu(0, affinity)) | 190 | if (cpumask_test_cpu(0, affinity)) |
202 | #endif | 191 | # endif |
203 | bfin_write_SIC_IMASK(mask_bank, | 192 | bfin_write_SIC_IMASK(mask_bank, |
204 | bfin_read_SIC_IMASK(mask_bank) | | 193 | bfin_read_SIC_IMASK(mask_bank) | |
205 | (1 << mask_bit)); | 194 | (1 << mask_bit)); |
206 | #ifdef CONFIG_SMP | 195 | # ifdef CONFIG_SMP |
207 | if (cpumask_test_cpu(1, affinity)) | 196 | if (cpumask_test_cpu(1, affinity)) |
208 | bfin_write_SICB_IMASK(mask_bank, | 197 | bfin_write_SICB_IMASK(mask_bank, |
209 | bfin_read_SICB_IMASK(mask_bank) | | 198 | bfin_read_SICB_IMASK(mask_bank) | |
210 | (1 << mask_bit)); | 199 | (1 << mask_bit)); |
200 | # endif | ||
201 | #else | ||
202 | bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() | | ||
203 | (1 << SIC_SYSIRQ(irq))); | ||
211 | #endif | 204 | #endif |
212 | #endif | 205 | |
213 | hard_local_irq_restore(flags); | 206 | hard_local_irq_restore(flags); |
214 | } | 207 | } |
215 | 208 | ||
@@ -292,6 +285,8 @@ static int bfin_internal_set_wake_chip(struct irq_data *d, unsigned int state) | |||
292 | { | 285 | { |
293 | return bfin_internal_set_wake(d->irq, state); | 286 | return bfin_internal_set_wake(d->irq, state); |
294 | } | 287 | } |
288 | #else | ||
289 | # define bfin_internal_set_wake_chip NULL | ||
295 | #endif | 290 | #endif |
296 | 291 | ||
297 | static struct irq_chip bfin_core_irqchip = { | 292 | static struct irq_chip bfin_core_irqchip = { |
@@ -312,9 +307,7 @@ static struct irq_chip bfin_internal_irqchip = { | |||
312 | #ifdef CONFIG_SMP | 307 | #ifdef CONFIG_SMP |
313 | .irq_set_affinity = bfin_internal_set_affinity, | 308 | .irq_set_affinity = bfin_internal_set_affinity, |
314 | #endif | 309 | #endif |
315 | #ifdef CONFIG_PM | ||
316 | .irq_set_wake = bfin_internal_set_wake_chip, | 310 | .irq_set_wake = bfin_internal_set_wake_chip, |
317 | #endif | ||
318 | }; | 311 | }; |
319 | 312 | ||
320 | static void bfin_handle_irq(unsigned irq) | 313 | static void bfin_handle_irq(unsigned irq) |
@@ -508,6 +501,8 @@ int bfin_mac_status_set_wake(struct irq_data *d, unsigned int state) | |||
508 | return bfin_internal_set_wake(IRQ_MAC_ERROR, state); | 501 | return bfin_internal_set_wake(IRQ_MAC_ERROR, state); |
509 | #endif | 502 | #endif |
510 | } | 503 | } |
504 | #else | ||
505 | # define bfin_mac_status_set_wake NULL | ||
511 | #endif | 506 | #endif |
512 | 507 | ||
513 | static struct irq_chip bfin_mac_status_irqchip = { | 508 | static struct irq_chip bfin_mac_status_irqchip = { |
@@ -516,9 +511,7 @@ static struct irq_chip bfin_mac_status_irqchip = { | |||
516 | .irq_mask_ack = bfin_mac_status_mask_irq, | 511 | .irq_mask_ack = bfin_mac_status_mask_irq, |
517 | .irq_mask = bfin_mac_status_mask_irq, | 512 | .irq_mask = bfin_mac_status_mask_irq, |
518 | .irq_unmask = bfin_mac_status_unmask_irq, | 513 | .irq_unmask = bfin_mac_status_unmask_irq, |
519 | #ifdef CONFIG_PM | ||
520 | .irq_set_wake = bfin_mac_status_set_wake, | 514 | .irq_set_wake = bfin_mac_status_set_wake, |
521 | #endif | ||
522 | }; | 515 | }; |
523 | 516 | ||
524 | static void bfin_demux_mac_status_irq(unsigned int int_err_irq, | 517 | static void bfin_demux_mac_status_irq(unsigned int int_err_irq, |
@@ -681,6 +674,8 @@ int bfin_gpio_set_wake(struct irq_data *d, unsigned int state) | |||
681 | { | 674 | { |
682 | return gpio_pm_wakeup_ctrl(irq_to_gpio(d->irq), state); | 675 | return gpio_pm_wakeup_ctrl(irq_to_gpio(d->irq), state); |
683 | } | 676 | } |
677 | #else | ||
678 | # define bfin_gpio_set_wake NULL | ||
684 | #endif | 679 | #endif |
685 | 680 | ||
686 | static void bfin_demux_gpio_irq(unsigned int inta_irq, | 681 | static void bfin_demux_gpio_irq(unsigned int inta_irq, |
@@ -699,7 +694,7 @@ static void bfin_demux_gpio_irq(unsigned int inta_irq, | |||
699 | irq = IRQ_PH0; | 694 | irq = IRQ_PH0; |
700 | break; | 695 | break; |
701 | # endif | 696 | # endif |
702 | #elif defined(CONFIG_BF538) || defined(CONFIG_BF539) | 697 | #elif defined(BF538_FAMILY) |
703 | case IRQ_PORTF_INTA: | 698 | case IRQ_PORTF_INTA: |
704 | irq = IRQ_PF0; | 699 | irq = IRQ_PF0; |
705 | break; | 700 | break; |
@@ -1036,6 +1031,8 @@ void bfin_pm_restore(void) | |||
1036 | } | 1031 | } |
1037 | } | 1032 | } |
1038 | } | 1033 | } |
1034 | #else | ||
1035 | # define bfin_gpio_set_wake NULL | ||
1039 | #endif | 1036 | #endif |
1040 | 1037 | ||
1041 | static void bfin_demux_gpio_irq(unsigned int inta_irq, | 1038 | static void bfin_demux_gpio_irq(unsigned int inta_irq, |
@@ -1088,9 +1085,7 @@ static struct irq_chip bfin_gpio_irqchip = { | |||
1088 | .irq_set_type = bfin_gpio_irq_type, | 1085 | .irq_set_type = bfin_gpio_irq_type, |
1089 | .irq_startup = bfin_gpio_irq_startup, | 1086 | .irq_startup = bfin_gpio_irq_startup, |
1090 | .irq_shutdown = bfin_gpio_irq_shutdown, | 1087 | .irq_shutdown = bfin_gpio_irq_shutdown, |
1091 | #ifdef CONFIG_PM | ||
1092 | .irq_set_wake = bfin_gpio_set_wake, | 1088 | .irq_set_wake = bfin_gpio_set_wake, |
1093 | #endif | ||
1094 | }; | 1089 | }; |
1095 | 1090 | ||
1096 | void __cpuinit init_exception_vectors(void) | 1091 | void __cpuinit init_exception_vectors(void) |
@@ -1124,12 +1119,12 @@ int __init init_arch_irq(void) | |||
1124 | { | 1119 | { |
1125 | int irq; | 1120 | int irq; |
1126 | unsigned long ilat = 0; | 1121 | unsigned long ilat = 0; |
1122 | |||
1127 | /* Disable all the peripheral intrs - page 4-29 HW Ref manual */ | 1123 | /* Disable all the peripheral intrs - page 4-29 HW Ref manual */ |
1128 | #if defined(CONFIG_BF54x) || defined(CONFIG_BF52x) || defined(CONFIG_BF561) \ | 1124 | #ifdef SIC_IMASK0 |
1129 | || defined(BF538_FAMILY) || defined(CONFIG_BF51x) | ||
1130 | bfin_write_SIC_IMASK0(SIC_UNMASK_ALL); | 1125 | bfin_write_SIC_IMASK0(SIC_UNMASK_ALL); |
1131 | bfin_write_SIC_IMASK1(SIC_UNMASK_ALL); | 1126 | bfin_write_SIC_IMASK1(SIC_UNMASK_ALL); |
1132 | # ifdef CONFIG_BF54x | 1127 | # ifdef SIC_IMASK2 |
1133 | bfin_write_SIC_IMASK2(SIC_UNMASK_ALL); | 1128 | bfin_write_SIC_IMASK2(SIC_UNMASK_ALL); |
1134 | # endif | 1129 | # endif |
1135 | # ifdef CONFIG_SMP | 1130 | # ifdef CONFIG_SMP |
@@ -1183,7 +1178,7 @@ int __init init_arch_irq(void) | |||
1183 | case IRQ_PROG0_INTA: | 1178 | case IRQ_PROG0_INTA: |
1184 | case IRQ_PROG1_INTA: | 1179 | case IRQ_PROG1_INTA: |
1185 | case IRQ_PROG2_INTA: | 1180 | case IRQ_PROG2_INTA: |
1186 | #elif defined(CONFIG_BF538) || defined(CONFIG_BF539) | 1181 | #elif defined(BF538_FAMILY) |
1187 | case IRQ_PORTF_INTA: | 1182 | case IRQ_PORTF_INTA: |
1188 | #endif | 1183 | #endif |
1189 | irq_set_chained_handler(irq, bfin_demux_gpio_irq); | 1184 | irq_set_chained_handler(irq, bfin_demux_gpio_irq); |
@@ -1210,11 +1205,10 @@ int __init init_arch_irq(void) | |||
1210 | case IRQ_CORETMR: | 1205 | case IRQ_CORETMR: |
1211 | # ifdef CONFIG_SMP | 1206 | # ifdef CONFIG_SMP |
1212 | irq_set_handler(irq, handle_percpu_irq); | 1207 | irq_set_handler(irq, handle_percpu_irq); |
1213 | break; | ||
1214 | # else | 1208 | # else |
1215 | irq_set_handler(irq, handle_simple_irq); | 1209 | irq_set_handler(irq, handle_simple_irq); |
1216 | break; | ||
1217 | # endif | 1210 | # endif |
1211 | break; | ||
1218 | #endif | 1212 | #endif |
1219 | 1213 | ||
1220 | #ifdef CONFIG_TICKSOURCE_GPTMR0 | 1214 | #ifdef CONFIG_TICKSOURCE_GPTMR0 |
@@ -1223,15 +1217,13 @@ int __init init_arch_irq(void) | |||
1223 | break; | 1217 | break; |
1224 | #endif | 1218 | #endif |
1225 | 1219 | ||
1226 | #ifdef CONFIG_IPIPE | ||
1227 | default: | 1220 | default: |
1221 | #ifdef CONFIG_IPIPE | ||
1228 | irq_set_handler(irq, handle_level_irq); | 1222 | irq_set_handler(irq, handle_level_irq); |
1229 | break; | 1223 | #else |
1230 | #else /* !CONFIG_IPIPE */ | ||
1231 | default: | ||
1232 | irq_set_handler(irq, handle_simple_irq); | 1224 | irq_set_handler(irq, handle_simple_irq); |
1225 | #endif | ||
1233 | break; | 1226 | break; |
1234 | #endif /* !CONFIG_IPIPE */ | ||
1235 | } | 1227 | } |
1236 | } | 1228 | } |
1237 | 1229 | ||