aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/cpuidle
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-04-13 14:08:28 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-04-13 14:08:28 -0400
commit7fd56474db326f7a6df0e2a4e3a9600cc083ab9b (patch)
tree72611132105deedcde415e6f41c081fd784e31db /drivers/cpuidle
parent49d2953c72c64182ef2dcac64f6979c0b4e25db7 (diff)
parentdef747087e83aa5f6a71582cfa71e18341988688 (diff)
Merge branch 'timers-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull timer updates from Ingo Molnar: "The main changes in this cycle were: - clockevents state machine cleanups and enhancements (Viresh Kumar) - clockevents broadcast notifier horror to state machine conversion and related cleanups (Thomas Gleixner, Rafael J Wysocki) - clocksource and timekeeping core updates (John Stultz) - clocksource driver updates and fixes (Ben Dooks, Dmitry Osipenko, Hans de Goede, Laurent Pinchart, Maxime Ripard, Xunlei Pang) - y2038 fixes (Xunlei Pang, John Stultz) - NMI-safe ktime_get_raw_fast() and general refactoring of the clock code, in preparation to perf's per event clock ID support (Peter Zijlstra) - generic sched/clock fixes, optimizations and cleanups (Daniel Thompson) - clockevents cpu_down() race fix (Preeti U Murthy)" * 'timers-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (94 commits) timers/PM: Drop unnecessary braces from tick_freeze() timers/PM: Fix up tick_unfreeze() timekeeping: Get rid of stale comment clockevents: Cleanup dead cpu explicitely clockevents: Make tick handover explicit clockevents: Remove broadcast oneshot control leftovers sched/idle: Use explicit broadcast oneshot control function ARM: Tegra: Use explicit broadcast oneshot control function ARM: OMAP: Use explicit broadcast oneshot control function intel_idle: Use explicit broadcast oneshot control function ACPI/idle: Use explicit broadcast control function ACPI/PAD: Use explicit broadcast oneshot control function x86/amd/idle, clockevents: Use explicit broadcast oneshot control functions clockevents: Provide explicit broadcast oneshot control functions clockevents: Remove the broadcast control leftovers ARM: OMAP: Use explicit broadcast control function intel_idle: Use explicit broadcast control function cpuidle: Use explicit broadcast control function ACPI/processor: Use explicit broadcast control function ACPI/PAD: Use explicit broadcast control function ...
Diffstat (limited to 'drivers/cpuidle')
-rw-r--r--drivers/cpuidle/driver.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/drivers/cpuidle/driver.c b/drivers/cpuidle/driver.c
index 2697e87d5b34..5db147859b90 100644
--- a/drivers/cpuidle/driver.c
+++ b/drivers/cpuidle/driver.c
@@ -13,7 +13,7 @@
13#include <linux/sched.h> 13#include <linux/sched.h>
14#include <linux/cpuidle.h> 14#include <linux/cpuidle.h>
15#include <linux/cpumask.h> 15#include <linux/cpumask.h>
16#include <linux/clockchips.h> 16#include <linux/tick.h>
17 17
18#include "cpuidle.h" 18#include "cpuidle.h"
19 19
@@ -130,21 +130,20 @@ static inline void __cpuidle_unset_driver(struct cpuidle_driver *drv)
130#endif 130#endif
131 131
132/** 132/**
133 * cpuidle_setup_broadcast_timer - enable/disable the broadcast timer 133 * cpuidle_setup_broadcast_timer - enable/disable the broadcast timer on a cpu
134 * @arg: a void pointer used to match the SMP cross call API 134 * @arg: a void pointer used to match the SMP cross call API
135 * 135 *
136 * @arg is used as a value of type 'long' with one of the two values: 136 * If @arg is NULL broadcast is disabled otherwise enabled
137 * - CLOCK_EVT_NOTIFY_BROADCAST_ON
138 * - CLOCK_EVT_NOTIFY_BROADCAST_OFF
139 * 137 *
140 * Set the broadcast timer notification for the current CPU. This function 138 * This function is executed per CPU by an SMP cross call. It's not
141 * is executed per CPU by an SMP cross call. It not supposed to be called 139 * supposed to be called directly.
142 * directly.
143 */ 140 */
144static void cpuidle_setup_broadcast_timer(void *arg) 141static void cpuidle_setup_broadcast_timer(void *arg)
145{ 142{
146 int cpu = smp_processor_id(); 143 if (arg)
147 clockevents_notify((long)(arg), &cpu); 144 tick_broadcast_enable();
145 else
146 tick_broadcast_disable();
148} 147}
149 148
150/** 149/**
@@ -239,7 +238,7 @@ static int __cpuidle_register_driver(struct cpuidle_driver *drv)
239 238
240 if (drv->bctimer) 239 if (drv->bctimer)
241 on_each_cpu_mask(drv->cpumask, cpuidle_setup_broadcast_timer, 240 on_each_cpu_mask(drv->cpumask, cpuidle_setup_broadcast_timer,
242 (void *)CLOCK_EVT_NOTIFY_BROADCAST_ON, 1); 241 (void *)1, 1);
243 242
244 poll_idle_init(drv); 243 poll_idle_init(drv);
245 244
@@ -263,7 +262,7 @@ static void __cpuidle_unregister_driver(struct cpuidle_driver *drv)
263 if (drv->bctimer) { 262 if (drv->bctimer) {
264 drv->bctimer = 0; 263 drv->bctimer = 0;
265 on_each_cpu_mask(drv->cpumask, cpuidle_setup_broadcast_timer, 264 on_each_cpu_mask(drv->cpumask, cpuidle_setup_broadcast_timer,
266 (void *)CLOCK_EVT_NOTIFY_BROADCAST_OFF, 1); 265 NULL, 1);
267 } 266 }
268 267
269 __cpuidle_unset_driver(drv); 268 __cpuidle_unset_driver(drv);