blob: 353b86e3808f93afa297d3ce961a001cab43270c [file] [log] [blame]
Sascha Haueref4bac52012-09-20 14:59:36 +02001/*
2 * Copyright 2012 Sascha Hauer, Pengutronix
3 *
4 * The code contained herein is licensed under the GNU General Public
5 * License. You may obtain a copy of the GNU General Public License
6 * Version 2 or later at the following locations:
7 *
8 * http://www.opensource.org/licenses/gpl-license.html
9 * http://www.gnu.org/copyleft/gpl.html
10 */
11
12#include <linux/irq.h>
Fabio Estevam6869a222015-03-13 10:31:55 -030013#include <linux/of_address.h>
Sascha Haueref4bac52012-09-20 14:59:36 +020014#include <linux/of_irq.h>
15#include <linux/of_platform.h>
16#include <asm/mach/arch.h>
17#include <asm/mach/time.h>
18#include "common.h"
Fabio Estevam6869a222015-03-13 10:31:55 -030019#include "hardware.h"
20
21static void __init imx25_init_early(void)
22{
23 mxc_set_cpu_type(MXC_CPU_MX25);
24}
25
Martin Kaiser24bb2442017-04-03 21:47:05 +020026static void __init imx25_dt_init(void)
27{
28 imx_aips_allow_unprivileged_access("fsl,imx25-aips");
29}
30
Fabio Estevam6869a222015-03-13 10:31:55 -030031static void __init mx25_init_irq(void)
32{
33 struct device_node *np;
34 void __iomem *avic_base;
35
36 np = of_find_compatible_node(NULL, NULL, "fsl,avic");
37 avic_base = of_iomap(np, 0);
38 BUG_ON(!avic_base);
39 mxc_init_irq(avic_base);
40}
Sascha Haueref4bac52012-09-20 14:59:36 +020041
Sascha Haueref4bac52012-09-20 14:59:36 +020042static const char * const imx25_dt_board_compat[] __initconst = {
43 "fsl,imx25",
44 NULL
45};
46
47DT_MACHINE_START(IMX25_DT, "Freescale i.MX25 (Device Tree Support)")
Sascha Haueref4bac52012-09-20 14:59:36 +020048 .init_early = imx25_init_early,
Martin Kaiser24bb2442017-04-03 21:47:05 +020049 .init_machine = imx25_dt_init,
Fabio Estevam8c4300c2016-02-02 19:45:38 -020050 .init_late = imx25_pm_init,
Sascha Haueref4bac52012-09-20 14:59:36 +020051 .init_irq = mx25_init_irq,
Sascha Haueref4bac52012-09-20 14:59:36 +020052 .dt_compat = imx25_dt_board_compat,
Sascha Haueref4bac52012-09-20 14:59:36 +020053MACHINE_END