blob: d9f932de80e926f3701e4a63166e48f37ac89f8f [file] [log] [blame]
Ralf Baechlebdc92d742013-05-21 16:59:19 +02001#ifndef __ASM_IDLE_H
2#define __ASM_IDLE_H
3
Paul Burtonda9f9702014-04-14 16:16:41 +01004#include <linux/cpuidle.h>
Ralf Baechlebdc92d742013-05-21 16:59:19 +02005#include <linux/linkage.h>
6
7extern void (*cpu_wait)(void);
Ralf Baechle087d9902013-05-21 17:33:32 +02008extern void r4k_wait(void);
9extern asmlinkage void __r4k_wait(void);
Ralf Baechlebdc92d742013-05-21 16:59:19 +020010extern void r4k_wait_irqoff(void);
11extern void __pastwait(void);
12
Ralf Baechlef94d9a82013-05-21 17:30:36 +020013static inline int using_rollback_handler(void)
14{
15 return cpu_wait == r4k_wait;
16}
17
18static inline int address_is_in_r4k_wait_irqoff(unsigned long addr)
19{
20 return addr >= (unsigned long)r4k_wait_irqoff &&
21 addr < (unsigned long)__pastwait;
22}
23
Paul Burtonda9f9702014-04-14 16:16:41 +010024extern int mips_cpuidle_wait_enter(struct cpuidle_device *dev,
25 struct cpuidle_driver *drv, int index);
26
27#define MIPS_CPUIDLE_WAIT_STATE {\
28 .enter = mips_cpuidle_wait_enter,\
29 .exit_latency = 1,\
30 .target_residency = 1,\
31 .power_usage = UINT_MAX,\
32 .flags = CPUIDLE_FLAG_TIME_VALID,\
33 .name = "wait",\
34 .desc = "MIPS wait",\
35}
36
Ralf Baechlebdc92d742013-05-21 16:59:19 +020037#endif /* __ASM_IDLE_H */