diff options
Diffstat (limited to 'drivers/gpu/drm/msm/msm_gpu.c')
| -rw-r--r-- | drivers/gpu/drm/msm/msm_gpu.c | 21 | 
1 files changed, 19 insertions, 2 deletions
diff --git a/drivers/gpu/drm/msm/msm_gpu.c b/drivers/gpu/drm/msm/msm_gpu.c index c8cd9bfa3eeb..484346daa05f 100644 --- a/drivers/gpu/drm/msm/msm_gpu.c +++ b/drivers/gpu/drm/msm/msm_gpu.c @@ -4,6 +4,8 @@   * Author: Rob Clark <[email protected]>   */ +#include "drm/drm_drv.h" +  #include "msm_gpu.h"  #include "msm_gem.h"  #include "msm_mmu.h" @@ -146,6 +148,16 @@ int msm_gpu_pm_suspend(struct msm_gpu *gpu)  	return 0;  } +void msm_gpu_show_fdinfo(struct msm_gpu *gpu, struct msm_file_private *ctx, +			 struct drm_printer *p) +{ +	drm_printf(p, "drm-driver:\t%s\n", gpu->dev->driver->name); +	drm_printf(p, "drm-client-id:\t%u\n", ctx->seqno); +	drm_printf(p, "drm-engine-gpu:\t%llu ns\n", ctx->elapsed_ns); +	drm_printf(p, "drm-cycles-gpu:\t%llu\n", ctx->cycles); +	drm_printf(p, "drm-maxfreq-gpu:\t%u Hz\n", gpu->fast_rate); +} +  int msm_gpu_hw_init(struct msm_gpu *gpu)  {  	int ret; @@ -634,7 +646,7 @@ static void retire_submit(struct msm_gpu *gpu, struct msm_ringbuffer *ring,  {  	int index = submit->seqno % MSM_GPU_SUBMIT_STATS_COUNT;  	volatile struct msm_gpu_submit_stats *stats; -	u64 elapsed, clock = 0; +	u64 elapsed, clock = 0, cycles;  	unsigned long flags;  	stats = &ring->memptrs->stats[index]; @@ -642,12 +654,17 @@ static void retire_submit(struct msm_gpu *gpu, struct msm_ringbuffer *ring,  	elapsed = (stats->alwayson_end - stats->alwayson_start) * 10000;  	do_div(elapsed, 192); +	cycles = stats->cpcycles_end - stats->cpcycles_start; +  	/* Calculate the clock frequency from the number of CP cycles */  	if (elapsed) { -		clock = (stats->cpcycles_end - stats->cpcycles_start) * 1000; +		clock = cycles * 1000;  		do_div(clock, elapsed);  	} +	submit->queue->ctx->elapsed_ns += elapsed; +	submit->queue->ctx->cycles     += cycles; +  	trace_msm_gpu_submit_retired(submit, elapsed, clock,  		stats->alwayson_start, stats->alwayson_end);  |