aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ppc64/kernel/xics.c
diff options
context:
space:
mode:
authorPaul Mackerras <paulus@samba.org>2005-05-06 16:28:56 +1000
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-05-06 08:07:01 -0700
commit6c80a21cb1825e576ffff9df2302bf0fa1065ceb (patch)
treeb364bcb9f1ed3b187cf96c7c9167ab850de808cc /arch/ppc64/kernel/xics.c
parent2512809255d018744fe6c2f5e996c83769846c07 (diff)
downloadkernel_samsung_smdk4412-6c80a21cb1825e576ffff9df2302bf0fa1065ceb.zip
kernel_samsung_smdk4412-6c80a21cb1825e576ffff9df2302bf0fa1065ceb.tar.gz
kernel_samsung_smdk4412-6c80a21cb1825e576ffff9df2302bf0fa1065ceb.tar.bz2
[PATCH] ppc64: global interrupt queue cleanup
Move the code to set global interrupt queue membership to xics.c, and remove no longer needed extern declarations. Also call it on all cpus (even the boot cpu) to prepare for kexec. Signed-off-by: Milton Miller <miltonm@bga.com> Signed-off-by: R Sharada <sharada@in.ibm.com> Signed-off-by: Paul Mackerras <paulus@samba.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/ppc64/kernel/xics.c')
-rw-r--r--arch/ppc64/kernel/xics.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/arch/ppc64/kernel/xics.c b/arch/ppc64/kernel/xics.c
index eedd1d3..879f39b 100644
--- a/arch/ppc64/kernel/xics.c
+++ b/arch/ppc64/kernel/xics.c
@@ -432,6 +432,7 @@ void xics_cause_IPI(int cpu)
{
ops->qirr_info(cpu, IPI_PRIORITY);
}
+#endif /* CONFIG_SMP */
void xics_setup_cpu(void)
{
@@ -439,9 +440,17 @@ void xics_setup_cpu(void)
ops->cppr_info(cpu, 0xff);
iosync();
-}
-#endif /* CONFIG_SMP */
+ /*
+ * Put the calling processor into the GIQ. This is really only
+ * necessary from a secondary thread as the OF start-cpu interface
+ * performs this function for us on primary threads.
+ *
+ * XXX: undo of teardown on kexec needs this too, as may hotplug
+ */
+ rtas_set_indicator(GLOBAL_INTERRUPT_QUEUE,
+ (1UL << interrupt_server_size) - 1 - default_distrib_server, 1);
+}
void xics_init_IRQ(void)
{
@@ -563,8 +572,7 @@ nextnode:
for (; i < NR_IRQS; ++i)
get_irq_desc(i)->handler = &xics_pic;
- ops->cppr_info(boot_cpuid, 0xff);
- iosync();
+ xics_setup_cpu();
ppc64_boot_msg(0x21, "XICS Done");
}