diff options
| author | Joshua Aberback <[email protected]> | 2019-04-01 15:21:24 -0400 | 
|---|---|---|
| committer | Alex Deucher <[email protected]> | 2019-04-15 00:22:19 -0500 | 
| commit | f55be0be5b7296e73f1634e2839a1953dc12d11e (patch) | |
| tree | b37f389fc6c5b6700feeb08329bd2a6c5c1a431b /drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c | |
| parent | afcd526b1ba9dbc5707f9bd8d2d032ae62e337dc (diff) | |
drm/amd/display: Add profiling tools for bandwidth validation
[Why]
We used this change to investigate the performance of bandwidth validation,
it will be useful to have if we need to investigate further.
[How]
We use performance counter tick numbers to profile performance, they live
at dc->debug.bw_val_profile (set .enable in debugger to turn on measuring).
Signed-off-by: Joshua Aberback <[email protected]>
Reviewed-by: Tony Cheng <[email protected]>
Acked-by: Bhawanpreet Lakha <Bhawanpreet [email protected]>
Signed-off-by: Alex Deucher <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c')
| -rw-r--r-- | drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c | 18 | 
1 files changed, 18 insertions, 0 deletions
| diff --git a/drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c b/drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c index d7aece82e4fe..1b4b51657f5e 100644 --- a/drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c +++ b/drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c @@ -704,6 +704,12 @@ bool dcn_validate_bandwidth(  		struct dc_state *context,  		bool fast_validate)  { +	/* +	 * we want a breakdown of the various stages of validation, which the +	 * perf_trace macro doesn't support +	 */ +	BW_VAL_TRACE_SETUP(); +  	const struct resource_pool *pool = dc->res_pool;  	struct dcn_bw_internal_vars *v = &context->dcn_bw_vars;  	int i, input_idx; @@ -712,6 +718,9 @@ bool dcn_validate_bandwidth(  	float bw_limit;  	PERFORMANCE_TRACE_START(); + +	BW_VAL_TRACE_COUNT(); +  	if (dcn_bw_apply_registry_override(dc))  		dcn_bw_sync_calcs_and_dml(dc); @@ -1014,6 +1023,8 @@ bool dcn_validate_bandwidth(  		mode_support_and_system_configuration(v);  	} +	BW_VAL_TRACE_END_VOLTAGE_LEVEL(); +  	if (v->voltage_level != number_of_states_plus_one && !fast_validate) {  		float bw_consumed = v->total_bandwidth_consumed_gbyte_per_second; @@ -1089,6 +1100,8 @@ bool dcn_validate_bandwidth(  			break;  		} +		BW_VAL_TRACE_END_WATERMARKS(); +  		for (i = 0, input_idx = 0; i < pool->pipe_count; i++) {  			struct pipe_ctx *pipe = &context->res_ctx.pipe_ctx[i]; @@ -1179,6 +1192,10 @@ bool dcn_validate_bandwidth(  			input_idx++;  		} +	} else if (v->voltage_level == number_of_states_plus_one) { +		BW_VAL_TRACE_SKIP(fail); +	} else if (fast_validate) { +		BW_VAL_TRACE_SKIP(fast);  	}  	if (v->voltage_level == 0) { @@ -1198,6 +1215,7 @@ bool dcn_validate_bandwidth(  	kernel_fpu_end();  	PERFORMANCE_TRACE_END(); +	BW_VAL_TRACE_FINISH();  	if (bw_limit_pass && v->voltage_level != 5)  		return true; |