diff options
Diffstat (limited to 'arch/powerpc/platforms/83xx/misc.c')
| -rw-r--r-- | arch/powerpc/platforms/83xx/misc.c | 77 | 
1 files changed, 77 insertions, 0 deletions
diff --git a/arch/powerpc/platforms/83xx/misc.c b/arch/powerpc/platforms/83xx/misc.c index f01806c940e..125336f750c 100644 --- a/arch/powerpc/platforms/83xx/misc.c +++ b/arch/powerpc/platforms/83xx/misc.c @@ -11,10 +11,15 @@  #include <linux/stddef.h>  #include <linux/kernel.h> +#include <linux/of_platform.h> +#include <linux/pci.h>  #include <asm/io.h>  #include <asm/hw_irq.h> +#include <asm/ipic.h> +#include <asm/qe_ic.h>  #include <sysdev/fsl_soc.h> +#include <sysdev/fsl_pci.h>  #include "mpc83xx.h" @@ -65,3 +70,75 @@ long __init mpc83xx_time_init(void)  	return 0;  } + +void __init mpc83xx_ipic_init_IRQ(void) +{ +	struct device_node *np; + +	/* looking for fsl,pq2pro-pic which is asl compatible with fsl,ipic */ +	np = of_find_compatible_node(NULL, NULL, "fsl,ipic"); +	if (!np) +		np = of_find_node_by_type(NULL, "ipic"); +	if (!np) +		return; + +	ipic_init(np, 0); + +	of_node_put(np); + +	/* Initialize the default interrupt mapping priorities, +	 * in case the boot rom changed something on us. +	 */ +	ipic_set_default_priority(); +} + +#ifdef CONFIG_QUICC_ENGINE +void __init mpc83xx_qe_init_IRQ(void) +{ +	struct device_node *np; + +	np = of_find_compatible_node(NULL, NULL, "fsl,qe-ic"); +	if (!np) { +		np = of_find_node_by_type(NULL, "qeic"); +		if (!np) +			return; +	} +	qe_ic_init(np, 0, qe_ic_cascade_low_ipic, qe_ic_cascade_high_ipic); +	of_node_put(np); +} + +void __init mpc83xx_ipic_and_qe_init_IRQ(void) +{ +	mpc83xx_ipic_init_IRQ(); +	mpc83xx_qe_init_IRQ(); +} +#endif /* CONFIG_QUICC_ENGINE */ + +static struct of_device_id __initdata of_bus_ids[] = { +	{ .type = "soc", }, +	{ .compatible = "soc", }, +	{ .compatible = "simple-bus" }, +	{ .compatible = "gianfar" }, +	{ .compatible = "gpio-leds", }, +	{ .type = "qe", }, +	{ .compatible = "fsl,qe", }, +	{}, +}; + +int __init mpc83xx_declare_of_platform_devices(void) +{ +	of_platform_bus_probe(NULL, of_bus_ids, NULL); +	return 0; +} + +#ifdef CONFIG_PCI +void __init mpc83xx_setup_pci(void) +{ +	struct device_node *np; + +	for_each_compatible_node(np, "pci", "fsl,mpc8349-pci") +		mpc83xx_add_bridge(np); +	for_each_compatible_node(np, "pci", "fsl,mpc8314-pcie") +		mpc83xx_add_bridge(np); +} +#endif  |