Commit e0d1ca33 authored by Viresh Kumar's avatar Viresh Kumar Committed by Daniel Lezcano

clockevents/drivers/digicolor: Migrate to new 'set-state' interface

Migrate digicolor driver to the new 'set-state' interface provided by
clockevents core, the earlier 'set-mode' interface is marked obsolete
now.

This also enables us to implement callbacks for new states of clockevent
devices, for example: ONESHOT_STOPPED.

Cc: Baruch Siach <baruch@tkos.co.il>
Signed-off-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
Acked-by: default avatarBaruch Siach <baruch@tkos.co.il>
Tested-by: default avatarBaruch Siach <baruch@tkos.co.il>
parent 8ab28230
...@@ -87,27 +87,27 @@ static inline void dc_timer_set_count(struct clock_event_device *ce, ...@@ -87,27 +87,27 @@ static inline void dc_timer_set_count(struct clock_event_device *ce,
writel(count, dt->base + COUNT(dt->timer_id)); writel(count, dt->base + COUNT(dt->timer_id));
} }
static void digicolor_clkevt_mode(enum clock_event_mode mode, static int digicolor_clkevt_shutdown(struct clock_event_device *ce)
struct clock_event_device *ce) {
dc_timer_disable(ce);
return 0;
}
static int digicolor_clkevt_set_oneshot(struct clock_event_device *ce)
{
dc_timer_disable(ce);
dc_timer_enable(ce, CONTROL_MODE_ONESHOT);
return 0;
}
static int digicolor_clkevt_set_periodic(struct clock_event_device *ce)
{ {
struct digicolor_timer *dt = dc_timer(ce); struct digicolor_timer *dt = dc_timer(ce);
switch (mode) { dc_timer_disable(ce);
case CLOCK_EVT_MODE_PERIODIC: dc_timer_set_count(ce, dt->ticks_per_jiffy);
dc_timer_disable(ce); dc_timer_enable(ce, CONTROL_MODE_PERIODIC);
dc_timer_set_count(ce, dt->ticks_per_jiffy); return 0;
dc_timer_enable(ce, CONTROL_MODE_PERIODIC);
break;
case CLOCK_EVT_MODE_ONESHOT:
dc_timer_disable(ce);
dc_timer_enable(ce, CONTROL_MODE_ONESHOT);
break;
case CLOCK_EVT_MODE_UNUSED:
case CLOCK_EVT_MODE_SHUTDOWN:
default:
dc_timer_disable(ce);
break;
}
} }
static int digicolor_clkevt_next_event(unsigned long evt, static int digicolor_clkevt_next_event(unsigned long evt,
...@@ -125,7 +125,10 @@ static struct digicolor_timer dc_timer_dev = { ...@@ -125,7 +125,10 @@ static struct digicolor_timer dc_timer_dev = {
.name = "digicolor_tick", .name = "digicolor_tick",
.rating = 340, .rating = 340,
.features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT,
.set_mode = digicolor_clkevt_mode, .set_state_shutdown = digicolor_clkevt_shutdown,
.set_state_periodic = digicolor_clkevt_set_periodic,
.set_state_oneshot = digicolor_clkevt_set_oneshot,
.tick_resume = digicolor_clkevt_shutdown,
.set_next_event = digicolor_clkevt_next_event, .set_next_event = digicolor_clkevt_next_event,
}, },
.timer_id = TIMER_C, .timer_id = TIMER_C,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment