| #ifndef __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H |
| #define __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H |
| |
| #include <linux/types.h> |
| #include <linux/ioctl.h> |
| |
| #define MSM_IDLE_STATS_EVENT_NONE 0 |
| #define MSM_IDLE_STATS_EVENT_BUSY_TIMER_EXPIRED 1 |
| #define MSM_IDLE_STATS_EVENT_BUSY_TIMER_EXPIRED_RESET 2 |
| #define MSM_IDLE_STATS_EVENT_COLLECTION_NEARLY_FULL 4 |
| #define MSM_IDLE_STATS_EVENT_COLLECTION_FULL 8 |
| #define MSM_IDLE_STATS_EVENT_IDLE_TIMER_EXPIRED 16 |
| |
| /* |
| * All time, timer, and time interval values are in units of |
| * microseconds unless stated otherwise. |
| */ |
| #define MSM_IDLE_STATS_NR_MAX_INTERVALS 200 |
| |
| struct msm_idle_pulse { |
| __s64 busy_start_time; |
| __u32 busy_interval; |
| __u32 wait_interval; |
| }; |
| |
| struct msm_idle_read_stats { |
| __u32 event; |
| __s64 return_timestamp; |
| __u32 busy_timer_remaining; |
| __u32 nr_collected; |
| struct msm_idle_pulse pulse_chain[MSM_IDLE_STATS_NR_MAX_INTERVALS]; |
| }; |
| |
| struct msm_idle_write_stats { |
| __u32 busy_timer; |
| __u32 next_busy_timer; |
| __u32 max_samples; |
| }; |
| |
| #define MSM_IDLE_STATS_IOC_MAGIC 0xD8 |
| #define MSM_IDLE_STATS_IOC_READ_STATS \ |
| _IOWR(MSM_IDLE_STATS_IOC_MAGIC, 1, struct msm_idle_read_stats) |
| #define MSM_IDLE_STATS_IOC_WRITE_STATS \ |
| _IOWR(MSM_IDLE_STATS_IOC_MAGIC, 2, struct msm_idle_write_stats) |
| |
| #ifdef __KERNEL__ |
| #include <linux/hrtimer.h> |
| #include <linux/mutex.h> |
| #include <linux/miscdevice.h> |
| |
| struct msm_idle_stats_device { |
| const char *name; |
| void (*get_sample)(struct msm_idle_stats_device *device, |
| struct msm_idle_pulse *pulse); |
| |
| struct miscdevice miscdev; |
| spinlock_t lock; |
| wait_queue_head_t wait; |
| struct list_head list; |
| struct hrtimer busy_timer; |
| ktime_t busy_timer_interval; |
| ktime_t idle_start; |
| ktime_t remaining_time; |
| __u32 max_samples; |
| |
| struct msm_idle_read_stats *stats; |
| struct msm_idle_read_stats stats_vector[2]; |
| }; |
| |
| int msm_idle_stats_register_device(struct msm_idle_stats_device *device); |
| int msm_idle_stats_deregister_device(struct msm_idle_stats_device *device); |
| void msm_idle_stats_prepare_idle_start(struct msm_idle_stats_device *device); |
| void msm_idle_stats_abort_idle_start(struct msm_idle_stats_device *device); |
| void msm_idle_stats_idle_start(struct msm_idle_stats_device *device); |
| void msm_idle_stats_idle_end(struct msm_idle_stats_device *device, |
| struct msm_idle_pulse *pulse); |
| void msm_idle_stats_update_event(struct msm_idle_stats_device *device, |
| __u32 event); |
| #endif |
| |
| #endif /* __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H */ |
| |