1 /***************************************************************************/
4 * m5249.c -- platform support for ColdFire 5249 based boards
6 * Copyright (C) 2002, Greg Ungerer (gerg@snapgear.com)
9 /***************************************************************************/
11 #include <linux/kernel.h>
12 #include <linux/param.h>
13 #include <linux/init.h>
15 #include <linux/platform_device.h>
16 #include <asm/machdep.h>
17 #include <asm/coldfire.h>
18 #include <asm/mcfsim.h>
19 #include <asm/mcfclk.h>
21 /***************************************************************************/
23 DEFINE_CLK(pll
, "pll.0", MCF_CLK
);
24 DEFINE_CLK(sys
, "sys.0", MCF_BUSCLK
);
25 DEFINE_CLK(mcftmr0
, "mcftmr.0", MCF_BUSCLK
);
26 DEFINE_CLK(mcftmr1
, "mcftmr.1", MCF_BUSCLK
);
27 DEFINE_CLK(mcfuart0
, "mcfuart.0", MCF_BUSCLK
);
28 DEFINE_CLK(mcfuart1
, "mcfuart.1", MCF_BUSCLK
);
29 DEFINE_CLK(mcfqspi0
, "mcfqspi.0", MCF_BUSCLK
);
31 struct clk
*mcf_clks
[] = {
42 /***************************************************************************/
46 static struct resource m5249_smc91x_resources
[] = {
49 .end
= 0xe0000300 + 0x100,
50 .flags
= IORESOURCE_MEM
,
53 .start
= MCF_IRQ_GPIO6
,
55 .flags
= IORESOURCE_IRQ
,
59 static struct platform_device m5249_smc91x
= {
62 .num_resources
= ARRAY_SIZE(m5249_smc91x_resources
),
63 .resource
= m5249_smc91x_resources
,
66 #endif /* CONFIG_M5249C3 */
68 static struct platform_device
*m5249_devices
[] __initdata
= {
74 /***************************************************************************/
76 static void __init
m5249_qspi_init(void)
78 #if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
80 writeb(MCFSIM_ICR_AUTOVEC
| MCFSIM_ICR_LEVEL4
| MCFSIM_ICR_PRI0
,
82 mcf_mapirq2imr(MCF_IRQ_QSPI
, MCFINTC_QSPI
);
83 #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
86 /***************************************************************************/
90 static void __init
m5249_smc91x_init(void)
94 /* Set the GPIO line as interrupt source for smc91x device */
95 gpio
= readl(MCFSIM2_GPIOINTENABLE
);
96 writel(gpio
| 0x40, MCFSIM2_GPIOINTENABLE
);
98 gpio
= readl(MCFINTC2_INTPRI5
);
99 writel(gpio
| 0x04000000, MCFINTC2_INTPRI5
);
102 #endif /* CONFIG_M5249C3 */
104 /***************************************************************************/
106 void __init
config_BSP(char *commandp
, int size
)
108 mach_sched_init
= hw_timer_init
;
110 #ifdef CONFIG_M5249C3
116 /***************************************************************************/
118 static int __init
init_BSP(void)
120 platform_add_devices(m5249_devices
, ARRAY_SIZE(m5249_devices
));
124 arch_initcall(init_BSP
);
126 /***************************************************************************/