提交 d2b578e5 编写于 作者: D Daniel Lezcano 提交者: Rafael J. Wysocki

cpuidle / ux500 : use CPUIDLE_FLAG_TIMER_STOP flag

Use the CPUIDLE_FLAG_TIMER_STOP and let the cpuidle framework
to handle the CLOCK_EVT_NOTIFY_BROADCAST_ENTER/EXIT when entering
this state.
Signed-off-by: NDaniel Lezcano <daniel.lezcano@linaro.org>
Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
上级 8de46eff
...@@ -30,8 +30,6 @@ static inline int ux500_enter_idle(struct cpuidle_device *dev, ...@@ -30,8 +30,6 @@ static inline int ux500_enter_idle(struct cpuidle_device *dev,
int this_cpu = smp_processor_id(); int this_cpu = smp_processor_id();
bool recouple = false; bool recouple = false;
clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_ENTER, &this_cpu);
if (atomic_inc_return(&master) == num_online_cpus()) { if (atomic_inc_return(&master) == num_online_cpus()) {
/* With this lock, we prevent the other cpu to exit and enter /* With this lock, we prevent the other cpu to exit and enter
...@@ -91,8 +89,6 @@ static inline int ux500_enter_idle(struct cpuidle_device *dev, ...@@ -91,8 +89,6 @@ static inline int ux500_enter_idle(struct cpuidle_device *dev,
spin_unlock(&master_lock); spin_unlock(&master_lock);
} }
clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_EXIT, &this_cpu);
return index; return index;
} }
...@@ -106,7 +102,8 @@ static struct cpuidle_driver ux500_idle_driver = { ...@@ -106,7 +102,8 @@ static struct cpuidle_driver ux500_idle_driver = {
.enter = ux500_enter_idle, .enter = ux500_enter_idle,
.exit_latency = 70, .exit_latency = 70,
.target_residency = 260, .target_residency = 260,
.flags = CPUIDLE_FLAG_TIME_VALID, .flags = CPUIDLE_FLAG_TIME_VALID |
CPUIDLE_FLAG_TIMER_STOP,
.name = "ApIdle", .name = "ApIdle",
.desc = "ARM Retention", .desc = "ARM Retention",
}, },
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册