[PATCH linux dev-5.3 3/4] clocksource: fttmr010: Set interrupt and shutdown

Cédric Le Goater clg at kaod.org
Thu Nov 7 01:34:10 AEDT 2019


On 06/11/2019 10:17, Joel Stanley wrote:
> In preparation for supporting the ast2600, pass the shutdown and
> interrupt functions to the common init callback.
> 
> Signed-off-by: Joel Stanley <joel at jms.id.au>

Reviewed-by: Cédric Le Goater <clg at kaod.org>

> ---
>  drivers/clocksource/timer-fttmr010.c | 17 ++++++++++++-----
>  1 file changed, 12 insertions(+), 5 deletions(-)
> 
> diff --git a/drivers/clocksource/timer-fttmr010.c b/drivers/clocksource/timer-fttmr010.c
> index c2d30eb9dc72..8a79025339d0 100644
> --- a/drivers/clocksource/timer-fttmr010.c
> +++ b/drivers/clocksource/timer-fttmr010.c
> @@ -244,7 +244,10 @@ static irqreturn_t fttmr010_timer_interrupt(int irq, void *dev_id)
>  	return IRQ_HANDLED;
>  }
>  
> -static int __init fttmr010_common_init(struct device_node *np, bool is_aspeed)
> +static int __init fttmr010_common_init(struct device_node *np,
> +		bool is_aspeed,
> +		int (*timer_shutdown)(struct clock_event_device *),
> +		irq_handler_t handler)

may be rename handler -> irq_handler. This is minor, just better for 
readability.

C. 

>  {
>  	struct fttmr010 *fttmr010;
>  	int irq;
> @@ -345,7 +348,7 @@ static int __init fttmr010_common_init(struct device_node *np, bool is_aspeed)
>  				     fttmr010->tick_rate);
>  	}
>  
> -	fttmr010->timer_shutdown = fttmr010_timer_shutdown;
> +	fttmr010->timer_shutdown = timer_shutdown;
>  
>  	/*
>  	 * Setup clockevent timer (interrupt-driven) on timer 1.
> @@ -354,7 +357,7 @@ static int __init fttmr010_common_init(struct device_node *np, bool is_aspeed)
>  	writel(0, fttmr010->base + TIMER1_LOAD);
>  	writel(0, fttmr010->base + TIMER1_MATCH1);
>  	writel(0, fttmr010->base + TIMER1_MATCH2);
> -	ret = request_irq(irq, fttmr010_timer_interrupt, IRQF_TIMER,
> +	ret = request_irq(irq, handler, IRQF_TIMER,
>  			  "FTTMR010-TIMER1", &fttmr010->clkevt);
>  	if (ret) {
>  		pr_err("FTTMR010-TIMER1 no IRQ\n");
> @@ -403,12 +406,16 @@ static int __init fttmr010_common_init(struct device_node *np, bool is_aspeed)
>  
>  static __init int aspeed_timer_init(struct device_node *np)
>  {
> -	return fttmr010_common_init(np, true);
> +	return fttmr010_common_init(np, true,
> +			fttmr010_timer_shutdown,
> +			fttmr010_timer_interrupt);
>  }
>  
>  static __init int fttmr010_timer_init(struct device_node *np)
>  {
> -	return fttmr010_common_init(np, false);
> +	return fttmr010_common_init(np, false,
> +			fttmr010_timer_shutdown,
> +			fttmr010_timer_interrupt);
>  }
>  
>  TIMER_OF_DECLARE(fttmr010, "faraday,fttmr010", fttmr010_timer_init);
> 



More information about the openbmc mailing list