]> git.baikalelectronics.ru Git - kernel.git/commit
irqchip/mips-gic: Map to VPs using HW VPNum
authorPaul Burton <paul.burton@imgtec.com>
Tue, 5 Jul 2016 13:25:59 +0000 (14:25 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Tue, 5 Jul 2016 14:54:21 +0000 (16:54 +0200)
commit08e9b3fd9c49b72294e32d9d90a4e2d0de26cda0
tree3293577da1d2e26e69c55e3cc424c3ba5c2508d9
parent67cdf5a8c0d1e87063033bea9387a1c64c63e552
irqchip/mips-gic: Map to VPs using HW VPNum

When mapping an interrupt to a VP(E) we must use the identifier for the
VP that the hardware expects, and this does not always match up with the
Linux CPU number. Commit a9960b1c5260 ("irqchip: mips-gic: Use HW IDs
for VPE_OTHER_ADDR") corrected this for the cases that existed at the
time it was written, but commit b68705177d8a ("irqchip/mips-gic: Add a
IPI hierarchy domain") added another case before the former patch was
merged. This leads to incorrectly using Linux CPU numbers when mapping
interrupts to VPs, which breaks on certain systems such as those with
multi-core I6400 CPUs. Fix by adding the appropriate call to
mips_cm_vp_id() to retrieve the expected VP identifier.

Fixes: a9960b1c5260 ("irqchip: mips-gic: Use HW IDs for VPE_OTHER_ADDR")
Fixes: b68705177d8a ("irqchip/mips-gic: Add a IPI hierarchy domain")
Signed-off-by: Paul Burton <paul.burton@imgtec.com>
Cc: linux-mips@linux-mips.org
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Qais Yousef <qsyousef@gmail.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Cc: stable@vger.kernel.org
Link: http://lkml.kernel.org/r/20160705132600.27730-1-paul.burton@imgtec.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
drivers/irqchip/irq-mips-gic.c