blob: cd613af16aa2d9e0e7ee81dd5c7f7123c7908f47 [file] [log] [blame]
Lucille Sylvester20ec38a2011-09-14 10:51:28 -06001#ifndef __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H
2#define __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H
3
4#include <linux/types.h>
5#include <linux/ioctl.h>
6
7#define MSM_IDLE_STATS_EVENT_NONE 0
8#define MSM_IDLE_STATS_EVENT_BUSY_TIMER_EXPIRED 1
9#define MSM_IDLE_STATS_EVENT_BUSY_TIMER_EXPIRED_RESET 2
10#define MSM_IDLE_STATS_EVENT_COLLECTION_NEARLY_FULL 4
11#define MSM_IDLE_STATS_EVENT_COLLECTION_FULL 8
Lucille Sylvester3b46d002011-10-04 16:26:38 -060012#define MSM_IDLE_STATS_EVENT_IDLE_TIMER_EXPIRED 16
Lucille Sylvester20ec38a2011-09-14 10:51:28 -060013
14/*
15 * All time, timer, and time interval values are in units of
16 * microseconds unless stated otherwise.
17 */
18#define MSM_IDLE_STATS_NR_MAX_INTERVALS 200
19
20struct msm_idle_pulse {
21 __s64 busy_start_time;
22 __u32 busy_interval;
23 __u32 wait_interval;
24};
25
26struct msm_idle_read_stats {
27 __u32 event;
28 __s64 return_timestamp;
29 __u32 busy_timer_remaining;
30 __u32 nr_collected;
31 struct msm_idle_pulse pulse_chain[MSM_IDLE_STATS_NR_MAX_INTERVALS];
32};
33
34struct msm_idle_write_stats {
35 __u32 busy_timer;
36 __u32 next_busy_timer;
Lynus Vazfdecd1e2012-01-17 15:45:49 +053037 __u32 max_samples;
Lucille Sylvester20ec38a2011-09-14 10:51:28 -060038};
39
40#define MSM_IDLE_STATS_IOC_MAGIC 0xD8
41#define MSM_IDLE_STATS_IOC_READ_STATS \
42 _IOWR(MSM_IDLE_STATS_IOC_MAGIC, 1, struct msm_idle_read_stats)
43#define MSM_IDLE_STATS_IOC_WRITE_STATS \
44 _IOWR(MSM_IDLE_STATS_IOC_MAGIC, 2, struct msm_idle_write_stats)
45
46#ifdef __KERNEL__
47#include <linux/hrtimer.h>
48#include <linux/mutex.h>
49#include <linux/miscdevice.h>
50
51struct msm_idle_stats_device {
52 const char *name;
53 void (*get_sample)(struct msm_idle_stats_device *device,
54 struct msm_idle_pulse *pulse);
55
56 struct miscdevice miscdev;
57 spinlock_t lock;
58 wait_queue_head_t wait;
59 struct list_head list;
60 struct hrtimer busy_timer;
61 ktime_t busy_timer_interval;
62 ktime_t idle_start;
63 ktime_t remaining_time;
Lynus Vazfdecd1e2012-01-17 15:45:49 +053064 __u32 max_samples;
Lucille Sylvester20ec38a2011-09-14 10:51:28 -060065
66 struct msm_idle_read_stats *stats;
67 struct msm_idle_read_stats stats_vector[2];
68};
69
70int msm_idle_stats_register_device(struct msm_idle_stats_device *device);
71int msm_idle_stats_deregister_device(struct msm_idle_stats_device *device);
72void msm_idle_stats_prepare_idle_start(struct msm_idle_stats_device *device);
73void msm_idle_stats_abort_idle_start(struct msm_idle_stats_device *device);
74void msm_idle_stats_idle_start(struct msm_idle_stats_device *device);
75void msm_idle_stats_idle_end(struct msm_idle_stats_device *device,
76 struct msm_idle_pulse *pulse);
Lynus Vazbdb0c072011-11-14 16:55:04 +053077void msm_idle_stats_update_event(struct msm_idle_stats_device *device,
78 __u32 event);
Lucille Sylvester20ec38a2011-09-14 10:51:28 -060079#endif
80
81#endif /* __ARCH_ARM_MACH_MSM_IDLE_STATS_DEVICE_H */
82