diff options
author | Viresh Kumar <viresh.kumar@linaro.org> | 2015-07-16 07:26:18 -0400 |
---|---|---|
committer | Daniel Lezcano <daniel.lezcano@linaro.org> | 2015-08-10 05:41:08 -0400 |
commit | 2b5cf544934fe15f7b2f8bd26696284606f9e7d3 (patch) | |
tree | d71f3a66def755f714401f584aa8b11d583daf6c /arch/cris | |
parent | ecbebcb868bed598354d3b6d94cfeb10e440e4ca (diff) |
cris/time: Migrate to new 'set-state' interface
Migrate cris 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: Mikael Starvik <starvik@axis.com>
Cc: Jesper Nilsson <jesper.nilsson@axis.com>
Cc: Rabin Vincent <rabin@rab.in>
Cc: Guenter Roeck <linux@roeck-us.net>
Cc: linux-cris-kernel@axis.com
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Diffstat (limited to 'arch/cris')
-rw-r--r-- | arch/cris/arch-v32/kernel/time.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/arch/cris/arch-v32/kernel/time.c b/arch/cris/arch-v32/kernel/time.c index 4fce9f1f7cc0..d2a84407654a 100644 --- a/arch/cris/arch-v32/kernel/time.c +++ b/arch/cris/arch-v32/kernel/time.c | |||
@@ -172,8 +172,7 @@ void handle_watchdog_bite(struct pt_regs *regs) | |||
172 | extern void cris_profile_sample(struct pt_regs *regs); | 172 | extern void cris_profile_sample(struct pt_regs *regs); |
173 | static void __iomem *timer_base; | 173 | static void __iomem *timer_base; |
174 | 174 | ||
175 | static void crisv32_clkevt_mode(enum clock_event_mode mode, | 175 | static int crisv32_clkevt_switch_state(struct clock_event_device *dev) |
176 | struct clock_event_device *dev) | ||
177 | { | 176 | { |
178 | reg_timer_rw_tmr0_ctrl ctrl = { | 177 | reg_timer_rw_tmr0_ctrl ctrl = { |
179 | .op = regk_timer_hold, | 178 | .op = regk_timer_hold, |
@@ -181,6 +180,7 @@ static void crisv32_clkevt_mode(enum clock_event_mode mode, | |||
181 | }; | 180 | }; |
182 | 181 | ||
183 | REG_WR(timer, timer_base, rw_tmr0_ctrl, ctrl); | 182 | REG_WR(timer, timer_base, rw_tmr0_ctrl, ctrl); |
183 | return 0; | ||
184 | } | 184 | } |
185 | 185 | ||
186 | static int crisv32_clkevt_next_event(unsigned long evt, | 186 | static int crisv32_clkevt_next_event(unsigned long evt, |
@@ -231,7 +231,9 @@ static struct clock_event_device crisv32_clockevent = { | |||
231 | .name = "crisv32-timer", | 231 | .name = "crisv32-timer", |
232 | .rating = 300, | 232 | .rating = 300, |
233 | .features = CLOCK_EVT_FEAT_ONESHOT, | 233 | .features = CLOCK_EVT_FEAT_ONESHOT, |
234 | .set_mode = crisv32_clkevt_mode, | 234 | .set_state_oneshot = crisv32_clkevt_switch_state, |
235 | .set_state_shutdown = crisv32_clkevt_switch_state, | ||
236 | .tick_resume = crisv32_clkevt_switch_state, | ||
235 | .set_next_event = crisv32_clkevt_next_event, | 237 | .set_next_event = crisv32_clkevt_next_event, |
236 | }; | 238 | }; |
237 | 239 | ||