|
@@ -664,6 +664,19 @@ resume_kernel:
|
|
ld r4,TI_FLAGS(r9)
|
|
ld r4,TI_FLAGS(r9)
|
|
andi. r0,r4,_TIF_NEED_RESCHED
|
|
andi. r0,r4,_TIF_NEED_RESCHED
|
|
bne 1b
|
|
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 */
|
|
#endif /* CONFIG_PREEMPT */
|
|
|
|
|
|
.globl fast_exc_return_irq
|
|
.globl fast_exc_return_irq
|