mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/amd/display: remove DC_FP_* wrapper from dml folder
FPU documentation states that developers must not use DC_FP_START/END inside dml files, but use this macro to wrap calls to FPU functions in dc folder (outside dml folder). Therefore, this patch removes DC_FP_* wrappers from dml folder and wraps calls for these FPU operations outside dml, as required. Acked-by: Christian König <christian.koenig@amd.com> Reviewed-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Signed-off-by: Melissa Wen <mwen@igalia.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
		
							parent
							
								
									851c5f242a
								
							
						
					
					
						commit
						9696679bf7
					
				| @ -2983,8 +2983,11 @@ void dcn10_prepare_bandwidth( | |||||||
| 			true); | 			true); | ||||||
| 	dcn10_stereo_hw_frame_pack_wa(dc, context); | 	dcn10_stereo_hw_frame_pack_wa(dc, context); | ||||||
| 
 | 
 | ||||||
| 	if (dc->debug.pplib_wm_report_mode == WM_REPORT_OVERRIDE) | 	if (dc->debug.pplib_wm_report_mode == WM_REPORT_OVERRIDE) { | ||||||
|  | 		DC_FP_START(); | ||||||
| 		dcn_bw_notify_pplib_of_wm_ranges(dc); | 		dcn_bw_notify_pplib_of_wm_ranges(dc); | ||||||
|  | 		DC_FP_END(); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (dc->debug.sanity_checks) | 	if (dc->debug.sanity_checks) | ||||||
| 		hws->funcs.verify_allow_pstate_change_high(dc); | 		hws->funcs.verify_allow_pstate_change_high(dc); | ||||||
| @ -3017,8 +3020,11 @@ void dcn10_optimize_bandwidth( | |||||||
| 
 | 
 | ||||||
| 	dcn10_stereo_hw_frame_pack_wa(dc, context); | 	dcn10_stereo_hw_frame_pack_wa(dc, context); | ||||||
| 
 | 
 | ||||||
| 	if (dc->debug.pplib_wm_report_mode == WM_REPORT_OVERRIDE) | 	if (dc->debug.pplib_wm_report_mode == WM_REPORT_OVERRIDE) { | ||||||
|  | 		DC_FP_START(); | ||||||
| 		dcn_bw_notify_pplib_of_wm_ranges(dc); | 		dcn_bw_notify_pplib_of_wm_ranges(dc); | ||||||
|  | 		DC_FP_END(); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (dc->debug.sanity_checks) | 	if (dc->debug.sanity_checks) | ||||||
| 		hws->funcs.verify_allow_pstate_change_high(dc); | 		hws->funcs.verify_allow_pstate_change_high(dc); | ||||||
|  | |||||||
| @ -1506,6 +1506,7 @@ static bool dcn10_resource_construct( | |||||||
| 			&& pool->base.pp_smu->rv_funcs.set_pme_wa_enable != NULL) | 			&& pool->base.pp_smu->rv_funcs.set_pme_wa_enable != NULL) | ||||||
| 		dc->debug.az_endpoint_mute_only = false; | 		dc->debug.az_endpoint_mute_only = false; | ||||||
| 
 | 
 | ||||||
|  | 	DC_FP_START(); | ||||||
| 	if (!dc->debug.disable_pplib_clock_request) | 	if (!dc->debug.disable_pplib_clock_request) | ||||||
| 		dcn_bw_update_from_pplib(dc); | 		dcn_bw_update_from_pplib(dc); | ||||||
| 	dcn_bw_sync_calcs_and_dml(dc); | 	dcn_bw_sync_calcs_and_dml(dc); | ||||||
| @ -1513,6 +1514,7 @@ static bool dcn10_resource_construct( | |||||||
| 		dc->res_pool = &pool->base; | 		dc->res_pool = &pool->base; | ||||||
| 		dcn_bw_notify_pplib_of_wm_ranges(dc); | 		dcn_bw_notify_pplib_of_wm_ranges(dc); | ||||||
| 	} | 	} | ||||||
|  | 	DC_FP_END(); | ||||||
| 
 | 
 | ||||||
| 	{ | 	{ | ||||||
| 		struct irq_service_init_data init_data; | 		struct irq_service_init_data init_data; | ||||||
|  | |||||||
| @ -639,7 +639,6 @@ static bool dcn_bw_apply_registry_override(struct dc *dc) | |||||||
| { | { | ||||||
| 	bool updated = false; | 	bool updated = false; | ||||||
| 
 | 
 | ||||||
| 	DC_FP_START(); |  | ||||||
| 	if ((int)(dc->dcn_soc->sr_exit_time * 1000) != dc->debug.sr_exit_time_ns | 	if ((int)(dc->dcn_soc->sr_exit_time * 1000) != dc->debug.sr_exit_time_ns | ||||||
| 			&& dc->debug.sr_exit_time_ns) { | 			&& dc->debug.sr_exit_time_ns) { | ||||||
| 		updated = true; | 		updated = true; | ||||||
| @ -675,7 +674,6 @@ static bool dcn_bw_apply_registry_override(struct dc *dc) | |||||||
| 		dc->dcn_soc->dram_clock_change_latency = | 		dc->dcn_soc->dram_clock_change_latency = | ||||||
| 				dc->debug.dram_clock_change_latency_ns / 1000.0; | 				dc->debug.dram_clock_change_latency_ns / 1000.0; | ||||||
| 	} | 	} | ||||||
| 	DC_FP_END(); |  | ||||||
| 
 | 
 | ||||||
| 	return updated; | 	return updated; | ||||||
| } | } | ||||||
| @ -1492,8 +1490,6 @@ void dcn_bw_update_from_pplib(struct dc *dc) | |||||||
| 	res = dm_pp_get_clock_levels_by_type_with_voltage( | 	res = dm_pp_get_clock_levels_by_type_with_voltage( | ||||||
| 			ctx, DM_PP_CLOCK_TYPE_FCLK, &fclks); | 			ctx, DM_PP_CLOCK_TYPE_FCLK, &fclks); | ||||||
| 
 | 
 | ||||||
| 	DC_FP_START(); |  | ||||||
| 
 |  | ||||||
| 	if (res) | 	if (res) | ||||||
| 		res = verify_clock_values(&fclks); | 		res = verify_clock_values(&fclks); | ||||||
| 
 | 
 | ||||||
| @ -1523,13 +1519,9 @@ void dcn_bw_update_from_pplib(struct dc *dc) | |||||||
| 	} else | 	} else | ||||||
| 		BREAK_TO_DEBUGGER(); | 		BREAK_TO_DEBUGGER(); | ||||||
| 
 | 
 | ||||||
| 	DC_FP_END(); |  | ||||||
| 
 |  | ||||||
| 	res = dm_pp_get_clock_levels_by_type_with_voltage( | 	res = dm_pp_get_clock_levels_by_type_with_voltage( | ||||||
| 			ctx, DM_PP_CLOCK_TYPE_DCFCLK, &dcfclks); | 			ctx, DM_PP_CLOCK_TYPE_DCFCLK, &dcfclks); | ||||||
| 
 | 
 | ||||||
| 	DC_FP_START(); |  | ||||||
| 
 |  | ||||||
| 	if (res) | 	if (res) | ||||||
| 		res = verify_clock_values(&dcfclks); | 		res = verify_clock_values(&dcfclks); | ||||||
| 
 | 
 | ||||||
| @ -1540,8 +1532,6 @@ void dcn_bw_update_from_pplib(struct dc *dc) | |||||||
| 		dc->dcn_soc->dcfclkv_max0p9 = dcfclks.data[dcfclks.num_levels - 1].clocks_in_khz / 1000.0; | 		dc->dcn_soc->dcfclkv_max0p9 = dcfclks.data[dcfclks.num_levels - 1].clocks_in_khz / 1000.0; | ||||||
| 	} else | 	} else | ||||||
| 		BREAK_TO_DEBUGGER(); | 		BREAK_TO_DEBUGGER(); | ||||||
| 
 |  | ||||||
