forked from luck/tmp_suning_uos_patched
b82b6cca48
The only place where the time is invalid is when the ACPI_CSTATE_FFH entry method is not set. Otherwise for all the drivers, the time can be correctly measured. Instead of duplicating the CPUIDLE_FLAG_TIME_VALID flag in all the drivers for all the states, just invert the logic by replacing it by the flag CPUIDLE_FLAG_TIME_INVALID, hence we can set this flag only for the acpi idle driver, remove the former flag from all the drivers and invert the logic with this flag in the different governor. Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
30 lines
650 B
C
30 lines
650 B
C
#ifndef __ASM_IDLE_H
|
|
#define __ASM_IDLE_H
|
|
|
|
#include <linux/cpuidle.h>
|
|
#include <linux/linkage.h>
|
|
|
|
extern void (*cpu_wait)(void);
|
|
extern void r4k_wait(void);
|
|
extern asmlinkage void __r4k_wait(void);
|
|
extern void r4k_wait_irqoff(void);
|
|
|
|
static inline int using_rollback_handler(void)
|
|
{
|
|
return cpu_wait == r4k_wait;
|
|
}
|
|
|
|
extern int mips_cpuidle_wait_enter(struct cpuidle_device *dev,
|
|
struct cpuidle_driver *drv, int index);
|
|
|
|
#define MIPS_CPUIDLE_WAIT_STATE {\
|
|
.enter = mips_cpuidle_wait_enter,\
|
|
.exit_latency = 1,\
|
|
.target_residency = 1,\
|
|
.power_usage = UINT_MAX,\
|
|
.name = "wait",\
|
|
.desc = "MIPS wait",\
|
|
}
|
|
|
|
#endif /* __ASM_IDLE_H */
|