2011-07-08 17:40:12 +08:00
|
|
|
/*
|
2011-09-23 13:51:30 +08:00
|
|
|
* Defines machines for CSR SiRFprimaII
|
2011-07-08 17:40:12 +08:00
|
|
|
*
|
|
|
|
* Copyright (c) 2011 Cambridge Silicon Radio Limited, a CSR plc group company.
|
|
|
|
*
|
|
|
|
* Licensed under GPLv2 or later.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/kernel.h>
|
2012-12-20 19:37:32 +08:00
|
|
|
#include <linux/of_irq.h>
|
2011-11-17 22:18:14 +08:00
|
|
|
#include <asm/sizes.h>
|
2011-07-08 17:40:12 +08:00
|
|
|
#include <asm/mach-types.h>
|
|
|
|
#include <asm/mach/arch.h>
|
2012-12-20 19:37:32 +08:00
|
|
|
#include <asm/hardware/gic.h>
|
2011-07-08 17:40:12 +08:00
|
|
|
#include <linux/of.h>
|
|
|
|
#include <linux/of_platform.h>
|
|
|
|
#include "common.h"
|
|
|
|
|
|
|
|
static struct of_device_id sirfsoc_of_bus_ids[] __initdata = {
|
|
|
|
{ .compatible = "simple-bus", },
|
|
|
|
{},
|
|
|
|
};
|
|
|
|
|
|
|
|
void __init sirfsoc_mach_init(void)
|
|
|
|
{
|
|
|
|
of_platform_bus_probe(NULL, sirfsoc_of_bus_ids, NULL);
|
|
|
|
}
|
|
|
|
|
2012-04-26 20:51:36 +08:00
|
|
|
void __init sirfsoc_init_late(void)
|
|
|
|
{
|
|
|
|
sirfsoc_pm_init();
|
|
|
|
}
|
|
|
|
|
2012-12-20 19:37:32 +08:00
|
|
|
static __init void sirfsoc_map_io(void)
|
|
|
|
{
|
|
|
|
sirfsoc_map_lluart();
|
|
|
|
sirfsoc_map_scu();
|
|
|
|
}
|
|
|
|
|
2012-08-23 13:41:57 +08:00
|
|
|
#ifdef CONFIG_ARCH_PRIMA2
|
|
|
|
static const char *prima2_dt_match[] __initdata = {
|
|
|
|
"sirf,prima2",
|
2011-07-08 17:40:12 +08:00
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2012-08-23 13:41:57 +08:00
|
|
|
DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
|
2011-07-08 17:40:12 +08:00
|
|
|
/* Maintainer: Barry Song <baohua.song@csr.com> */
|
2012-12-20 19:37:32 +08:00
|
|
|
.map_io = sirfsoc_map_io,
|
2011-07-08 17:40:12 +08:00
|
|
|
.init_irq = sirfsoc_of_irq_init,
|
2012-12-20 17:33:49 +08:00
|
|
|
.init_time = sirfsoc_prima2_timer_init,
|
2012-12-20 19:11:18 +08:00
|
|
|
#ifdef CONFIG_MULTI_IRQ_HANDLER
|
|
|
|
.handle_irq = sirfsoc_handle_irq,
|
|
|
|
#endif
|
2011-09-03 09:05:10 +08:00
|
|
|
.dma_zone_size = SZ_256M,
|
2011-07-08 17:40:12 +08:00
|
|
|
.init_machine = sirfsoc_mach_init,
|
2012-04-26 20:51:36 +08:00
|
|
|
.init_late = sirfsoc_init_late,
|
2012-08-23 13:41:57 +08:00
|
|
|
.dt_compat = prima2_dt_match,
|
2011-11-05 18:23:27 +08:00
|
|
|
.restart = sirfsoc_restart,
|
2011-07-08 17:40:12 +08:00
|
|
|
MACHINE_END
|
2012-08-23 13:41:57 +08:00
|
|
|
#endif
|
2012-12-20 19:37:32 +08:00
|
|
|
|
|
|
|
#ifdef CONFIG_ARCH_MARCO
|
|
|
|
static const struct of_device_id marco_irq_match[] __initconst = {
|
|
|
|
{ .compatible = "arm,cortex-a9-gic", .data = gic_of_init, },
|
|
|
|
{ /* sentinel */ }
|
|
|
|
};
|
|
|
|
|
|
|
|
static void __init marco_init_irq(void)
|
|
|
|
{
|
|
|
|
of_irq_init(marco_irq_match);
|
|
|
|
}
|
|
|
|
|
|
|
|
static const char *marco_dt_match[] __initdata = {
|
|
|
|
"sirf,marco",
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
|
|
|
DT_MACHINE_START(MARCO_DT, "Generic MARCO (Flattened Device Tree)")
|
|
|
|
/* Maintainer: Barry Song <baohua.song@csr.com> */
|
|
|
|
.smp = smp_ops(sirfsoc_smp_ops),
|
|
|
|
.map_io = sirfsoc_map_io,
|
|
|
|
.init_irq = marco_init_irq,
|
|
|
|
.init_time = sirfsoc_marco_timer_init,
|
|
|
|
.handle_irq = gic_handle_irq,
|
|
|
|
.init_machine = sirfsoc_mach_init,
|
|
|
|
.init_late = sirfsoc_init_late,
|
|
|
|
.dt_compat = marco_dt_match,
|
|
|
|
.restart = sirfsoc_restart,
|
|
|
|
MACHINE_END
|
|
|
|
#endif
|