| 	DC_FP_END(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void dcn_bw_notify_pplib_of_wm_ranges(struct dc *dc) | void dcn_bw_notify_pplib_of_wm_ranges(struct dc *dc) | ||||||
| @ -1556,11 +1546,9 @@ void dcn_bw_notify_pplib_of_wm_ranges(struct dc *dc) | |||||||
| 	if (!pp || !pp->set_wm_ranges) | 	if (!pp || !pp->set_wm_ranges) | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	DC_FP_START(); |  | ||||||
| 	min_fclk_khz = dc->dcn_soc->fabric_and_dram_bandwidth_vmin0p65 * 1000000 / 32; | 	min_fclk_khz = dc->dcn_soc->fabric_and_dram_bandwidth_vmin0p65 * 1000000 / 32; | ||||||
| 	min_dcfclk_khz = dc->dcn_soc->dcfclkv_min0p65 * 1000; | 	min_dcfclk_khz = dc->dcn_soc->dcfclkv_min0p65 * 1000; | ||||||
| 	socclk_khz = dc->dcn_soc->socclk * 1000; | 	socclk_khz = dc->dcn_soc->socclk * 1000; | ||||||
| 	DC_FP_END(); |  | ||||||
| 
 | 
 | ||||||
| 	/* Now notify PPLib/SMU about which Watermarks sets they should select
 | 	/* Now notify PPLib/SMU about which Watermarks sets they should select
 | ||||||
| 	 * depending on DPM state they are in. And update BW MGR GFX Engine and | 	 * depending on DPM state they are in. And update BW MGR GFX Engine and | ||||||
| @ -1611,7 +1599,6 @@ void dcn_bw_notify_pplib_of_wm_ranges(struct dc *dc) | |||||||
| 
 | 
 | ||||||
| void dcn_bw_sync_calcs_and_dml(struct dc *dc) | void dcn_bw_sync_calcs_and_dml(struct dc *dc) | ||||||
| { | { | ||||||
| 	DC_FP_START(); |  | ||||||
| 	DC_LOG_BANDWIDTH_CALCS("sr_exit_time: %f ns\n" | 	DC_LOG_BANDWIDTH_CALCS("sr_exit_time: %f ns\n" | ||||||
| 			"sr_enter_plus_exit_time: %f ns\n" | 			"sr_enter_plus_exit_time: %f ns\n" | ||||||
| 			"urgent_latency: %f ns\n" | 			"urgent_latency: %f ns\n" | ||||||
| @ -1800,5 +1787,4 @@ void dcn_bw_sync_calcs_and_dml(struct dc *dc) | |||||||
| 	dc->dml.ip.bug_forcing_LC_req_same_size_fixed = | 	dc->dml.ip.bug_forcing_LC_req_same_size_fixed = | ||||||
| 		dc->dcn_ip->bug_forcing_luma_and_chroma_request_to_same_size_fixed == dcn_bw_yes; | 		dc->dcn_ip->bug_forcing_luma_and_chroma_request_to_same_size_fixed == dcn_bw_yes; | ||||||
| 	dc->dml.ip.dcfclk_cstate_latency = dc->dcn_ip->dcfclk_cstate_latency; | 	dc->dml.ip.dcfclk_cstate_latency = dc->dcn_ip->dcfclk_cstate_latency; | ||||||
| 	DC_FP_END(); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -1302,9 +1302,7 @@ int dcn20_populate_dml_pipes_from_context( | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* populate writeback information */ | 	/* populate writeback information */ | ||||||
| 	DC_FP_START(); |  | ||||||
| 	dc->res_pool->funcs->populate_dml_writeback_from_context(dc, res_ctx, pipes); | 	dc->res_pool->funcs->populate_dml_writeback_from_context(dc, res_ctx, pipes); | ||||||
| 	DC_FP_END(); |  | ||||||
| 
 | 
 | ||||||
| 	return pipe_cnt; | 	return pipe_cnt; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Melissa Wen
						Melissa Wen