diff options
Diffstat (limited to 'arch/powerpc/kernel/entry_64.S')
| -rw-r--r-- | arch/powerpc/kernel/entry_64.S | 13 | 
1 files changed, 13 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/entry_64.S b/arch/powerpc/kernel/entry_64.S index b310a057362..3d990d3bd8b 100644 --- a/arch/powerpc/kernel/entry_64.S +++ b/arch/powerpc/kernel/entry_64.S @@ -664,6 +664,19 @@ resume_kernel:  	ld	r4,TI_FLAGS(r9)  	andi.	r0,r4,_TIF_NEED_RESCHED  	bne	1b + +	/* +	 * arch_local_irq_restore() from preempt_schedule_irq above may +	 * enable hard interrupt but we really should disable interrupts +	 * when we return from the interrupt, and so that we don't get +	 * interrupted after loading SRR0/1. +	 */ +#ifdef CONFIG_PPC_BOOK3E +	wrteei	0 +#else +	ld	r10,PACAKMSR(r13) /* Get kernel MSR without EE */ +	mtmsrd	r10,1		  /* Update machine state */ +#endif /* CONFIG_PPC_BOOK3E */  #endif /* CONFIG_PREEMPT */  	.globl	fast_exc_return_irq  |