android_kernel_google_msm/include/linux/idle_stats_device.h
Lynus Vaz 0b74e5a2ad msm: IDLE_TIMER wakes up waiting processes
The msm_idle_stats_update_event() function is now a public function.
In case of IDLE_TIMER expiry, kgsl calls this function to immediately
wake up waiting processes.

Change-Id: Ia259d10e08deea71db047d8091cc97066fba3c1c
Signed-off-by: Lynus Vaz <lvaz@codeaurora.org>
(cherry picked from commit bdb0c07e65cad13deea5d187ad553cc9782c620d)

Conflicts:

	arch/arm/mach-msm/idle_stats_device.c
	drivers/gpu/msm/kgsl_pwrscale_idlestats.c
2013-02-25 11:40:28 -08:00

82 lines
2.4 KiB
C

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