2  * cpuidle.h - a generic framework for CPU idle power management
 
   4  * (C) 2007 Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
 
   5  *          Shaohua Li <shaohua.li@intel.com>
 
   6  *          Adam Belay <abelay@novell.com>
 
   8  * This code is licenced under the GPL.
 
  11 #ifndef _LINUX_CPUIDLE_H
 
  12 #define _LINUX_CPUIDLE_H
 
  14 #include <linux/percpu.h>
 
  15 #include <linux/list.h>
 
  16 #include <linux/module.h>
 
  17 #include <linux/kobject.h>
 
  18 #include <linux/completion.h>
 
  20 #define CPUIDLE_STATE_MAX       8
 
  21 #define CPUIDLE_NAME_LEN        16
 
  23 struct cpuidle_device;
 
  26 /****************************
 
  27  * CPUIDLE DEVICE INTERFACE *
 
  28  ****************************/
 
  30 struct cpuidle_state {
 
  31         char            name[CPUIDLE_NAME_LEN];
 
  35         unsigned int    exit_latency; /* in US */
 
  36         unsigned int    power_usage; /* in mW */
 
  37         unsigned int    target_residency; /* in US */
 
  40         unsigned int    time; /* in US */
 
  42         int (*enter)    (struct cpuidle_device *dev,
 
  43                          struct cpuidle_state *state);
 
  46 /* Idle State Flags */
 
  47 #define CPUIDLE_FLAG_TIME_VALID (0x01) /* is residency time measurable? */
 
  48 #define CPUIDLE_FLAG_CHECK_BM   (0x02) /* BM activity will exit state */
 
  49 #define CPUIDLE_FLAG_SHALLOW    (0x10) /* low latency, minimal savings */
 
  50 #define CPUIDLE_FLAG_BALANCED   (0x20) /* medium latency, moderate savings */
 
  51 #define CPUIDLE_FLAG_DEEP       (0x40) /* high latency, large savings */
 
  53 #define CPUIDLE_DRIVER_FLAGS_MASK (0xFFFF0000)
 
  56  * cpuidle_get_statedata - retrieves private driver state data
 
  59 static inline void * cpuidle_get_statedata(struct cpuidle_state *state)
 
  61         return state->driver_data;
 
  65  * cpuidle_set_statedata - stores private driver state data
 
  67  * @data: the private data
 
  70 cpuidle_set_statedata(struct cpuidle_state *state, void *data)
 
  72         state->driver_data = data;
 
  75 struct cpuidle_state_kobj {
 
  76         struct cpuidle_state *state;
 
  77         struct completion kobj_unregister;
 
  81 struct cpuidle_device {
 
  87         struct cpuidle_state    states[CPUIDLE_STATE_MAX];
 
  88         struct cpuidle_state_kobj *kobjs[CPUIDLE_STATE_MAX];
 
  89         struct cpuidle_state    *last_state;
 
  91         struct list_head        device_list;
 
  93         struct completion       kobj_unregister;
 
  95         struct cpuidle_state    *safe_state;
 
  98 DECLARE_PER_CPU(struct cpuidle_device *, cpuidle_devices);
 
 101  * cpuidle_get_last_residency - retrieves the last state's residency time
 
 102  * @dev: the target CPU
 
 104  * NOTE: this value is invalid if CPUIDLE_FLAG_TIME_VALID isn't set
 
 106 static inline int cpuidle_get_last_residency(struct cpuidle_device *dev)
 
 108         return dev->last_residency;
 
 112 /****************************
 
 113  * CPUIDLE DRIVER INTERFACE *
 
 114  ****************************/
 
 116 struct cpuidle_driver {
 
 117         char                    name[CPUIDLE_NAME_LEN];
 
 118         struct module           *owner;
 
 121 #ifdef CONFIG_CPU_IDLE
 
 123 extern int cpuidle_register_driver(struct cpuidle_driver *drv);
 
 124 extern void cpuidle_unregister_driver(struct cpuidle_driver *drv);
 
 125 extern int cpuidle_register_device(struct cpuidle_device *dev);
 
 126 extern void cpuidle_unregister_device(struct cpuidle_device *dev);
 
 128 extern void cpuidle_pause_and_lock(void);
 
 129 extern void cpuidle_resume_and_unlock(void);
 
 130 extern int cpuidle_enable_device(struct cpuidle_device *dev);
 
 131 extern void cpuidle_disable_device(struct cpuidle_device *dev);
 
 135 static inline int cpuidle_register_driver(struct cpuidle_driver *drv)
 
 137 static inline void cpuidle_unregister_driver(struct cpuidle_driver *drv) { }
 
 138 static inline int cpuidle_register_device(struct cpuidle_device *dev)
 
 140 static inline void cpuidle_unregister_device(struct cpuidle_device *dev) { }
 
 142 static inline void cpuidle_pause_and_lock(void) { }
 
 143 static inline void cpuidle_resume_and_unlock(void) { }
 
 144 static inline int cpuidle_enable_device(struct cpuidle_device *dev)
 
 146 static inline void cpuidle_disable_device(struct cpuidle_device *dev) { }
 
 150 /******************************
 
 151  * CPUIDLE GOVERNOR INTERFACE *
 
 152  ******************************/
 
 154 struct cpuidle_governor {
 
 155         char                    name[CPUIDLE_NAME_LEN];
 
 156         struct list_head        governor_list;
 
 159         int  (*enable)          (struct cpuidle_device *dev);
 
 160         void (*disable)         (struct cpuidle_device *dev);
 
 162         int  (*select)          (struct cpuidle_device *dev);
 
 163         void (*reflect)         (struct cpuidle_device *dev);
 
 165         struct module           *owner;
 
 168 #ifdef CONFIG_CPU_IDLE
 
 170 extern int cpuidle_register_governor(struct cpuidle_governor *gov);
 
 171 extern void cpuidle_unregister_governor(struct cpuidle_governor *gov);
 
 175 static inline int cpuidle_register_governor(struct cpuidle_governor *gov)
 
 177 static inline void cpuidle_unregister_governor(struct cpuidle_governor *gov) { }
 
 181 #endif /* _LINUX_CPUIDLE_H */