]> git.baikalelectronics.ru Git - kernel.git/commit
irqchip: gic: Fix core ID calculation when topology is read from DT
authorTomasz Figa <t.figa@samsung.com>
Thu, 17 Jul 2014 15:23:44 +0000 (17:23 +0200)
committerJason Cooper <jason@lakedaemon.net>
Fri, 18 Jul 2014 13:13:41 +0000 (13:13 +0000)
commit75b894ae47bf12833ae7621510b5fca6efdf286f
tree74a9accacfe0ae96dec2a3e315ed1e70600738fb
parent7d322fb83f63da1c1a80bad6e588e80b4db3001a
irqchip: gic: Fix core ID calculation when topology is read from DT

Certain GIC implementation, namely those found on earlier, single
cluster, Exynos SoCs, have registers mapped without per-CPU banking,
which means that the driver needs to use different offset for each CPU.

Currently the driver calculates the offset by multiplying value returned
by cpu_logical_map() by CPU offset parsed from DT. This is correct when
CPU topology is not specified in DT and aforementioned function returns
core ID alone. However when DT contains CPU topology, the function
changes to return cluster ID as well, which is non-zero on mentioned
SoCs and so breaks the calculation in GIC driver.

This patch fixes this by masking out cluster ID in CPU offset
calculation so that only core ID is considered. Multi-cluster Exynos
SoCs already have banked GIC implementations, so this simple fix should
be enough.

Reported-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Reported-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Signed-off-by: Tomasz Figa <t.figa@samsung.com>
Fixes: d23a87ad6cf49 ("ARM: gic: allow GIC to support non-banked setups")
Cc: <stable@vger.kernel.org> # v3.3+
Link: https://lkml.kernel.org/r/1405610624-18722-1-git-send-email-t.figa@samsung.com
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
drivers/irqchip/irq-gic.c