|  |  | 
|  |  | 
|  | Supporting multiple CPU idle levels in kernel | 
|  |  | 
|  | cpuidle drivers | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | cpuidle driver hooks into the cpuidle infrastructure and handles the | 
|  | architecture/platform dependent part of CPU idle states. Driver | 
|  | provides the platform idle state detection capability and also | 
|  | has mechanisms in place to support actual entry-exit into CPU idle states. | 
|  |  | 
|  | cpuidle driver initializes the cpuidle_device structure for each CPU device | 
|  | and registers with cpuidle using cpuidle_register_device. | 
|  |  | 
|  | If all the idle states are the same, the wrapper function cpuidle_register | 
|  | could be used instead. | 
|  |  | 
|  | It can also support the dynamic changes (like battery <-> AC), by using | 
|  | cpuidle_pause_and_lock, cpuidle_disable_device and cpuidle_enable_device, | 
|  | cpuidle_resume_and_unlock. | 
|  |  | 
|  | Interfaces: | 
|  | extern int cpuidle_register(struct cpuidle_driver *drv, | 
|  | const struct cpumask *const coupled_cpus); | 
|  | extern int cpuidle_unregister(struct cpuidle_driver *drv); | 
|  | extern int cpuidle_register_driver(struct cpuidle_driver *drv); | 
|  | extern void cpuidle_unregister_driver(struct cpuidle_driver *drv); | 
|  | extern int cpuidle_register_device(struct cpuidle_device *dev); | 
|  | extern void cpuidle_unregister_device(struct cpuidle_device *dev); | 
|  |  | 
|  | extern void cpuidle_pause_and_lock(void); | 
|  | extern void cpuidle_resume_and_unlock(void); | 
|  | extern int cpuidle_enable_device(struct cpuidle_device *dev); | 
|  | extern void cpuidle_disable_device(struct cpuidle_device *dev); |