blob: 72c4b5ff8f90d9ab35f5d6146910e0478adee2e3 [file] [log] [blame]
Simon Arlottec9653b2012-05-26 01:04:43 -06001/*
2 * Copyright (C) 2010 Broadcom
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 */
14
15#include <linux/init.h>
Simon Arlott89214f02012-09-12 19:57:26 -060016#include <linux/irqchip/bcm2835.h>
Simon Arlottec9653b2012-05-26 01:04:43 -060017#include <linux/of_platform.h>
18
19#include <asm/mach/arch.h>
20#include <asm/mach/map.h>
21#include <asm/mach/time.h>
Simon Arlottec9653b2012-05-26 01:04:43 -060022
23#include <mach/bcm2835_soc.h>
24
25static struct map_desc io_map __initdata = {
26 .virtual = BCM2835_PERIPH_VIRT,
27 .pfn = __phys_to_pfn(BCM2835_PERIPH_PHYS),
28 .length = BCM2835_PERIPH_SIZE,
29 .type = MT_DEVICE
30};
31
32void __init bcm2835_map_io(void)
33{
34 iotable_init(&io_map, 1);
35}
36
Simon Arlottec9653b2012-05-26 01:04:43 -060037void __init bcm2835_init(void)
38{
39 int ret;
40
41 ret = of_platform_populate(NULL, of_default_bus_match_table, NULL,
42 NULL);
43 if (ret) {
44 pr_err("of_platform_populate failed: %d\n", ret);
45 BUG();
46 }
47}
48
49static void __init bcm2835_timer_init(void)
50{
51}
52
53struct sys_timer bcm2835_timer = {
54 .init = bcm2835_timer_init
55};
56
57static const char * const bcm2835_compat[] = {
58 "brcm,bcm2835",
59 NULL
60};
61
62DT_MACHINE_START(BCM2835, "BCM2835")
63 .map_io = bcm2835_map_io,
64 .init_irq = bcm2835_init_irq,
65 .handle_irq = bcm2835_handle_irq,
66 .init_machine = bcm2835_init,
67 .timer = &bcm2835_timer,
68 .dt_compat = bcm2835_compat
69MACHINE_END