aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/clocksource/arm_arch_timer.c
diff options
context:
space:
mode:
authorViresh Kumar <viresh.kumar@linaro.org>2015-12-23 06:29:12 -0500
committerDaniel Lezcano <daniel.lezcano@linaro.org>2016-02-25 08:34:05 -0500
commitcf8c5009ee37d25cf4da0a250f3044ec6d1144a0 (patch)
treec33c26fa30da506ed8ff56b8e69f4ceeda27c1b0 /drivers/clocksource/arm_arch_timer.c
parentbbaa06702719818913ed686612d0db477b2b53b0 (diff)
clockevents/drivers/arm_arch_timer: Implement ->set_state_oneshot_stopped()
set_state_oneshot_stopped() is called by the clkevt core, when the next event is required at an expiry time of 'KTIME_MAX'. This normally happens with NO_HZ_{IDLE|FULL} in both LOWRES/HIGHRES modes. This patch makes the clockevent device to stop on such an event, to avoid spurious interrupts, as explained by: commit 8fff52fd5093 ("clockevents: Introduce CLOCK_EVT_STATE_ONESHOT_STOPPED state"). Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Diffstat (limited to 'drivers/clocksource/arm_arch_timer.c')
-rw-r--r--drivers/clocksource/arm_arch_timer.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/clocksource/arm_arch_timer.c b/drivers/clocksource/arm_arch_timer.c
index 7c567f0c87f5..f0dd9d42bc7b 100644
--- a/drivers/clocksource/arm_arch_timer.c
+++ b/drivers/clocksource/arm_arch_timer.c
@@ -274,10 +274,12 @@ static void __arch_timer_setup(unsigned type,
274 if (arch_timer_use_virtual) { 274 if (arch_timer_use_virtual) {
275 clk->irq = arch_timer_ppi[VIRT_PPI]; 275 clk->irq = arch_timer_ppi[VIRT_PPI];
276 clk->set_state_shutdown = arch_timer_shutdown_virt; 276 clk->set_state_shutdown = arch_timer_shutdown_virt;
277 clk->set_state_oneshot_stopped = arch_timer_shutdown_virt;
277 clk->set_next_event = arch_timer_set_next_event_virt; 278 clk->set_next_event = arch_timer_set_next_event_virt;
278 } else { 279 } else {
279 clk->irq = arch_timer_ppi[PHYS_SECURE_PPI]; 280 clk->irq = arch_timer_ppi[PHYS_SECURE_PPI];
280 clk->set_state_shutdown = arch_timer_shutdown_phys; 281 clk->set_state_shutdown = arch_timer_shutdown_phys;
282 clk->set_state_oneshot_stopped = arch_timer_shutdown_phys;
281 clk->set_next_event = arch_timer_set_next_event_phys; 283 clk->set_next_event = arch_timer_set_next_event_phys;
282 } 284 }
283 } else { 285 } else {
@@ -287,10 +289,12 @@ static void __arch_timer_setup(unsigned type,
287 clk->cpumask = cpu_all_mask; 289 clk->cpumask = cpu_all_mask;
288 if (arch_timer_mem_use_virtual) { 290 if (arch_timer_mem_use_virtual) {
289 clk->set_state_shutdown = arch_timer_shutdown_virt_mem; 291 clk->set_state_shutdown = arch_timer_shutdown_virt_mem;
292 clk->set_state_oneshot_stopped = arch_timer_shutdown_virt_mem;
290 clk->set_next_event = 293 clk->set_next_event =
291 arch_timer_set_next_event_virt_mem; 294 arch_timer_set_next_event_virt_mem;
292 } else { 295 } else {
293 clk->set_state_shutdown = arch_timer_shutdown_phys_mem; 296 clk->set_state_shutdown = arch_timer_shutdown_phys_mem;
297 clk->set_state_oneshot_stopped = arch_timer_shutdown_phys_mem;
294 clk->set_next_event = 298 clk->set_next_event =
295 arch_timer_set_next_event_phys_mem; 299 arch_timer_set_next_event_phys_mem;
296 } 300 }