alpha: irq: run all handlers with interrupts disabled

Linux has expected that interrupt handlers are executed with local
interrupts disabled for a while now, so ensure that this is the case on
Alpha even for non-device interrupts such as IPIs.

Without this patch, secondary boot results in the following backtrace:

warning: at kernel/softirq.c:139 __local_bh_enable+0xb8/0xd0()
trace:
__local_bh_enable+0xb8/0xd0
irq_enter+0x74/0xa0
scheduler_ipi+0x50/0x100
handle_ipi+0x84/0x260
do_entint+0x1ac/0x2e0
irq_exit+0x60/0xa0
handle_irq+0x98/0x100
do_entint+0x2c8/0x2e0
ret_from_sys_call+0x0/0x10
load_balance+0x3e4/0x870
cpu_idle+0x24/0x80
rcu_eqs_enter_common.isra.38+0x0/0x120
cpu_idle+0x40/0x80
rest_init+0xc0/0xe0
_stext+0x1c/0x20

A similar dump occurs if you try to reboot using magic-sysrq.

Cc: Richard Henderson <rth@twiddle.net>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Matt Turner <mattst88@gmail.com>
Reviewed-by: Matt Turner <mattst88@gmail.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Michael Cree <mcree@orcon.net.nz>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>

authored by Will Deacon and committed by Linus Torvalds e20800fd cd8d2331

Changed files
+8 -8
arch
alpha
-7
arch/alpha/kernel/irq.c
··· 117 return; 118 } 119 120 - /* 121 - * From here we must proceed with IPL_MAX. Note that we do not 122 - * explicitly enable interrupts afterwards - some MILO PALcode 123 - * (namely LX164 one) seems to have severe problems with RTI 124 - * at IPL 0. 125 - */ 126 - local_irq_disable(); 127 irq_enter(); 128 generic_handle_irq_desc(irq, desc); 129 irq_exit();
··· 117 return; 118 } 119 120 irq_enter(); 121 generic_handle_irq_desc(irq, desc); 122 irq_exit();
+8 -1
arch/alpha/kernel/irq_alpha.c
··· 45 unsigned long la_ptr, struct pt_regs *regs) 46 { 47 struct pt_regs *old_regs; 48 switch (type) { 49 case 0: 50 #ifdef CONFIG_SMP ··· 70 { 71 long cpu; 72 73 - local_irq_disable(); 74 smp_percpu_timer_interrupt(regs); 75 cpu = smp_processor_id(); 76 if (cpu != boot_cpuid) {
··· 45 unsigned long la_ptr, struct pt_regs *regs) 46 { 47 struct pt_regs *old_regs; 48 + 49 + /* 50 + * Disable interrupts during IRQ handling. 51 + * Note that there is no matching local_irq_enable() due to 52 + * severe problems with RTI at IPL0 and some MILO PALcode 53 + * (namely LX164). 54 + */ 55 + local_irq_disable(); 56 switch (type) { 57 case 0: 58 #ifdef CONFIG_SMP ··· 62 { 63 long cpu; 64 65 smp_percpu_timer_interrupt(regs); 66 cpu = smp_processor_id(); 67 if (cpu != boot_cpuid) {