From: Tony Luck Date: Thu, 28 Jun 2007 23:05:34 +0000 (-0700) Subject: [IA64] Don't set psr.ic and psr.i simultaneously X-Git-Tag: v2.6.23-rc1~1105^2~6 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=83ce6ef8408bbc7d9322ab50ba592f83012dea94;p=linux-2.6-omap-h63xx.git [IA64] Don't set psr.ic and psr.i simultaneously It's not a good idea to use "ssm psr.ic | psr.i" to simultaneously enable interrupts and interrupt state collection, the two bits can take effect asynchronously, so it is possible for an interrupt to be serviced while psr.ic is still zero. Signed-off-by: Tony Luck --- diff --git a/arch/ia64/kernel/mca_drv_asm.S b/arch/ia64/kernel/mca_drv_asm.S index f2d4900751b..3bccb06c8d2 100644 --- a/arch/ia64/kernel/mca_drv_asm.S +++ b/arch/ia64/kernel/mca_drv_asm.S @@ -40,7 +40,11 @@ GLOBAL_ENTRY(mca_handler_bhhook) mov b6=loc1 ;; mov loc1=rp - ssm psr.i | psr.ic + ssm psr.ic + ;; + srlz.i + ;; + ssm psr.i br.call.sptk.many rp=b6 // does not return ... ;; mov ar.pfs=loc0