diff options
author | George G. Davis <gdavis@mvista.com> | 2007-06-25 20:38:27 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2007-07-12 06:13:35 -0400 |
commit | 909d6c6c80311f800aee338e5fa528818b115951 (patch) | |
tree | d4934d8ea67ade7c78e02e4cebd0fc934d3698b1 /arch/arm | |
parent | 9d20fdd58e74d4d26dc5216efaaa0f800c23dd3a (diff) |
[ARM] 4453/1: Fully Decode ARM instruction set state in show_regs() tombstone
The ARM show_regs() tombstone only partially decodes which ARM ISA was
executing at the time a fault occurred displaying either "(T)" for the
Thumb case or nothing at all for other cases. This patch therefore
explicitly identifies which state the processor is in at the time of
a fault: ARM, Thumb, Jazelle or JazelleEE.
Signed-off-by: George G. Davis <gdavis@mvista.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/kernel/process.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c index 842361777d4e..93b7f8e22dcc 100644 --- a/arch/arm/kernel/process.c +++ b/arch/arm/kernel/process.c | |||
@@ -44,6 +44,10 @@ static const char *processor_modes[] = { | |||
44 | "UK8_32" , "UK9_32" , "UK10_32", "UND_32" , "UK12_32", "UK13_32", "UK14_32", "SYS_32" | 44 | "UK8_32" , "UK9_32" , "UK10_32", "UND_32" , "UK12_32", "UK13_32", "UK14_32", "SYS_32" |
45 | }; | 45 | }; |
46 | 46 | ||
47 | static const char *isa_modes[] = { | ||
48 | "ARM" , "Thumb" , "Jazelle", "ThumbEE" | ||
49 | }; | ||
50 | |||
47 | extern void setup_mm_for_reboot(char mode); | 51 | extern void setup_mm_for_reboot(char mode); |
48 | 52 | ||
49 | static volatile int hlt_counter; | 53 | static volatile int hlt_counter; |
@@ -230,11 +234,11 @@ void __show_regs(struct pt_regs *regs) | |||
230 | buf[3] = flags & PSR_V_BIT ? 'V' : 'v'; | 234 | buf[3] = flags & PSR_V_BIT ? 'V' : 'v'; |
231 | buf[4] = '\0'; | 235 | buf[4] = '\0'; |
232 | 236 | ||
233 | printk("Flags: %s IRQs o%s FIQs o%s Mode %s%s Segment %s\n", | 237 | printk("Flags: %s IRQs o%s FIQs o%s Mode %s ISA %s Segment %s\n", |
234 | buf, interrupts_enabled(regs) ? "n" : "ff", | 238 | buf, interrupts_enabled(regs) ? "n" : "ff", |
235 | fast_interrupts_enabled(regs) ? "n" : "ff", | 239 | fast_interrupts_enabled(regs) ? "n" : "ff", |
236 | processor_modes[processor_mode(regs)], | 240 | processor_modes[processor_mode(regs)], |
237 | thumb_mode(regs) ? " (T)" : "", | 241 | isa_modes[isa_mode(regs)], |
238 | get_fs() == get_ds() ? "kernel" : "user"); | 242 | get_fs() == get_ds() ? "kernel" : "user"); |
239 | #ifdef CONFIG_CPU_CP15 | 243 | #ifdef CONFIG_CPU_CP15 |
240 | { | 244 | { |