Commit 23882a69 authored by Nikola Cornij's avatar Nikola Cornij Committed by Alex Deucher

drm/amd/display: Make sure DSC slice height is divisible by 2 for 4:2:0 color format

[why] DSC spec requires this
Signed-off-by: default avatarNikola Cornij <nikola.cornij@amd.com>
Reviewed-by: default avatarWenjing Liu <Wenjing.Liu@amd.com>
Acked-by: default avatarBhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent d438d113
......@@ -658,14 +658,23 @@ static bool setup_dsc_config(
dsc_cfg->num_slices_h = num_slices_h;
slice_width = pic_width / num_slices_h;
// Vertical number of slices: start from policy and pick the first one that height is divisible by
// Vertical number of slices: start from policy and pick the first one that height is divisible by.
// For 4:2:0 make sure the slice height is divisible by 2 as well.
pic_height = timing->v_addressable + timing->v_border_top + timing->v_border_bottom;
num_slices_v = dsc_policy.num_slices_v;
if (num_slices_v < 1)
num_slices_v = 1;
while (num_slices_v >= 1 && (pic_height % num_slices_v != 0))
while (num_slices_v >= 1) {
if (timing->pixel_encoding == PIXEL_ENCODING_YCBCR420) {
int slice_height = pic_height / num_slices_v;
if (pic_height % num_slices_v == 0 && slice_height % 2 == 0)
break;
} else if (pic_height % num_slices_v == 0)
break;
num_slices_v--;
}
dsc_cfg->num_slices_v = num_slices_v;
......
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