Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3549130e authored by Harry Wentland's avatar Harry Wentland Committed by Alex Deucher
Browse files

drm/amd/display: Call update_stream_signal directly from amdgpu_dm



There's no good place in DC to cover all place where stream signal should
be updated. update_stream_signal depends on timing which comes from DM.

Signed-off-by: default avatarHarry Wentland <harry.wentland@amd.com>
Reviewed-by: default avatarTony Cheng <Tony.Cheng@amd.com>
Acked-by: default avatarHarry Wentland <harry.wentland@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 52f401f9
Loading
Loading
Loading
Loading
+3 −0
Original line number Original line Diff line number Diff line
@@ -2418,6 +2418,7 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
				dm_state ? (dm_state->scaling != RMX_OFF) : false);
				dm_state ? (dm_state->scaling != RMX_OFF) : false);
	}
	}


	drm_mode_set_crtcinfo(&mode, 0);
	fill_stream_properties_from_drm_display_mode(stream,
	fill_stream_properties_from_drm_display_mode(stream,
			&mode, &aconnector->base);
			&mode, &aconnector->base);
	update_stream_scaling_settings(&mode, dm_state, stream);
	update_stream_scaling_settings(&mode, dm_state, stream);
@@ -2427,6 +2428,8 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
		drm_connector,
		drm_connector,
		aconnector->dc_sink);
		aconnector->dc_sink);


	update_stream_signal(stream);

	return stream;
	return stream;
}
}


+1 −1
Original line number Original line Diff line number Diff line
@@ -33,7 +33,7 @@
/*******************************************************************************
/*******************************************************************************
 * Private functions
 * Private functions
 ******************************************************************************/
 ******************************************************************************/
static void update_stream_signal(struct dc_stream_state *stream)
void update_stream_signal(struct dc_stream_state *stream)
{
{


	struct dc_sink *dc_sink = stream->sink;
	struct dc_sink *dc_sink = stream->sink;
+2 −0
Original line number Original line Diff line number Diff line
@@ -237,6 +237,8 @@ enum surface_update_type dc_check_update_surfaces_for_stream(
 */
 */
struct dc_stream_state *dc_create_stream_for_sink(struct dc_sink *dc_sink);
struct dc_stream_state *dc_create_stream_for_sink(struct dc_sink *dc_sink);


void update_stream_signal(struct dc_stream_state *stream);

void dc_stream_retain(struct dc_stream_state *dc_stream);
void dc_stream_retain(struct dc_stream_state *dc_stream);
void dc_stream_release(struct dc_stream_state *dc_stream);
void dc_stream_release(struct dc_stream_state *dc_stream);