[PATCH 5/7] Samsung: SMDKV210: Init Timer Using Device tree

Grant Likely grant.likely at secretlab.ca
Fri Sep 24 06:01:46 EST 2010


On Mon, Sep 20, 2010 at 03:49:57PM +0530, Shaju Abraham wrote:
> Get the irq number and virtual address to be used from the
> device tree. Initialise the timer using these parameters.
> 
> Signed-off-by: Shaju Abraham <shaju.abraham at linaro.org>
> ---
>  arch/arm/plat-s5p/irq_dt.c |   29 +++++++++++++++++++++++------
>  1 files changed, 23 insertions(+), 6 deletions(-)
> 
> diff --git a/arch/arm/plat-s5p/irq_dt.c b/arch/arm/plat-s5p/irq_dt.c
> index 2fca196..317348f 100644
> --- a/arch/arm/plat-s5p/irq_dt.c
> +++ b/arch/arm/plat-s5p/irq_dt.c
> @@ -58,7 +58,28 @@ static struct s3c_uart_irq uart_irqs[] = {
>  	},
>  #endif
>  };
> +int s5p_dt_init_vic_timer_irq(void)
> +{
> +	struct device_node *node;
> +	int err = -ENODEV, irq = 0;
> +	const u32 *prop;
> +	u32 virt_irq = 0;
>  
> +	for_each_compatible_node(node, NULL , "samsung,s5p-timer") {
> +		prop = of_get_property(node, "interrupts", NULL);
> +		if (prop == NULL) {
> +			printk(KERN_ERR "No Irq defined for %s timer\n",
> +				node->name);
> +			return err;
> +		}
> +		irq = of_read_ulong(prop, 1);
> +		s3c_init_vic_timer_irq(S5P_IRQ_VIC0(irq),
> +					S5P_TIMER_IRQ(virt_irq));
> +		virt_irq++;
> +	}
> +	of_node_put(node);
> +	return 0;
> +}
>  
>  static int __init s5p_dt_vic_init(void)
>  {
> @@ -88,11 +109,7 @@ void __init s5p_dt_init_irq(void)
>  
>  	/* initialize the VICs */
>  	s5p_dt_vic_init();
> -	s3c_init_vic_timer_irq(IRQ_TIMER0_VIC, IRQ_TIMER0);
> -	s3c_init_vic_timer_irq(IRQ_TIMER1_VIC, IRQ_TIMER1);
> -	s3c_init_vic_timer_irq(IRQ_TIMER2_VIC, IRQ_TIMER2);
> -	s3c_init_vic_timer_irq(IRQ_TIMER3_VIC, IRQ_TIMER3);
> -	s3c_init_vic_timer_irq(IRQ_TIMER4_VIC, IRQ_TIMER4);
> -
> +	if (s5p_dt_init_vic_timer_irq())
> +		printk(KERN_ERR"s5p_dt Timer init Failed\n");

Ah, heh.  Forget my comment from the last patch as you are doing what
I suggested here.  You can probably merge this patch with the previous
patch.


>  	s3c_init_uart_irqs(uart_irqs, ARRAY_SIZE(uart_irqs));
>  }
> -- 
> 1.7.2
> 
> _______________________________________________
> devicetree-discuss mailing list
> devicetree-discuss at lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/devicetree-discuss


More information about the devicetree-discuss mailing list