diff options
Diffstat (limited to 'arch/powerpc/kernel/process.c')
| -rw-r--r-- | arch/powerpc/kernel/process.c | 14 | 
1 files changed, 12 insertions, 2 deletions
diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c index c22cc234672f..4b29ac5ddac6 100644 --- a/arch/powerpc/kernel/process.c +++ b/arch/powerpc/kernel/process.c @@ -1405,8 +1405,7 @@ static void show_instructions(struct pt_regs *regs)  	for (i = 0; i < NR_INSN_TO_PRINT; i++) {  		int instr; -		if (!__kernel_text_address(pc) || -		    get_kernel_nofault(instr, (const void *)pc)) { +		if (get_kernel_nofault(instr, (const void *)pc)) {  			pr_cont("XXXXXXXX ");  		} else {  			if (nip == pc) @@ -2118,6 +2117,9 @@ static inline int valid_irq_stack(unsigned long sp, struct task_struct *p,  	unsigned long stack_page;  	unsigned long cpu = task_cpu(p); +	if (!hardirq_ctx[cpu] || !softirq_ctx[cpu]) +		return 0; +  	stack_page = (unsigned long)hardirq_ctx[cpu];  	if (sp >= stack_page && sp <= stack_page + THREAD_SIZE - nbytes)  		return 1; @@ -2139,6 +2141,14 @@ static inline int valid_emergency_stack(unsigned long sp, struct task_struct *p,  	if (!paca_ptrs)  		return 0; +	if (!paca_ptrs[cpu]->emergency_sp) +		return 0; + +# ifdef CONFIG_PPC_BOOK3S_64 +	if (!paca_ptrs[cpu]->nmi_emergency_sp || !paca_ptrs[cpu]->mc_emergency_sp) +		return 0; +#endif +  	stack_page = (unsigned long)paca_ptrs[cpu]->emergency_sp - THREAD_SIZE;  	if (sp >= stack_page && sp <= stack_page + THREAD_SIZE - nbytes)  		return 1;  |