diff options
Diffstat (limited to 'arch/arm/mach-spear6xx/spear6xx.c')
| -rw-r--r-- | arch/arm/mach-spear6xx/spear6xx.c | 60 | 
1 files changed, 43 insertions, 17 deletions
| diff --git a/arch/arm/mach-spear6xx/spear6xx.c b/arch/arm/mach-spear6xx/spear6xx.c index f2fe14e8471d..981812961ac7 100644 --- a/arch/arm/mach-spear6xx/spear6xx.c +++ b/arch/arm/mach-spear6xx/spear6xx.c @@ -18,9 +18,9 @@  #include <asm/hardware/vic.h>  #include <asm/irq.h>  #include <asm/mach/arch.h> -#include <mach/irqs.h>  #include <mach/generic.h> -#include <mach/spear.h> +#include <mach/hardware.h> +#include <mach/irqs.h>  /* Add spear6xx machines common devices here */  /* uart device registration */ @@ -31,8 +31,7 @@ struct amba_device uart_device[] = {  		},  		.res = {  			.start = SPEAR6XX_ICM1_UART0_BASE, -			.end = SPEAR6XX_ICM1_UART0_BASE + -				SPEAR6XX_ICM1_UART0_SIZE - 1, +			.end = SPEAR6XX_ICM1_UART0_BASE + SZ_4K - 1,  			.flags = IORESOURCE_MEM,  		},  		.irq = {IRQ_UART_0, NO_IRQ}, @@ -42,8 +41,7 @@ struct amba_device uart_device[] = {  		},  		.res = {  			.start = SPEAR6XX_ICM1_UART1_BASE, -			.end = SPEAR6XX_ICM1_UART1_BASE + -				SPEAR6XX_ICM1_UART1_SIZE - 1, +			.end = SPEAR6XX_ICM1_UART1_BASE + SZ_4K - 1,  			.flags = IORESOURCE_MEM,  		},  		.irq = {IRQ_UART_1, NO_IRQ}, @@ -72,8 +70,7 @@ struct amba_device gpio_device[] = {  		},  		.res = {  			.start = SPEAR6XX_CPU_GPIO_BASE, -			.end = SPEAR6XX_CPU_GPIO_BASE + -				SPEAR6XX_CPU_GPIO_SIZE - 1, +			.end = SPEAR6XX_CPU_GPIO_BASE + SZ_4K - 1,  			.flags = IORESOURCE_MEM,  		},  		.irq = {IRQ_LOCAL_GPIO, NO_IRQ}, @@ -84,8 +81,7 @@ struct amba_device gpio_device[] = {  		},  		.res = {  			.start = SPEAR6XX_ICM3_GPIO_BASE, -			.end = SPEAR6XX_ICM3_GPIO_BASE + -				SPEAR6XX_ICM3_GPIO_SIZE - 1, +			.end = SPEAR6XX_ICM3_GPIO_BASE + SZ_4K - 1,  			.flags = IORESOURCE_MEM,  		},  		.irq = {IRQ_BASIC_GPIO, NO_IRQ}, @@ -96,8 +92,7 @@ struct amba_device gpio_device[] = {  		},  		.res = {  			.start = SPEAR6XX_ICM2_GPIO_BASE, -			.end = SPEAR6XX_ICM2_GPIO_BASE + -				SPEAR6XX_ICM2_GPIO_SIZE - 1, +			.end = SPEAR6XX_ICM2_GPIO_BASE + SZ_4K - 1,  			.flags = IORESOURCE_MEM,  		},  		.irq = {IRQ_APPL_GPIO, NO_IRQ}, @@ -122,27 +117,27 @@ static struct map_desc spear6xx_io_desc[] __initdata = {  	{  		.virtual	= VA_SPEAR6XX_ICM1_UART0_BASE,  		.pfn		= __phys_to_pfn(SPEAR6XX_ICM1_UART0_BASE), -		.length		= SPEAR6XX_ICM1_UART0_SIZE, +		.length		= SZ_4K,  		.type		= MT_DEVICE  	}, {  		.virtual	= VA_SPEAR6XX_CPU_VIC_PRI_BASE,  		.pfn		= __phys_to_pfn(SPEAR6XX_CPU_VIC_PRI_BASE), -		.length		= SPEAR6XX_CPU_VIC_PRI_SIZE, +		.length		= SZ_4K,  		.type		= MT_DEVICE  	}, {  		.virtual	= VA_SPEAR6XX_CPU_VIC_SEC_BASE,  		.pfn		= __phys_to_pfn(SPEAR6XX_CPU_VIC_SEC_BASE), -		.length		= SPEAR6XX_CPU_VIC_SEC_SIZE, +		.length		= SZ_4K,  		.type		= MT_DEVICE  	}, {  		.virtual	= VA_SPEAR6XX_ICM3_SYS_CTRL_BASE,  		.pfn		= __phys_to_pfn(SPEAR6XX_ICM3_SYS_CTRL_BASE), -		.length		= SPEAR6XX_ICM3_MISC_REG_BASE, +		.length		= SZ_4K,  		.type		= MT_DEVICE  	}, {  		.virtual	= VA_SPEAR6XX_ICM3_MISC_REG_BASE,  		.pfn		= __phys_to_pfn(SPEAR6XX_ICM3_MISC_REG_BASE), -		.length		= SPEAR6XX_ICM3_MISC_REG_SIZE, +		.length		= SZ_4K,  		.type		= MT_DEVICE  	},  }; @@ -155,3 +150,34 @@ void __init spear6xx_map_io(void)  	/* This will initialize clock framework */  	clk_init();  } + +static void __init spear6xx_timer_init(void) +{ +	char pclk_name[] = "pll3_48m_clk"; +	struct clk *gpt_clk, *pclk; + +	/* get the system timer clock */ +	gpt_clk = clk_get_sys("gpt0", NULL); +	if (IS_ERR(gpt_clk)) { +		pr_err("%s:couldn't get clk for gpt\n", __func__); +		BUG(); +	} + +	/* get the suitable parent clock for timer*/ +	pclk = clk_get(NULL, pclk_name); +	if (IS_ERR(pclk)) { +		pr_err("%s:couldn't get %s as parent for gpt\n", +				__func__, pclk_name); +		BUG(); +	} + +	clk_set_parent(gpt_clk, pclk); +	clk_put(gpt_clk); +	clk_put(pclk); + +	spear_setup_timer(); +} + +struct sys_timer spear6xx_timer = { +	.init = spear6xx_timer_init, +}; | 
