aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStuart Yoder <stuart.yoder@freescale.com>2011-05-19 09:54:26 -0400
committerKumar Gala <galak@kernel.crashing.org>2011-06-22 22:44:59 -0400
commit6ec36b5848a8336d3a0010727b9365c3254d2d2e (patch)
tree7876f705354d8b6e73a6079b5bd6561f0b8e2cbd
parent47fe819e7555b31d24f8a11d9b2568d8f5de8b01 (diff)
powerpc: make irq_choose_cpu() available to all PIC drivers
Move irq_choose_cpu() into arch/powerpc/kernel/irq.c so that it can be used by other PIC drivers. The function is not MPIC-specific. Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com> Signed-off-by: Timur Tabi <timur@freescale.com> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
-rw-r--r--arch/powerpc/include/asm/irq.h2
-rw-r--r--arch/powerpc/kernel/irq.c35
-rw-r--r--arch/powerpc/sysdev/mpic.c36
3 files changed, 37 insertions, 36 deletions
diff --git a/arch/powerpc/include/asm/irq.h b/arch/powerpc/include/asm/irq.h
index 1bff591f7f72..c57a28e52b64 100644
--- a/arch/powerpc/include/asm/irq.h
+++ b/arch/powerpc/include/asm/irq.h
@@ -330,5 +330,7 @@ extern int call_handle_irq(int irq, void *p1,
330 struct thread_info *tp, void *func); 330 struct thread_info *tp, void *func);
331extern void do_IRQ(struct pt_regs *regs); 331extern void do_IRQ(struct pt_regs *regs);
332 332
333int irq_choose_cpu(const struct cpumask *mask);
334
333#endif /* _ASM_IRQ_H */ 335#endif /* _ASM_IRQ_H */
334#endif /* __KERNEL__ */ 336#endif /* __KERNEL__ */
diff --git a/arch/powerpc/kernel/irq.c b/arch/powerpc/kernel/irq.c
index 5b428e308666..38dd10e2841d 100644
--- a/arch/powerpc/kernel/irq.c
+++ b/arch/powerpc/kernel/irq.c
@@ -882,6 +882,41 @@ unsigned int irq_find_mapping(struct irq_host *host,
882} 882}
883EXPORT_SYMBOL_GPL(irq_find_mapping); 883EXPORT_SYMBOL_GPL(irq_find_mapping);
884 884
885#ifdef CONFIG_SMP
886int irq_choose_cpu(const struct cpumask *mask)
887{
888 int cpuid;
889
890 if (cpumask_equal(mask, cpu_all_mask)) {
891 static int irq_rover;
892 static DEFINE_RAW_SPINLOCK(irq_rover_lock);
893 unsigned long flags;
894
895 /* Round-robin distribution... */
896do_round_robin:
897 raw_spin_lock_irqsave(&irq_rover_lock, flags);
898
899 irq_rover = cpumask_next(irq_rover, cpu_online_mask);
900 if (irq_rover >= nr_cpu_ids)
901 irq_rover = cpumask_first(cpu_online_mask);
902
903 cpuid = irq_rover;
904
905 raw_spin_unlock_irqrestore(&irq_rover_lock, flags);
906 } else {
907 cpuid = cpumask_first_and(mask, cpu_online_mask);
908 if (cpuid >= nr_cpu_ids)
909 goto do_round_robin;
910 }
911
912 return get_hard_smp_processor_id(cpuid);
913}
914#else
915int irq_choose_cpu(const struct cpumask *mask)
916{
917 return hard_smp_processor_id();
918}
919#endif
885 920
886unsigned int irq_radix_revmap_lookup(struct irq_host *host, 921unsigned int irq_radix_revmap_lookup(struct irq_host *host,
887 irq_hw_number_t hwirq) 922 irq_hw_number_t hwirq)
diff --git a/arch/powerpc/sysdev/mpic.c b/arch/powerpc/sysdev/mpic.c
index 3f995dcf95c9..d3bc7e595d0b 100644
--- a/arch/powerpc/sysdev/mpic.c
+++ b/arch/powerpc/sysdev/mpic.c
@@ -597,42 +597,6 @@ static void __init mpic_scan_ht_pics(struct mpic *mpic)
597 597
598#endif /* CONFIG_MPIC_U3_HT_IRQS */ 598#endif /* CONFIG_MPIC_U3_HT_IRQS */
599 599
600#ifdef CONFIG_SMP
601static int irq_choose_cpu(const struct cpumask *mask)
602{
603 int cpuid;
604
605 if (cpumask_equal(mask, cpu_all_mask)) {
606 static int irq_rover = 0;
607 static DEFINE_RAW_SPINLOCK(irq_rover_lock);
608 unsigned long flags;
609
610 /* Round-robin distribution... */
611 do_round_robin:
612 raw_spin_lock_irqsave(&irq_rover_lock, flags);
613
614 irq_rover = cpumask_next(irq_rover, cpu_online_mask);
615 if (irq_rover >= nr_cpu_ids)
616 irq_rover = cpumask_first(cpu_online_mask);
617
618 cpuid = irq_rover;
619
620 raw_spin_unlock_irqrestore(&irq_rover_lock, flags);
621 } else {
622 cpuid = cpumask_first_and(mask, cpu_online_mask);
623 if (cpuid >= nr_cpu_ids)
624 goto do_round_robin;
625 }
626
627 return get_hard_smp_processor_id(cpuid);
628}
629#else
630static int irq_choose_cpu(const struct cpumask *mask)
631{
632 return hard_smp_processor_id();
633}
634#endif
635
636/* Find an mpic associated with a given linux interrupt */ 600/* Find an mpic associated with a given linux interrupt */
637static struct mpic *mpic_find(unsigned int irq) 601static struct mpic *mpic_find(unsigned int irq)
638{ 602{