blob: e95ebef603a71489a2fc7dced7eaffd2e2efbf12 [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
Arnd Bergmann275786b2013-03-19 15:27:22 +01009#include <linux/clocksource.h>
Binghua Duan02c981c2011-07-08 17:40:12 +080010#include <linux/init.h>
11#include <linux/kernel.h>
Barry Songef4acb72013-02-04 13:41:36 +080012#include <linux/irqchip.h>
Barry Song1bdfd27a2011-11-17 22:18:14 +080013#include <asm/sizes.h>
Binghua Duan02c981c2011-07-08 17:40:12 +080014#include <asm/mach-types.h>
15#include <asm/mach/arch.h>
16#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
Arnd Bergmann275786b2013-03-19 15:27:22 +010035static __init void sirfsoc_init_time(void)
36{
37 /* initialize clocking early, we want to set the OS timer */
38 sirfsoc_of_clk_init();
39 clocksource_of_init();
40}
41
Barry Song4898de32012-12-20 19:37:32 +080042static __init void sirfsoc_map_io(void)
43{
44 sirfsoc_map_lluart();
45 sirfsoc_map_scu();
46}
47
Barry Songd4fe49e2013-03-18 15:04:38 +080048#ifdef CONFIG_ARCH_ATLAS6
49static const char *atlas6_dt_match[] __initdata = {
50 "sirf,atlas6",
51 NULL
52};
53
54DT_MACHINE_START(ATLAS6_DT, "Generic ATLAS6 (Flattened Device Tree)")
55 /* Maintainer: Barry Song <baohua.song@csr.com> */
Arnd Bergmann630be7e2013-03-19 12:19:01 +010056 .nr_irqs = 128,
Barry Songd4fe49e2013-03-18 15:04:38 +080057 .map_io = sirfsoc_map_io,
Arnd Bergmann60dbd762013-03-19 11:21:44 +010058 .init_irq = irqchip_init,
Arnd Bergmann275786b2013-03-19 15:27:22 +010059 .init_time = sirfsoc_init_time,
Barry Songd4fe49e2013-03-18 15:04:38 +080060 .init_machine = sirfsoc_mach_init,
61 .init_late = sirfsoc_init_late,
62 .dt_compat = atlas6_dt_match,
63 .restart = sirfsoc_restart,
64MACHINE_END
65#endif
66
Barry Songd0ec63f2012-08-23 13:41:57 +080067#ifdef CONFIG_ARCH_PRIMA2
68static const char *prima2_dt_match[] __initdata = {
Barry Song5a0ec562013-03-05 11:00:43 +080069 "sirf,prima2",
70 NULL
Binghua Duan02c981c2011-07-08 17:40:12 +080071};
72
Barry Songd0ec63f2012-08-23 13:41:57 +080073DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
Binghua Duan02c981c2011-07-08 17:40:12 +080074 /* Maintainer: Barry Song <baohua.song@csr.com> */
Arnd Bergmann630be7e2013-03-19 12:19:01 +010075 .nr_irqs = 128,
Barry Song4898de32012-12-20 19:37:32 +080076 .map_io = sirfsoc_map_io,
Arnd Bergmann60dbd762013-03-19 11:21:44 +010077 .init_irq = irqchip_init,
Arnd Bergmann275786b2013-03-19 15:27:22 +010078 .init_time = sirfsoc_init_time,
Nicolas Pitre98b01242011-09-02 21:05:10 -040079 .dma_zone_size = SZ_256M,
Binghua Duan02c981c2011-07-08 17:40:12 +080080 .init_machine = sirfsoc_mach_init,
Shawn Guoa4b46742012-04-26 20:51:36 +080081 .init_late = sirfsoc_init_late,
Barry Songd0ec63f2012-08-23 13:41:57 +080082 .dt_compat = prima2_dt_match,
Russell King125c4032011-11-05 10:23:27 +000083 .restart = sirfsoc_restart,
Binghua Duan02c981c2011-07-08 17:40:12 +080084MACHINE_END
Barry Songd0ec63f2012-08-23 13:41:57 +080085#endif
Barry Song4898de32012-12-20 19:37:32 +080086
87#ifdef CONFIG_ARCH_MARCO
Barry Song4898de32012-12-20 19:37:32 +080088static const char *marco_dt_match[] __initdata = {
89 "sirf,marco",
90 NULL
91};
92
93DT_MACHINE_START(MARCO_DT, "Generic MARCO (Flattened Device Tree)")
94 /* Maintainer: Barry Song <baohua.song@csr.com> */
95 .smp = smp_ops(sirfsoc_smp_ops),
96 .map_io = sirfsoc_map_io,
Barry Songef4acb72013-02-04 13:41:36 +080097 .init_irq = irqchip_init,
Arnd Bergmann275786b2013-03-19 15:27:22 +010098 .init_time = sirfsoc_init_time,
Barry Song4898de32012-12-20 19:37:32 +080099 .init_machine = sirfsoc_mach_init,
100 .init_late = sirfsoc_init_late,
101 .dt_compat = marco_dt_match,
102 .restart = sirfsoc_restart,
103MACHINE_END
104#endif