diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-13 14:08:28 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-13 14:08:28 -0400 |
commit | 7fd56474db326f7a6df0e2a4e3a9600cc083ab9b (patch) | |
tree | 72611132105deedcde415e6f41c081fd784e31db /drivers/cpuidle | |
parent | 49d2953c72c64182ef2dcac64f6979c0b4e25db7 (diff) | |
parent | def747087e83aa5f6a71582cfa71e18341988688 (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.c | 23 |
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 | */ |
144 | static void cpuidle_setup_broadcast_timer(void *arg) | 141 | static 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); |