1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- #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 */
|