summaryrefslogtreecommitdiffstats
path: root/drivers/tc
diff options
context:
space:
mode:
authorJon Hunter <jonathanh@nvidia.com>2015-07-31 10:44:11 +0200
committerThomas Gleixner <tglx@linutronix.de>2015-08-04 14:14:06 +0200
commit567e5a014848c6aeb1d6fc862b1b5d0183760259 (patch)
tree6214083d5af0debf4827573b15e3987612aea373 /drivers/tc
parentPCI/MSI: pci-xgene-msi: Consolidate chained IRQ handler install/remove (diff)
downloadlinux-567e5a014848c6aeb1d6fc862b1b5d0183760259.tar.xz
linux-567e5a014848c6aeb1d6fc862b1b5d0183760259.zip
irqchip/gic: Only allow the primary GIC to set the CPU map
The gic_init_bases() function initialises an array that stores the mapping between the GIC and CPUs. This array is a global array that is unconditionally initialised on every call to gic_init_bases(). Although, it is not common for there to be more than one GIC instance, there are some devices that do support nested GIC controllers and gic_init_bases() can be called more than once. A 2nd call to gic_init_bases() will clear the previous CPU mapping and will only setup the mapping again for the CPU calling gic_init_bases(). Fix this by only allowing the CPU map to be configured for the primary GIC. For secondary GICs the CPU map is not relevant because these GICs do not directly route the interrupts to the main CPU(s) but to other GICs or devices. Signed-off-by: Jon Hunter <jonathanh@nvidia.com> Reviewed-by: Marc Zyngier <marc.zyngier@arm.com> Cc: <linux-arm-kernel@lists.infradead.org> Cc: Russell King <linux@arm.linux.org.uk> Cc: Nicolas Pitre <nicolas.pitre@linaro.org> Cc: Jason Cooper <jason@lakedaemon.net> Link: http://lkml.kernel.org/r/1438332252-25248-1-git-send-email-jonathanh@nvidia.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/tc')
0 files changed, 0 insertions, 0 deletions