aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/xmon
diff options
context:
space:
mode:
authorJimi Xenidis <jimix@pobox.com>2011-09-23 01:40:46 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2011-09-29 02:58:22 -0400
commit66857b3a9e88ac6f6e279eaa06b84367e662c0dd (patch)
treebeae75afef05fc761d338f3ec9d238d60ffa4008 /arch/powerpc/xmon
parentbb36c44557a4fcbaa17c0f2776e12a05a691b432 (diff)
powerpc: Fix xmon for systems without MSR[RI]
Based on patch by David Gibson <dwg@au1.ibm.com> xmon has a longstanding bug on systems which are SMP-capable but lack the MSR[RI] bit. In these cases, xmon invoked by IPI on secondary CPUs will not properly keep quiet, but will print stuff, thereby garbling the primary xmon's output. This patch fixes it, by ignoring the RI bit if the processor does not support it. There's already a version of this for 4xx upstream, which we'll need to extend to other RI-lacking CPUs at some point. For now this adds Book3e processors to the mix. Signed-off-by: Jimi Xenidis <jimix@pobox.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/xmon')
-rw-r--r--arch/powerpc/xmon/xmon.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/powerpc/xmon/xmon.c b/arch/powerpc/xmon/xmon.c
index 42541bbcc7fa..13f82f847669 100644
--- a/arch/powerpc/xmon/xmon.c
+++ b/arch/powerpc/xmon/xmon.c
@@ -340,8 +340,8 @@ int cpus_are_in_xmon(void)
340 340
341static inline int unrecoverable_excp(struct pt_regs *regs) 341static inline int unrecoverable_excp(struct pt_regs *regs)
342{ 342{
343#ifdef CONFIG_4xx 343#if defined(CONFIG_4xx) || defined(CONFIG_BOOK3E)
344 /* We have no MSR_RI bit on 4xx, so we simply return false */ 344 /* We have no MSR_RI bit on 4xx or Book3e, so we simply return false */
345 return 0; 345 return 0;
346#else 346#else
347 return ((regs->msr & MSR_RI) == 0); 347 return ((regs->msr & MSR_RI) == 0);