MIPS: Avoid accidental raw backtrace

Since commit 81a76d7119f6 ("MIPS: Avoid using unwind_stack() with
usermode") show_backtrace() invokes the raw backtracer when
cp0_status & ST0_KSU indicates user mode to fix issues on EVA kernels
where user and kernel address spaces overlap.

However this is used by show_stack() which creates its own pt_regs on
the stack and leaves cp0_status uninitialised in most of the code paths.
This results in the non deterministic use of the raw back tracer
depending on the previous stack content.

show_stack() deals exclusively with kernel mode stacks anyway, so
explicitly initialise regs.cp0_status to KSU_KERNEL (i.e. 0) to ensure
we get a useful backtrace.

Fixes: 81a76d7119f6 ("MIPS: Avoid using unwind_stack() with usermode")
Signed-off-by: James Hogan <james.hogan@imgtec.com>
Cc: linux-mips@linux-mips.org
Cc: <stable@vger.kernel.org> # 3.15+
Patchwork: https://patchwork.linux-mips.org/patch/16656/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>

authored by James Hogan and committed by Ralf Baechle 85423636 cad482c1

Changed files
+2
arch
mips
kernel
+2
arch/mips/kernel/traps.c
··· 201 201 { 202 202 struct pt_regs regs; 203 203 mm_segment_t old_fs = get_fs(); 204 + 205 + regs.cp0_status = KSU_KERNEL; 204 206 if (sp) { 205 207 regs.regs[29] = (unsigned long)sp; 206 208 regs.regs[31] = 0;