summaryrefslogtreecommitdiffstats
path: root/arch/tile/kernel
diff options
context:
space:
mode:
authorChris Metcalf2013-08-09 21:41:09 +0200
committerChris Metcalf2013-08-30 17:56:16 +0200
commit8d8cf0674023da578e0539dc7cf4d824b2cf1f9e (patch)
tree2dd51ebbceaa602fcc9c90d0c45de929d5666804 /arch/tile/kernel
parenttile: use proper .align directives on __ex_table sections (diff)
downloadkernel-qcow2-linux-8d8cf0674023da578e0539dc7cf4d824b2cf1f9e.tar.gz
kernel-qcow2-linux-8d8cf0674023da578e0539dc7cf4d824b2cf1f9e.tar.xz
kernel-qcow2-linux-8d8cf0674023da578e0539dc7cf4d824b2cf1f9e.zip
tile: fix panic with large IRQ number
The "available_irqs" value needs to actually reflect the IRQs available, not just start as an all-ones mask, since we only have 32 IRQs available even on a 64-bit platform. Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
Diffstat (limited to 'arch/tile/kernel')
-rw-r--r--arch/tile/kernel/irq.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/tile/kernel/irq.c b/arch/tile/kernel/irq.c
index c90de6c3cb7f..0e6c521b8a89 100644
--- a/arch/tile/kernel/irq.c
+++ b/arch/tile/kernel/irq.c
@@ -55,7 +55,8 @@ static DEFINE_PER_CPU(int, irq_depth);
/* State for allocating IRQs on Gx. */
#if CHIP_HAS_IPI()
-static unsigned long available_irqs = ~(1UL << IRQ_RESCHEDULE);
+static unsigned long available_irqs = ((1UL << NR_IRQS) - 1) &
+ (~(1UL << IRQ_RESCHEDULE));
static DEFINE_SPINLOCK(available_irqs_lock);
#endif