Commit e6488982 authored by Paul Burton's avatar Paul Burton Committed by Ralf Baechle

MIPS: Stengthen IPI IRQ domain sanity check

Commit fbde2d7d ("MIPS: Add generic SMP IPI support") introduced a
sanity check that an IPI IRQ domain can be found during boot, in order
to ensure that IPIs are able to be set up in systems using such domains.
However it was added at a point where systems may have used an IPI IRQ
domain in some situations but not others, and we could not know which
were the case until runtime, so commit 578bffc8 ("MIPS: Don't BUG_ON
when no IPI domain is found") made that check simply skip IPI init if no
domain were found in order to fix the boot for systems such as QEMU
Malta.

We now use IPI IRQ domains for the MIPS CPU interrupt controller, which
means systems which make use of IPI IRQ domains will always do so when
running on multiple CPUs. As a result we now strengthen the sanity check
to ensure that an IPI IRQ domain is found when multiple CPUs are present
in the system.
Signed-off-by: default avatarPaul Burton <paul.burton@imgtec.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/15838/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 1eed4004
...@@ -261,16 +261,20 @@ int mips_smp_ipi_allocate(const struct cpumask *mask) ...@@ -261,16 +261,20 @@ int mips_smp_ipi_allocate(const struct cpumask *mask)
ipidomain = irq_find_matching_host(NULL, DOMAIN_BUS_IPI); ipidomain = irq_find_matching_host(NULL, DOMAIN_BUS_IPI);
/* /*
* There are systems which only use IPI domains some of the time, * There are systems which use IPI IRQ domains, but only have one
* depending upon configuration we don't know until runtime. An * registered when some runtime condition is met. For example a Malta
* example is Malta where we may compile in support for GIC & the * kernel may include support for GIC & CPU interrupt controller IPI
* MT ASE, but run on a system which has multiple VPEs in a single * IRQ domains, but if run on a system with no GIC & no MT ASE then
* core and doesn't include a GIC. Until all IPI implementations * neither will be supported or registered.
* have been converted to use IPI domains the best we can do here *
* is to return & hope some other code sets up the IPIs. * We only have a problem if we're actually using multiple CPUs so fail
* loudly if that is the case. Otherwise simply return, skipping IPI
* setup, if we're running with only a single CPU.
*/ */
if (!ipidomain) if (!ipidomain) {
BUG_ON(num_present_cpus() > 1);
return 0; return 0;
}
virq = irq_reserve_ipi(ipidomain, mask); virq = irq_reserve_ipi(ipidomain, mask);
BUG_ON(!virq); BUG_ON(!virq);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment