diff options
author | Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> | 2015-03-24 13:58:51 -0400 |
---|---|---|
committer | Will Deacon <will.deacon@arm.com> | 2015-03-26 11:13:09 -0400 |
commit | d8f4f161e31f3ee9768467344e6cc31a0b9d9249 (patch) | |
tree | 428ed2902d784abc052f8160d1f6b3a21849b248 /drivers/irqchip | |
parent | 33757ded074918eb49243968a82e7c9ec2d71720 (diff) |
ACPI: move arm64 GSI IRQ model to generic GSI IRQ layer
The code deployed to implement GSI linux IRQ numbers mapping on arm64 turns
out to be generic enough so that it can be moved to ACPI core code along
with its respective config option ACPI_GENERIC_GSI selectable on
architectures that can reuse the same code.
Current ACPI IRQ mapping code is not integrated in the kernel IRQ domain
infrastructure, in particular there is no way to look-up the
IRQ domain associated with a particular interrupt controller, so this
first version of GSI generic code carries out the GSI<->IRQ mapping relying
on the IRQ default domain which is supposed to be always set on a
specific architecture in case the domain structure passed to
irq_create/find_mapping() functions is missing.
This patch moves the arm64 acpi functions that implement the gsi mappings:
acpi_gsi_to_irq()
acpi_register_gsi()
acpi_unregister_gsi()
to ACPI core code. Since the generic GSI<->domain mapping is based on IRQ
domains, it can be extended as soon as a way to map an interrupt
controller to an IRQ domain is implemented for ACPI in the IRQ domain
layer.
x86 and ia64 code for GSI mappings cannot rely on the generic GSI
layer at present for legacy reasons, so they do not select the
ACPI_GENERIC_GSI config options and keep relying on their arch
specific GSI mapping layer.
Cc: Jiang Liu <jiang.liu@linux.intel.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Rafael J. Wysocki <rjw@rjwysocki.net>
Acked-by: Hanjun Guo <hanjun.guo@linaro.org>
Acked-by: Will Deacon <will.deacon@arm.com>
Acked-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'drivers/irqchip')
-rw-r--r-- | drivers/irqchip/irq-gic.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/irqchip/irq-gic.c b/drivers/irqchip/irq-gic.c index d15a36a93c52..f1efb53faebc 100644 --- a/drivers/irqchip/irq-gic.c +++ b/drivers/irqchip/irq-gic.c | |||
@@ -1189,6 +1189,8 @@ gic_v2_acpi_init(struct acpi_table_header *table) | |||
1189 | */ | 1189 | */ |
1190 | gic_init_bases(0, -1, dist_base, cpu_base, 0, NULL); | 1190 | gic_init_bases(0, -1, dist_base, cpu_base, 0, NULL); |
1191 | irq_set_default_host(gic_data[0].domain); | 1191 | irq_set_default_host(gic_data[0].domain); |
1192 | |||
1193 | acpi_irq_model = ACPI_IRQ_MODEL_GIC; | ||
1192 | return 0; | 1194 | return 0; |
1193 | } | 1195 | } |
1194 | #endif | 1196 | #endif |