blob: 00a65649a7e2bd7ba5954ac0b7bfdeaaf4afc0af [file] [log] [blame]
Binghua Duan02c981c2011-07-08 17:40:12 +08001/*
Barry Song013dd122011-09-22 22:51:30 -07002 * Defines machines for CSR SiRFprimaII
Binghua Duan02c981c2011-07-08 17:40:12 +08003 *
4 * Copyright (c) 2011 Cambridge Silicon Radio Limited, a CSR plc group company.
5 *
6 * Licensed under GPLv2 or later.
7 */
8
9#include <linux/init.h>
10#include <linux/kernel.h>
Barry Song4898de32012-12-20 19:37:32 +080011#include <linux/of_irq.h>
Barry Song1bdfd27a2011-11-17 22:18:14 +080012#include <asm/sizes.h>
Binghua Duan02c981c2011-07-08 17:40:12 +080013#include <asm/mach-types.h>
14#include <asm/mach/arch.h>
Barry Song4898de32012-12-20 19:37:32 +080015#include <asm/hardware/gic.h>
Binghua Duan02c981c2011-07-08 17:40:12 +080016#include <linux/of.h>
17#include <linux/of_platform.h>
18#include "common.h"
19
20static struct of_device_id sirfsoc_of_bus_ids[] __initdata = {
21 { .compatible = "simple-bus", },
22 {},
23};
24
25void __init sirfsoc_mach_init(void)
26{
27 of_platform_bus_probe(NULL, sirfsoc_of_bus_ids, NULL);
28}
29
Shawn Guoa4b46742012-04-26 20:51:36 +080030void __init sirfsoc_init_late(void)
31{
32 sirfsoc_pm_init();
33}
34
Barry Song4898de32012-12-20 19:37:32 +080035static __init void sirfsoc_map_io(void)
36{
37 sirfsoc_map_lluart();
38 sirfsoc_map_scu();
39}
40
Barry Songd0ec63f2012-08-23 13:41:57 +080041#ifdef CONFIG_ARCH_PRIMA2
42static const char *prima2_dt_match[] __initdata = {
43 "sirf,prima2",
Binghua Duan02c981c2011-07-08 17:40:12 +080044 NULL
45};
46
Barry Songd0ec63f2012-08-23 13:41:57 +080047DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
Binghua Duan02c981c2011-07-08 17:40:12 +080048 /* Maintainer: Barry Song <baohua.song@csr.com> */
Barry Song4898de32012-12-20 19:37:32 +080049 .map_io = sirfsoc_map_io,
Binghua Duan02c981c2011-07-08 17:40:12 +080050 .init_irq = sirfsoc_of_irq_init,
Barry Song0d5983a2012-12-20 17:33:49 +080051 .init_time = sirfsoc_prima2_timer_init,
Barry Songf2a94192012-12-20 19:11:18 +080052#ifdef CONFIG_MULTI_IRQ_HANDLER
53 .handle_irq = sirfsoc_handle_irq,
54#endif
Nicolas Pitre98b01242011-09-02 21:05:10 -040055 .dma_zone_size = SZ_256M,
Binghua Duan02c981c2011-07-08 17:40:12 +080056 .init_machine = sirfsoc_mach_init,
Shawn Guoa4b46742012-04-26 20:51:36 +080057 .init_late = sirfsoc_init_late,
Barry Songd0ec63f2012-08-23 13:41:57 +080058 .dt_compat = prima2_dt_match,
Russell King125c4032011-11-05 10:23:27 +000059 .restart = sirfsoc_restart,
Binghua Duan02c981c2011-07-08 17:40:12 +080060MACHINE_END
Barry Songd0ec63f2012-08-23 13:41:57 +080061#endif
Barry Song4898de32012-12-20 19:37:32 +080062
63#ifdef CONFIG_ARCH_MARCO
64static const struct of_device_id marco_irq_match[] __initconst = {
65 { .compatible = "arm,cortex-a9-gic", .data = gic_of_init, },
66 { /* sentinel */ }
67};
68
69static void __init marco_init_irq(void)
70{
71 of_irq_init(marco_irq_match);
72}
73
74static const char *marco_dt_match[] __initdata = {
75 "sirf,marco",
76 NULL
77};
78
79DT_MACHINE_START(MARCO_DT, "Generic MARCO (Flattened Device Tree)")
80 /* Maintainer: Barry Song <baohua.song@csr.com> */
81 .smp = smp_ops(sirfsoc_smp_ops),
82 .map_io = sirfsoc_map_io,
83 .init_irq = marco_init_irq,
84 .init_time = sirfsoc_marco_timer_init,
85 .handle_irq = gic_handle_irq,
86 .init_machine = sirfsoc_mach_init,
87 .init_late = sirfsoc_init_late,
88 .dt_compat = marco_dt_match,
89 .restart = sirfsoc_restart,
90MACHINE_END
91#endif