Commit 25c51dad authored by Paul Burton's avatar Paul Burton Committed by Marc Zyngier

irqchip: mips-gic: Use num_possible_cpus() to reserve IPIs

Reserving a number of IPIs based upon the number of VPs reported by the
GIC makes little sense for a few reasons:

 - The kernel may have been configured with NR_CPUS less than the number
   of VPs in the cluster, in which case using gic_vpes causes us to
   reserve more interrupts for IPIs than we will possibly use.

 - If a kernel is configured without support for multi-threading & runs
   on a system with multi-threading & multiple VPs per core then we'll
   similarly reserve more interrupts for IPIs than we will possibly use.

 - In systems with multiple clusters the GIC can only provide us with
   the number of VPs in its cluster, not across all clusters. In this
   case we'll reserve fewer interrupts for IPIs than we need.

Fix these issues by using num_possible_cpus() instead, which in all
cases is actually indicative of how many IPIs we may need.
Signed-off-by: default avatarPaul Burton <paul.burton@mips.com>
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: linux-mips@linux-mips.org
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent 890f6b55
...@@ -671,7 +671,7 @@ static int gic_cpu_startup(unsigned int cpu) ...@@ -671,7 +671,7 @@ static int gic_cpu_startup(unsigned int cpu)
static int __init gic_of_init(struct device_node *node, static int __init gic_of_init(struct device_node *node,
struct device_node *parent) struct device_node *parent)
{ {
unsigned int cpu_vec, i, gicconfig, v[2]; unsigned int cpu_vec, i, gicconfig, v[2], num_ipis;
unsigned long reserved; unsigned long reserved;
phys_addr_t gic_base; phys_addr_t gic_base;
struct resource res; struct resource res;
...@@ -781,10 +781,12 @@ static int __init gic_of_init(struct device_node *node, ...@@ -781,10 +781,12 @@ static int __init gic_of_init(struct device_node *node,
!of_property_read_u32_array(node, "mti,reserved-ipi-vectors", v, 2)) { !of_property_read_u32_array(node, "mti,reserved-ipi-vectors", v, 2)) {
bitmap_set(ipi_resrv, v[0], v[1]); bitmap_set(ipi_resrv, v[0], v[1]);
} else { } else {
/* Make the last 2 * gic_vpes available for IPIs */ /*
bitmap_set(ipi_resrv, * Reserve 2 interrupts per possible CPU/VP for use as IPIs,
gic_shared_intrs - 2 * gic_vpes, * meeting the requirements of arch/mips SMP.
2 * gic_vpes); */
num_ipis = 2 * num_possible_cpus();
bitmap_set(ipi_resrv, gic_shared_intrs - num_ipis, num_ipis);
} }
bitmap_copy(ipi_available, ipi_resrv, GIC_MAX_INTRS); bitmap_copy(ipi_available, ipi_resrv, GIC_MAX_INTRS);
......
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