irqchip: Make irqchip_init() usable on pure ACPI systems
authorHuacai Chen <chenhuacai@loongson.cn>
Tue, 27 Sep 2022 12:45:57 +0000 (20:45 +0800)
committerMarc Zyngier <maz@kernel.org>
Wed, 28 Sep 2022 13:11:28 +0000 (14:11 +0100)
Pure ACPI systems (e.g., LoongArch) do not need OF_IRQ, but still
require irqchip_init() to perform the ACPI irqchip probing,
even when OF_IRQ isn't selected.

Relax the dependency to enable the generic irqchip support when
ACPI_GENERIC_GSI is configured.

Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
Tested-by: Tiezhu Yang <yangtiezhu@loongson.cn>
[maz: revamped commit message]
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20220927124557.3246737-1-chenhuacai@loongson.cn
drivers/irqchip/Kconfig
include/linux/of_irq.h

index 66b9fa408bf2422fd083acddbaf705e6ddce6b9a..93ad04d58f17634f1f04d86f234c19b257f07d92 100644 (file)
@@ -3,7 +3,7 @@ menu "IRQ chip support"
 
 config IRQCHIP
        def_bool y
-       depends on OF_IRQ
+       depends on (OF_IRQ || ACPI_GENERIC_GSI)
 
 config ARM_GIC
        bool
index 83fccd0c9bba219192ea30604071287a399898e1..d6d3eae2f1452ff9a85c2fd29b30efb1b91177d4 100644 (file)
@@ -37,9 +37,8 @@ extern unsigned int irq_create_of_mapping(struct of_phandle_args *irq_data);
 extern int of_irq_to_resource(struct device_node *dev, int index,
                              struct resource *r);
 
-extern void of_irq_init(const struct of_device_id *matches);
-
 #ifdef CONFIG_OF_IRQ
+extern void of_irq_init(const struct of_device_id *matches);
 extern int of_irq_parse_one(struct device_node *device, int index,
                          struct of_phandle_args *out_irq);
 extern int of_irq_count(struct device_node *dev);
@@ -57,6 +56,9 @@ extern struct irq_domain *of_msi_map_get_device_domain(struct device *dev,
 extern void of_msi_configure(struct device *dev, struct device_node *np);
 u32 of_msi_map_id(struct device *dev, struct device_node *msi_np, u32 id_in);
 #else
+static inline void of_irq_init(const struct of_device_id *matches)
+{
+}
 static inline int of_irq_parse_one(struct device_node *device, int index,
                                   struct of_phandle_args *out_irq)
 {