aboutsummaryrefslogtreecommitdiffstats
path: root/common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch')
-rw-r--r--common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch90
1 files changed, 90 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch b/common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch
new file mode 100644
index 00000000..4e2afab8
--- /dev/null
+++ b/common/recipes-kernel/linux/linux-yocto-4.14.71/4714-drm-amd-display-add-a-check-for-display-depth-validi.patch
@@ -0,0 +1,90 @@
+From 7456cb4d8d7f538b679b05dfa0ee7a5975d9d404 Mon Sep 17 00:00:00 2001
+From: Mikita Lipski <mikita.lipski@amd.com>
+Date: Wed, 4 Jul 2018 17:27:56 -0400
+Subject: [PATCH 4714/5725] drm/amd/display: add a check for display depth
+ validity
+
+[why]
+HDMI 2.0 fails to validate 4K@60 timing with 10 bpc
+[how]
+Adding a helper function that would verify if the display depth
+assigned would pass a bandwidth validation.
+Drop the display depth by one level till calculated pixel clk
+is lower than maximum TMDS clk.
+
+Bugzilla: https://bugs.freedesktop.org/106959
+
+Tested-by: Mike Lothian <mike@fireburn.co.uk>
+Reviewed-by: Harry Wentland <harry.wentland@amd.com>
+Signed-off-by: Mikita Lipski <mikita.lipski@amd.com>
+Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
+Signed-off-by: Raveendra Talabattula <raveendra.talabattula@amd.com>
+---
+ drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 44 +++++++++++++++++++++++
+ 1 file changed, 44 insertions(+)
+
+diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+index 8d60833..2aa0041 100644
+--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
++++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+@@ -2364,6 +2364,47 @@ get_output_color_space(const struct dc_crtc_timing *dc_crtc_timing)
+ return color_space;
+ }
+
++static void reduce_mode_colour_depth(struct dc_crtc_timing *timing_out)
++{
++ if (timing_out->display_color_depth <= COLOR_DEPTH_888)
++ return;
++
++ timing_out->display_color_depth--;
++}
++
++static void adjust_colour_depth_from_display_info(struct dc_crtc_timing *timing_out,
++ const struct drm_display_info *info)
++{
++ int normalized_clk;
++ if (timing_out->display_color_depth <= COLOR_DEPTH_888)
++ return;
++ do {
++ normalized_clk = timing_out->pix_clk_khz;
++ /* YCbCr 4:2:0 requires additional adjustment of 1/2 */
++ if (timing_out->pixel_encoding == PIXEL_ENCODING_YCBCR420)
++ normalized_clk /= 2;
++ /* Adjusting pix clock following on HDMI spec based on colour depth */
++ switch (timing_out->display_color_depth) {
++ case COLOR_DEPTH_101010:
++ normalized_clk = (normalized_clk * 30) / 24;
++ break;
++ case COLOR_DEPTH_121212:
++ normalized_clk = (normalized_clk * 36) / 24;
++ break;
++ case COLOR_DEPTH_161616:
++ normalized_clk = (normalized_clk * 48) / 24;
++ break;
++ default:
++ return;
++ }
++ if (normalized_clk <= info->max_tmds_clock)
++ return;
++ reduce_mode_colour_depth(timing_out);
++
++ } while (timing_out->display_color_depth > COLOR_DEPTH_888);
++
++}
++
+ /*****************************************************************************/
+
+ static int
+@@ -2462,6 +2503,9 @@ fill_stream_properties_from_drm_display_mode(struct dc_stream_state *stream,
+ stream->out_transfer_func->type = TF_TYPE_PREDEFINED;
+ stream->out_transfer_func->tf = TRANSFER_FUNCTION_SRGB;
+
++ if (stream->sink->sink_signal == SIGNAL_TYPE_HDMI_TYPE_A)
++ adjust_colour_depth_from_display_info(timing_out, info);
++
+ calculate_phy_pix_clks(stream);
+ }
+
+--
+2.7.4
+