blob: 72efb4ff2803c37e0ffc348d549eeababcdc1e55 [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 Songef4acb72013-02-04 13:41:36 +080011#include <linux/irqchip.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>
15#include <linux/of.h>
16#include <linux/of_platform.h>
17#include "common.h"
18
19static struct of_device_id sirfsoc_of_bus_ids[] __initdata = {
20 { .compatible = "simple-bus", },
21 {},
22};
23
24void __init sirfsoc_mach_init(void)
25{
26 of_platform_bus_probe(NULL, sirfsoc_of_bus_ids, NULL);
27}
28
Shawn Guoa4b46742012-04-26 20:51:36 +080029void __init sirfsoc_init_late(void)
30{
31 sirfsoc_pm_init();
32}
33
Barry Song4898de32012-12-20 19:37:32 +080034static __init void sirfsoc_map_io(void)
35{
36 sirfsoc_map_lluart();
37 sirfsoc_map_scu();
38}
39
Barry Songd4fe49e2013-03-18 15:04:38 +080040#ifdef CONFIG_ARCH_ATLAS6
41static const char *atlas6_dt_match[] __initdata = {
42 "sirf,atlas6",
43 NULL
44};
45
46DT_MACHINE_START(ATLAS6_DT, "Generic ATLAS6 (Flattened Device Tree)")
47 /* Maintainer: Barry Song <baohua.song@csr.com> */
48 .map_io = sirfsoc_map_io,
49 .init_irq = sirfsoc_of_irq_init,
50 .init_time = sirfsoc_prima2_timer_init,
51#ifdef CONFIG_MULTI_IRQ_HANDLER
52 .handle_irq = sirfsoc_handle_irq,
53#endif
54 .init_machine = sirfsoc_mach_init,
55 .init_late = sirfsoc_init_late,
56 .dt_compat = atlas6_dt_match,
57 .restart = sirfsoc_restart,
58MACHINE_END
59#endif
60
Barry Songd0ec63f2012-08-23 13:41:57 +080061#ifdef CONFIG_ARCH_PRIMA2
62static const char *prima2_dt_match[] __initdata = {
63 "sirf,prima2",
Binghua Duan02c981c2011-07-08 17:40:12 +080064 NULL
65};
66
Barry Songd0ec63f2012-08-23 13:41:57 +080067DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
Binghua Duan02c981c2011-07-08 17:40:12 +080068 /* Maintainer: Barry Song <baohua.song@csr.com> */
Barry Song4898de32012-12-20 19:37:32 +080069 .map_io = sirfsoc_map_io,
Binghua Duan02c981c2011-07-08 17:40:12 +080070 .init_irq = sirfsoc_of_irq_init,
Barry Song0d5983a2012-12-20 17:33:49 +080071 .init_time = sirfsoc_prima2_timer_init,
Barry Songf2a94192012-12-20 19:11:18 +080072#ifdef CONFIG_MULTI_IRQ_HANDLER
73 .handle_irq = sirfsoc_handle_irq,
74#endif
Nicolas Pitre98b01242011-09-02 21:05:10 -040075 .dma_zone_size = SZ_256M,
Binghua Duan02c981c2011-07-08 17:40:12 +080076 .init_machine = sirfsoc_mach_init,
Shawn Guoa4b46742012-04-26 20:51:36 +080077 .init_late = sirfsoc_init_late,
Barry Songd0ec63f2012-08-23 13:41:57 +080078 .dt_compat = prima2_dt_match,
Russell King125c4032011-11-05 10:23:27 +000079 .restart = sirfsoc_restart,
Binghua Duan02c981c2011-07-08 17:40:12 +080080MACHINE_END
Barry Songd0ec63f2012-08-23 13:41:57 +080081#endif
Barry Song4898de32012-12-20 19:37:32 +080082
83#ifdef CONFIG_ARCH_MARCO
Barry Song4898de32012-12-20 19:37:32 +080084static const char *marco_dt_match[] __initdata = {
85 "sirf,marco",
86 NULL
87};
88
89DT_MACHINE_START(MARCO_DT, "Generic MARCO (Flattened Device Tree)")
90 /* Maintainer: Barry Song <baohua.song@csr.com> */
91 .smp = smp_ops(sirfsoc_smp_ops),
92 .map_io = sirfsoc_map_io,
Barry Songef4acb72013-02-04 13:41:36 +080093 .init_irq = irqchip_init,
Barry Song4898de32012-12-20 19:37:32 +080094 .init_time = sirfsoc_marco_timer_init,
Barry Song4898de32012-12-20 19:37:32 +080095 .init_machine = sirfsoc_mach_init,
96 .init_late = sirfsoc_init_late,
97 .dt_compat = marco_dt_match,
98 .restart = sirfsoc_restart,
99MACHINE_END
100#endif