2013-05-21 21:59:19 +07:00
|
|
|
#ifndef __ASM_IDLE_H
|
|
|
|
#define __ASM_IDLE_H
|
|
|
|
|
2014-04-14 22:16:41 +07:00
|
|
|
#include <linux/cpuidle.h>
|
2013-05-21 21:59:19 +07:00
|
|
|
#include <linux/linkage.h>
|
|
|
|
|
|
|
|
extern void (*cpu_wait)(void);
|
2013-05-21 22:33:32 +07:00
|
|
|
extern void r4k_wait(void);
|
|
|
|
extern asmlinkage void __r4k_wait(void);
|
2013-05-21 21:59:19 +07:00
|
|
|
extern void r4k_wait_irqoff(void);
|
|
|
|
extern void __pastwait(void);
|
|
|
|
|
2013-05-21 22:30:36 +07:00
|
|
|
static inline int using_rollback_handler(void)
|
|
|
|
{
|
|
|
|
return cpu_wait == r4k_wait;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int address_is_in_r4k_wait_irqoff(unsigned long addr)
|
|
|
|
{
|
|
|
|
return addr >= (unsigned long)r4k_wait_irqoff &&
|
|
|
|
addr < (unsigned long)__pastwait;
|
|
|
|
}
|
|
|
|
|
2014-04-14 22:16:41 +07:00
|
|
|
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,\
|
|
|
|
.flags = CPUIDLE_FLAG_TIME_VALID,\
|
|
|
|
.name = "wait",\
|
|
|
|
.desc = "MIPS wait",\
|
|
|
|
}
|
|
|
|
|
2013-05-21 21:59:19 +07:00
|
|
|
#endif /* __ASM_IDLE_H */
|