diff options
-rw-r--r-- | arch/sparc/kernel/sun4d_irq.c | 42 |
1 files changed, 16 insertions, 26 deletions
diff --git a/arch/sparc/kernel/sun4d_irq.c b/arch/sparc/kernel/sun4d_irq.c index 4156bf6657fb..6e3bf6eee543 100644 --- a/arch/sparc/kernel/sun4d_irq.c +++ b/arch/sparc/kernel/sun4d_irq.c | |||
@@ -60,9 +60,7 @@ static struct sun4d_timer_regs __iomem *sun4d_timers; | |||
60 | #define MAX_STATIC_ALLOC 4 | 60 | #define MAX_STATIC_ALLOC 4 |
61 | extern struct irqaction static_irqaction[MAX_STATIC_ALLOC]; | 61 | extern struct irqaction static_irqaction[MAX_STATIC_ALLOC]; |
62 | extern int static_irq_count; | 62 | extern int static_irq_count; |
63 | #ifdef CONFIG_SMP | ||
64 | static unsigned char sbus_tid[32]; | 63 | static unsigned char sbus_tid[32]; |
65 | #endif | ||
66 | 64 | ||
67 | static struct irqaction *irq_action[NR_IRQS]; | 65 | static struct irqaction *irq_action[NR_IRQS]; |
68 | extern spinlock_t irq_action_lock; | 66 | extern spinlock_t irq_action_lock; |
@@ -81,9 +79,9 @@ static int sbus_to_pil[] = { | |||
81 | }; | 79 | }; |
82 | 80 | ||
83 | static int nsbi; | 81 | static int nsbi; |
84 | #ifdef CONFIG_SMP | 82 | |
83 | /* Exported for sun4d_smp.c */ | ||
85 | DEFINE_SPINLOCK(sun4d_imsk_lock); | 84 | DEFINE_SPINLOCK(sun4d_imsk_lock); |
86 | #endif | ||
87 | 85 | ||
88 | int show_sun4d_interrupts(struct seq_file *p, void *v) | 86 | int show_sun4d_interrupts(struct seq_file *p, void *v) |
89 | { | 87 | { |
@@ -349,36 +347,28 @@ out: | |||
349 | 347 | ||
350 | static void sun4d_disable_irq(unsigned int irq) | 348 | static void sun4d_disable_irq(unsigned int irq) |
351 | { | 349 | { |
352 | #ifdef CONFIG_SMP | ||
353 | int tid = sbus_tid[(irq >> 5) - 1]; | 350 | int tid = sbus_tid[(irq >> 5) - 1]; |
354 | unsigned long flags; | 351 | unsigned long flags; |
355 | #endif | ||
356 | 352 | ||
357 | if (irq < NR_IRQS) return; | 353 | if (irq < NR_IRQS) |
358 | #ifdef CONFIG_SMP | 354 | return; |
355 | |||
359 | spin_lock_irqsave(&sun4d_imsk_lock, flags); | 356 | spin_lock_irqsave(&sun4d_imsk_lock, flags); |
360 | cc_set_imsk_other(tid, cc_get_imsk_other(tid) | (1 << sbus_to_pil[(irq >> 2) & 7])); | 357 | cc_set_imsk_other(tid, cc_get_imsk_other(tid) | (1 << sbus_to_pil[(irq >> 2) & 7])); |
361 | spin_unlock_irqrestore(&sun4d_imsk_lock, flags); | 358 | spin_unlock_irqrestore(&sun4d_imsk_lock, flags); |
362 | #else | ||
363 | cc_set_imsk(cc_get_imsk() | (1 << sbus_to_pil[(irq >> 2) & 7])); | ||
364 | #endif | ||
365 | } | 359 | } |
366 | 360 | ||
367 | static void sun4d_enable_irq(unsigned int irq) | 361 | static void sun4d_enable_irq(unsigned int irq) |
368 | { | 362 | { |
369 | #ifdef CONFIG_SMP | ||
370 | int tid = sbus_tid[(irq >> 5) - 1]; | 363 | int tid = sbus_tid[(irq >> 5) - 1]; |
371 | unsigned long flags; | 364 | unsigned long flags; |
372 | #endif | ||
373 | 365 | ||
374 | if (irq < NR_IRQS) return; | 366 | if (irq < NR_IRQS) |
375 | #ifdef CONFIG_SMP | 367 | return; |
368 | |||
376 | spin_lock_irqsave(&sun4d_imsk_lock, flags); | 369 | spin_lock_irqsave(&sun4d_imsk_lock, flags); |
377 | cc_set_imsk_other(tid, cc_get_imsk_other(tid) & ~(1 << sbus_to_pil[(irq >> 2) & 7])); | 370 | cc_set_imsk_other(tid, cc_get_imsk_other(tid) & ~(1 << sbus_to_pil[(irq >> 2) & 7])); |
378 | spin_unlock_irqrestore(&sun4d_imsk_lock, flags); | 371 | spin_unlock_irqrestore(&sun4d_imsk_lock, flags); |
379 | #else | ||
380 | cc_set_imsk(cc_get_imsk() & ~(1 << sbus_to_pil[(irq >> 2) & 7])); | ||
381 | #endif | ||
382 | } | 372 | } |
383 | 373 | ||
384 | #ifdef CONFIG_SMP | 374 | #ifdef CONFIG_SMP |
@@ -557,6 +547,11 @@ static void __init sun4d_init_timers(irq_handler_t counter_fn) | |||
557 | void __init sun4d_init_sbi_irq(void) | 547 | void __init sun4d_init_sbi_irq(void) |
558 | { | 548 | { |
559 | struct device_node *dp; | 549 | struct device_node *dp; |
550 | int target_cpu = 0; | ||
551 | |||
552 | #ifdef CONFIG_SMP | ||
553 | target_cpu = boot_cpu_id; | ||
554 | #endif | ||
560 | 555 | ||
561 | nsbi = 0; | 556 | nsbi = 0; |
562 | for_each_node_by_name(dp, "sbi") | 557 | for_each_node_by_name(dp, "sbi") |
@@ -571,14 +566,9 @@ void __init sun4d_init_sbi_irq(void) | |||
571 | int board = of_getintprop_default(dp, "board#", 0); | 566 | int board = of_getintprop_default(dp, "board#", 0); |
572 | unsigned int mask; | 567 | unsigned int mask; |
573 | 568 | ||
574 | #ifdef CONFIG_SMP | 569 | set_sbi_tid(devid, target_cpu << 3); |
575 | { | 570 | sbus_tid[board] = target_cpu; |
576 | extern unsigned char boot_cpu_id; | 571 | |
577 | |||
578 | set_sbi_tid(devid, boot_cpu_id << 3); | ||
579 | sbus_tid[board] = boot_cpu_id; | ||
580 | } | ||
581 | #endif | ||
582 | /* Get rid of pending irqs from PROM */ | 572 | /* Get rid of pending irqs from PROM */ |
583 | mask = acquire_sbi(devid, 0xffffffff); | 573 | mask = acquire_sbi(devid, 0xffffffff); |
584 | if (mask) { | 574 | if (mask) { |