Merge branch 'idle' into release
This commit is contained in:
commit
f752a091ab
|
@ -581,6 +581,11 @@ static int acpi_processor_power_verify(struct acpi_processor *pr)
|
||||||
for (i = 1; i < ACPI_PROCESSOR_MAX_POWER; i++) {
|
for (i = 1; i < ACPI_PROCESSOR_MAX_POWER; i++) {
|
||||||
struct acpi_processor_cx *cx = &pr->power.states[i];
|
struct acpi_processor_cx *cx = &pr->power.states[i];
|
||||||
|
|
||||||
|
#if defined (CONFIG_GENERIC_TIME) && defined (CONFIG_X86)
|
||||||
|
/* TSC could halt in idle, so notify users */
|
||||||
|
if (tsc_halts_in_c(cx->type))
|
||||||
|
mark_tsc_unstable("TSC halts in idle");;
|
||||||
|
#endif
|
||||||
switch (cx->type) {
|
switch (cx->type) {
|
||||||
case ACPI_STATE_C1:
|
case ACPI_STATE_C1:
|
||||||
cx->valid = 1;
|
cx->valid = 1;
|
||||||
|
@ -657,11 +662,9 @@ static int acpi_processor_power_seq_show(struct seq_file *seq, void *offset)
|
||||||
|
|
||||||
seq_printf(seq, "active state: C%zd\n"
|
seq_printf(seq, "active state: C%zd\n"
|
||||||
"max_cstate: C%d\n"
|
"max_cstate: C%d\n"
|
||||||
"bus master activity: %08x\n"
|
|
||||||
"maximum allowed latency: %d usec\n",
|
"maximum allowed latency: %d usec\n",
|
||||||
pr->power.state ? pr->power.state - pr->power.states : 0,
|
pr->power.state ? pr->power.state - pr->power.states : 0,
|
||||||
max_cstate, (unsigned)pr->power.bm_activity,
|
max_cstate, pm_qos_requirement(PM_QOS_CPU_DMA_LATENCY));
|
||||||
pm_qos_requirement(PM_QOS_CPU_DMA_LATENCY));
|
|
||||||
|
|
||||||
seq_puts(seq, "states:\n");
|
seq_puts(seq, "states:\n");
|
||||||
|
|
||||||
|
@ -871,11 +874,6 @@ static int acpi_idle_enter_simple(struct cpuidle_device *dev,
|
||||||
kt2 = ktime_get_real();
|
kt2 = ktime_get_real();
|
||||||
idle_time = ktime_to_us(ktime_sub(kt2, kt1));
|
idle_time = ktime_to_us(ktime_sub(kt2, kt1));
|
||||||
|
|
||||||
#if defined (CONFIG_GENERIC_TIME) && defined (CONFIG_X86)
|
|
||||||
/* TSC could halt in idle, so notify users */
|
|
||||||
if (tsc_halts_in_c(cx->type))
|
|
||||||
mark_tsc_unstable("TSC halts in idle");;
|
|
||||||
#endif
|
|
||||||
sleep_ticks = us_to_pm_timer_ticks(idle_time);
|
sleep_ticks = us_to_pm_timer_ticks(idle_time);
|
||||||
|
|
||||||
/* Tell the scheduler how much we idled: */
|
/* Tell the scheduler how much we idled: */
|
||||||
|
@ -989,11 +987,6 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev,
|
||||||
spin_unlock(&c3_lock);
|
spin_unlock(&c3_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined (CONFIG_GENERIC_TIME) && defined (CONFIG_X86)
|
|
||||||
/* TSC could halt in idle, so notify users */
|
|
||||||
if (tsc_halts_in_c(ACPI_STATE_C3))
|
|
||||||
mark_tsc_unstable("TSC halts in idle");
|
|
||||||
#endif
|
|
||||||
sleep_ticks = us_to_pm_timer_ticks(idle_time);
|
sleep_ticks = us_to_pm_timer_ticks(idle_time);
|
||||||
/* Tell the scheduler how much we idled: */
|
/* Tell the scheduler how much we idled: */
|
||||||
sched_clock_idle_wakeup_event(sleep_ticks*PM_TIMER_TICK_NS);
|
sched_clock_idle_wakeup_event(sleep_ticks*PM_TIMER_TICK_NS);
|
||||||
|
|
|
@ -84,7 +84,6 @@ struct acpi_processor_power {
|
||||||
struct acpi_processor_cx *state;
|
struct acpi_processor_cx *state;
|
||||||
unsigned long bm_check_timestamp;
|
unsigned long bm_check_timestamp;
|
||||||
u32 default_state;
|
u32 default_state;
|
||||||
u32 bm_activity;
|
|
||||||
int count;
|
int count;
|
||||||
struct acpi_processor_cx states[ACPI_PROCESSOR_MAX_POWER];
|
struct acpi_processor_cx states[ACPI_PROCESSOR_MAX_POWER];
|
||||||
int timer_broadcast_on_state;
|
int timer_broadcast_on_state;
|
||||||
|
|
Loading…
Reference in New Issue