diff options
| author | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
|---|---|---|
| committer | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
| commit | 79828b4fa835f73cdaf4bffa48696abdcbea9d02 (patch) | |
| tree | 5e0fa7156acb75ba603022bc807df8f2fedb97a8 /drivers/clocksource/timer-atlas7.c | |
| parent | 721b51fcf91898299d96f4b72cb9434cda29dce6 (diff) | |
| parent | 8c1a9d6323abf0fb1e5dad96cf3f1c783505ea5a (diff) | |
Merge remote-tracking branch 'asoc/fix/rt5645' into asoc-fix-rt5645
Diffstat (limited to 'drivers/clocksource/timer-atlas7.c')
| -rw-r--r-- | drivers/clocksource/timer-atlas7.c | 19 | 
1 files changed, 7 insertions, 12 deletions
diff --git a/drivers/clocksource/timer-atlas7.c b/drivers/clocksource/timer-atlas7.c index 60f9de3438b0..27fa13680be1 100644 --- a/drivers/clocksource/timer-atlas7.c +++ b/drivers/clocksource/timer-atlas7.c @@ -76,7 +76,7 @@ static irqreturn_t sirfsoc_timer_interrupt(int irq, void *dev_id)  	/* clear timer interrupt */  	writel_relaxed(BIT(cpu), sirfsoc_timer_base + SIRFSOC_TIMER_INTR_STATUS); -	if (ce->mode == CLOCK_EVT_MODE_ONESHOT) +	if (clockevent_state_oneshot(ce))  		sirfsoc_timer_count_disable(cpu);  	ce->event_handler(ce); @@ -117,18 +117,11 @@ static int sirfsoc_timer_set_next_event(unsigned long delta,  	return 0;  } -static void sirfsoc_timer_set_mode(enum clock_event_mode mode, -	struct clock_event_device *ce) +/* Oneshot is enabled in set_next_event */ +static int sirfsoc_timer_shutdown(struct clock_event_device *evt)  { -	switch (mode) { -	case CLOCK_EVT_MODE_ONESHOT: -		/* enable in set_next_event */ -		break; -	default: -		break; -	} -  	sirfsoc_timer_count_disable(smp_processor_id()); +	return 0;  }  static void sirfsoc_clocksource_suspend(struct clocksource *cs) @@ -193,7 +186,9 @@ static int sirfsoc_local_timer_setup(struct clock_event_device *ce)  	ce->name = "local_timer";  	ce->features = CLOCK_EVT_FEAT_ONESHOT;  	ce->rating = 200; -	ce->set_mode = sirfsoc_timer_set_mode; +	ce->set_state_shutdown = sirfsoc_timer_shutdown; +	ce->set_state_oneshot = sirfsoc_timer_shutdown; +	ce->tick_resume = sirfsoc_timer_shutdown;  	ce->set_next_event = sirfsoc_timer_set_next_event;  	clockevents_calc_mult_shift(ce, atlas7_timer_rate, 60);  	ce->max_delta_ns = clockevent_delta2ns(-2, ce);  |