diff options
author | Marc Zyngier <marc.zyngier@arm.com> | 2016-01-26 15:24:15 +0100 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2016-01-26 16:34:06 +0100 |
commit | 18aa60ce2751c95d3412ed06a58b8b6cfb6f88f2 (patch) | |
tree | ef3edb1c9ad9e788b19361bde9be10dea539dab9 /drivers/irqchip/irq-keystone.c | |
parent | base: Export platform_msi_domain_[alloc,free]_irqs (diff) | |
download | linux-18aa60ce2751c95d3412ed06a58b8b6cfb6f88f2.tar.xz linux-18aa60ce2751c95d3412ed06a58b8b6cfb6f88f2.zip |
irqchip/gic-v3-its: Recompute the number of pages on page size change
When the programming of a GITS_BASERn register fails because of
an unsupported ITS page size, we retry it with a smaller page size.
Unfortunately, we don't recompute the number of allocated ITS pages,
indicating the wrong value computed in the original allocation.
A convenient fix is to free the pages we allocated, update the
page size, and restart the allocation. This will ensure that
we always allocate the right amount in the case of a device
table, specially if we have to reduce the allocation order
to stay within the boundaries of the ITS maximum allocation.
Reported-and-tested-by: Ma Jun <majun258@huawei.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Cc: linux-arm-kernel@lists.infradead.org
Cc: Jason Cooper <jason@lakedaemon.net>
Link: http://lkml.kernel.org/r/1453818255-1289-1-git-send-email-marc.zyngier@arm.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/irqchip/irq-keystone.c')
0 files changed, 0 insertions, 0 deletions