Commit 75eb8f7d authored by Swapnil Patel's avatar Swapnil Patel Committed by Alex Deucher

drm/amd/display: Change default size for dummy plane in DML2

[WHY & HOW]
Currently, to map dc states into dml_display_cfg,
We create a dummy plane if the stream doesn't have any planes
attached to it. This dummy plane uses max addersable width height.
This results in certain mode validations failing when they shouldn't.

Cc: Mario Limonciello <mario.limonciello@amd.com>
Cc: Alex Deucher <alexander.deucher@amd.com>
Cc: stable@vger.kernel.org
Reviewed-by: default avatarChaitanya Dhere <chaitanya.dhere@amd.com>
Acked-by: default avatarAlex Hung <alex.hung@amd.com>
Signed-off-by: default avatarSwapnil Patel <swapnil.patel@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent c6ba60af
...@@ -824,13 +824,25 @@ static struct scaler_data get_scaler_data_for_plane(const struct dc_plane_state ...@@ -824,13 +824,25 @@ static struct scaler_data get_scaler_data_for_plane(const struct dc_plane_state
static void populate_dummy_dml_plane_cfg(struct dml_plane_cfg_st *out, unsigned int location, const struct dc_stream_state *in) static void populate_dummy_dml_plane_cfg(struct dml_plane_cfg_st *out, unsigned int location, const struct dc_stream_state *in)
{ {
dml_uint_t width, height;
if (in->timing.h_addressable > 3840)
width = 3840;
else
width = in->timing.h_addressable; // 4K max
if (in->timing.v_addressable > 2160)
height = 2160;
else
height = in->timing.v_addressable; // 4K max
out->CursorBPP[location] = dml_cur_32bit; out->CursorBPP[location] = dml_cur_32bit;
out->CursorWidth[location] = 256; out->CursorWidth[location] = 256;
out->GPUVMMinPageSizeKBytes[location] = 256; out->GPUVMMinPageSizeKBytes[location] = 256;
out->ViewportWidth[location] = in->timing.h_addressable; out->ViewportWidth[location] = width;
out->ViewportHeight[location] = in->timing.v_addressable; out->ViewportHeight[location] = height;
out->ViewportStationary[location] = false; out->ViewportStationary[location] = false;
out->ViewportWidthChroma[location] = 0; out->ViewportWidthChroma[location] = 0;
out->ViewportHeightChroma[location] = 0; out->ViewportHeightChroma[location] = 0;
...@@ -849,7 +861,7 @@ static void populate_dummy_dml_plane_cfg(struct dml_plane_cfg_st *out, unsigned ...@@ -849,7 +861,7 @@ static void populate_dummy_dml_plane_cfg(struct dml_plane_cfg_st *out, unsigned
out->HTapsChroma[location] = 0; out->HTapsChroma[location] = 0;
out->VTapsChroma[location] = 0; out->VTapsChroma[location] = 0;
out->SourceScan[location] = dml_rotation_0; out->SourceScan[location] = dml_rotation_0;
out->ScalerRecoutWidth[location] = in->timing.h_addressable; out->ScalerRecoutWidth[location] = width;
out->LBBitPerPixel[location] = 57; out->LBBitPerPixel[location] = 57;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment