19
19
#include <asm/irq.h>
20
20
#include <asm/mach/arch.h>
21
21
#include <mach/generic.h>
22
#include <mach/spear.h>
22
#include <mach/hardware.h>
24
24
/* Add spear3xx machines common devices here */
25
25
/* gpio device registration */
37
37
.start = SPEAR3XX_ICM3_GPIO_BASE,
38
.end = SPEAR3XX_ICM3_GPIO_BASE + SPEAR3XX_ICM3_GPIO_SIZE - 1,
38
.end = SPEAR3XX_ICM3_GPIO_BASE + SZ_4K - 1,
39
39
.flags = IORESOURCE_MEM,
41
41
.irq = {IRQ_BASIC_GPIO, NO_IRQ},
50
50
.start = SPEAR3XX_ICM1_UART_BASE,
51
.end = SPEAR3XX_ICM1_UART_BASE + SPEAR3XX_ICM1_UART_SIZE - 1,
51
.end = SPEAR3XX_ICM1_UART_BASE + SZ_4K - 1,
52
52
.flags = IORESOURCE_MEM,
54
54
.irq = {IRQ_UART, NO_IRQ},
72
72
.virtual = VA_SPEAR3XX_ICM1_UART_BASE,
73
73
.pfn = __phys_to_pfn(SPEAR3XX_ICM1_UART_BASE),
74
.length = SPEAR3XX_ICM1_UART_SIZE,
77
77
.virtual = VA_SPEAR3XX_ML1_VIC_BASE,
78
78
.pfn = __phys_to_pfn(SPEAR3XX_ML1_VIC_BASE),
79
.length = SPEAR3XX_ML1_VIC_SIZE,
82
82
.virtual = VA_SPEAR3XX_ICM3_SYS_CTRL_BASE,
83
83
.pfn = __phys_to_pfn(SPEAR3XX_ICM3_SYS_CTRL_BASE),
84
.length = SPEAR3XX_ICM3_SYS_CTRL_SIZE,
87
87
.virtual = VA_SPEAR3XX_ICM3_MISC_REG_BASE,
88
88
.pfn = __phys_to_pfn(SPEAR3XX_ICM3_MISC_REG_BASE),
89
.length = SPEAR3XX_ICM3_MISC_REG_SIZE,
523
523
.mode_count = ARRAY_SIZE(pmx_plgpio_45_46_49_50_modes),
524
524
.enb_on_reset = 1,
529
/* spear padmux initialization function */
530
void spear_pmx_init(struct pmx_driver *pmx_driver, uint base, uint size)
526
#endif /* CONFIG_MACH_SPEAR310 || CONFIG_MACH_SPEAR320 */
528
static void __init spear3xx_timer_init(void)
534
/* pad mux initialization */
535
pmx_driver->base = ioremap(base, size);
536
if (!pmx_driver->base) {
541
ret = pmx_register(pmx_driver);
542
iounmap(pmx_driver->base);
546
printk(KERN_ERR "padmux: registration failed. err no: %d\n",
530
char pclk_name[] = "pll3_48m_clk";
531
struct clk *gpt_clk, *pclk;
533
/* get the system timer clock */
534
gpt_clk = clk_get_sys("gpt0", NULL);
535
if (IS_ERR(gpt_clk)) {
536
pr_err("%s:couldn't get clk for gpt\n", __func__);
540
/* get the suitable parent clock for timer*/
541
pclk = clk_get(NULL, pclk_name);
543
pr_err("%s:couldn't get %s as parent for gpt\n",
544
__func__, pclk_name);
548
clk_set_parent(gpt_clk, pclk);
555
struct sys_timer spear3xx_timer = {
556
.init = spear3xx_timer_init,