diff options
Diffstat (limited to 'drivers/gpu/drm/msm/msm_gpu.h')
| -rw-r--r-- | drivers/gpu/drm/msm/msm_gpu.h | 25 | 
1 files changed, 16 insertions, 9 deletions
| diff --git a/drivers/gpu/drm/msm/msm_gpu.h b/drivers/gpu/drm/msm/msm_gpu.h index 02419f2ca2bc..6def00883046 100644 --- a/drivers/gpu/drm/msm/msm_gpu.h +++ b/drivers/gpu/drm/msm/msm_gpu.h @@ -9,6 +9,7 @@  #include <linux/adreno-smmu-priv.h>  #include <linux/clk.h> +#include <linux/devfreq.h>  #include <linux/interconnect.h>  #include <linux/pm_opp.h>  #include <linux/regulator/consumer.h> @@ -21,6 +22,7 @@  struct msm_gem_submit;  struct msm_gpu_perfcntr;  struct msm_gpu_state; +struct msm_file_private;  struct msm_gpu_config {  	const char *ioname; @@ -43,9 +45,9 @@ struct msm_gpu_config {   */  struct msm_gpu_funcs {  	int (*get_param)(struct msm_gpu *gpu, struct msm_file_private *ctx, -			 uint32_t param, uint64_t *value); +			 uint32_t param, uint64_t *value, uint32_t *len);  	int (*set_param)(struct msm_gpu *gpu, struct msm_file_private *ctx, -			 uint32_t param, uint64_t value); +			 uint32_t param, uint64_t value, uint32_t len);  	int (*hw_init)(struct msm_gpu *gpu);  	int (*pm_suspend)(struct msm_gpu *gpu);  	int (*pm_resume)(struct msm_gpu *gpu); @@ -62,7 +64,7 @@ struct msm_gpu_funcs {  	/* for generation specific debugfs: */  	void (*debugfs_init)(struct msm_gpu *gpu, struct drm_minor *minor);  #endif -	unsigned long (*gpu_busy)(struct msm_gpu *gpu); +	u64 (*gpu_busy)(struct msm_gpu *gpu, unsigned long *out_sample_rate);  	struct msm_gpu_state *(*gpu_state_get)(struct msm_gpu *gpu);  	int (*gpu_state_put)(struct msm_gpu_state *state);  	unsigned long (*gpu_get_freq)(struct msm_gpu *gpu); @@ -106,11 +108,8 @@ struct msm_gpu_devfreq {  	struct dev_pm_qos_request boost_freq;  	/** -	 * busy_cycles: -	 * -	 * Used by implementation of gpu->gpu_busy() to track the last -	 * busy counter value, for calculating elapsed busy cycles since -	 * last sampling period. +	 * busy_cycles: Last busy counter value, for calculating elapsed busy +	 * cycles since last sampling period.  	 */  	u64 busy_cycles; @@ -120,6 +119,8 @@ struct msm_gpu_devfreq {  	/** idle_time: Time of last transition to idle: */  	ktime_t idle_time; +	struct devfreq_dev_status average_status; +  	/**  	 * idle_work:  	 * @@ -290,7 +291,7 @@ static inline bool msm_gpu_active(struct msm_gpu *gpu)  	for (i = 0; i < gpu->nr_rings; i++) {  		struct msm_ringbuffer *ring = gpu->rb[i]; -		if (fence_after(ring->seqno, ring->memptrs->fence)) +		if (fence_after(ring->fctx->last_fence, ring->memptrs->fence))  			return true;  	} @@ -354,6 +355,12 @@ struct msm_file_private {  	 */  	int sysprof; +	/** comm: Overridden task comm, see MSM_PARAM_COMM */ +	char *comm; + +	/** cmdline: Overridden task cmdline, see MSM_PARAM_CMDLINE */ +	char *cmdline; +  	/**  	 * entities:  	 * | 
