ee07675046
The DT of_device.h and of_platform.h date back to the separate of_platform_bus_type before it as merged into the regular platform bus. As part of that merge prepping Arm DT support 13 years ago, they "temporarily" include each other. They also include platform_device.h and of.h. As a result, there's a pretty much random mix of those include files used throughout the tree. In order to detangle these headers and replace the implicit includes with struct declarations, users need to explicitly include the correct includes. Signed-off-by: Rob Herring <robh@kernel.org> Signed-off-by: Marc Zyngier <maz@kernel.org> Link: https://lore.kernel.org/r/20230714174645.4058547-1-robh@kernel.org
65 lines
1.8 KiB
C
65 lines
1.8 KiB
C
/*
|
|
* Copyright (C) 2012 Thomas Petazzoni
|
|
*
|
|
* Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*/
|
|
|
|
#include <linux/acpi.h>
|
|
#include <linux/init.h>
|
|
#include <linux/of.h>
|
|
#include <linux/of_irq.h>
|
|
#include <linux/irqchip.h>
|
|
#include <linux/platform_device.h>
|
|
|
|
/*
|
|
* This special of_device_id is the sentinel at the end of the
|
|
* of_device_id[] array of all irqchips. It is automatically placed at
|
|
* the end of the array by the linker, thanks to being part of a
|
|
* special section.
|
|
*/
|
|
static const struct of_device_id
|
|
irqchip_of_match_end __used __section("__irqchip_of_table_end");
|
|
|
|
extern struct of_device_id __irqchip_of_table[];
|
|
|
|
void __init irqchip_init(void)
|
|
{
|
|
of_irq_init(__irqchip_of_table);
|
|
acpi_probe_device_table(irqchip);
|
|
}
|
|
|
|
int platform_irqchip_probe(struct platform_device *pdev)
|
|
{
|
|
struct device_node *np = pdev->dev.of_node;
|
|
struct device_node *par_np = of_irq_find_parent(np);
|
|
of_irq_init_cb_t irq_init_cb = of_device_get_match_data(&pdev->dev);
|
|
|
|
if (!irq_init_cb) {
|
|
of_node_put(par_np);
|
|
return -EINVAL;
|
|
}
|
|
|
|
if (par_np == np)
|
|
par_np = NULL;
|
|
|
|
/*
|
|
* If there's a parent interrupt controller and none of the parent irq
|
|
* domains have been registered, that means the parent interrupt
|
|
* controller has not been initialized yet. it's not time for this
|
|
* interrupt controller to initialize. So, defer probe of this
|
|
* interrupt controller. The actual initialization callback of this
|
|
* interrupt controller can check for specific domains as necessary.
|
|
*/
|
|
if (par_np && !irq_find_matching_host(par_np, DOMAIN_BUS_ANY)) {
|
|
of_node_put(par_np);
|
|
return -EPROBE_DEFER;
|
|
}
|
|
|
|
return irq_init_cb(np, par_np);
|
|
}
|
|
EXPORT_SYMBOL_GPL(platform_irqchip_probe);
|