aboutsummaryrefslogtreecommitdiffstats
path: root/common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch')
-rw-r--r--common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch68
1 files changed, 68 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch b/common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch
new file mode 100644
index 00000000..6f8502cb
--- /dev/null
+++ b/common/recipes-kernel/linux/linux-yocto-4.14.71/4172-drm-amd-display-Check-dc_sink-every-time-in-MST-hotp.patch
@@ -0,0 +1,68 @@
+From ea179b97793cc28c2d7d4020d3c9ddd86b11bd28 Mon Sep 17 00:00:00 2001
+From: "Jerry (Fangzhi) Zuo" <Jerry.Zuo@amd.com>
+Date: Tue, 17 Apr 2018 15:36:15 -0400
+Subject: [PATCH 4172/5725] drm/amd/display: Check dc_sink every time in MST
+ hotplug
+
+Extended fix to: "Don't read EDID in atomic_check"
+
+Fix issue of missing dc_sink in .mode_valid in hot plug routine.
+
+Need to check dc_sink everytime in .get_modes hook after checking
+edid, since edid is not getting removed in hot unplug but dc_sink
+doesn't.
+
+Signed-off-by: Jerry (Fangzhi) Zuo <Jerry.Zuo@amd.com>
+Reviewed-by: Harry Wentland <harry.wentland@amd.com>
+Acked-by: Alex Deucher <alexander.deucher@amd.com>
+---
+ .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_mst_types.c | 16 +++++++++-------
+ 1 file changed, 9 insertions(+), 7 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_mst_types.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_mst_types.c
+index e57f690..a9b76fd 100644
+--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_mst_types.c
++++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_mst_types.c
+@@ -237,10 +237,6 @@ static int dm_dp_mst_get_modes(struct drm_connector *connector)
+
+ if (!aconnector->edid) {
+ struct edid *edid;
+- struct dc_sink *dc_sink;
+- struct dc_sink_init_data init_params = {
+- .link = aconnector->dc_link,
+- .sink_signal = SIGNAL_TYPE_DISPLAY_PORT_MST };
+ edid = drm_dp_mst_get_edid(connector, &aconnector->mst_port->mst_mgr, aconnector->port);
+
+ if (!edid) {
+@@ -251,11 +247,17 @@ static int dm_dp_mst_get_modes(struct drm_connector *connector)
+ }
+
+ aconnector->edid = edid;
++ }
+
++ if (!aconnector->dc_sink) {
++ struct dc_sink *dc_sink;
++ struct dc_sink_init_data init_params = {
++ .link = aconnector->dc_link,
++ .sink_signal = SIGNAL_TYPE_DISPLAY_PORT_MST };
+ dc_sink = dc_link_add_remote_sink(
+ aconnector->dc_link,
+- (uint8_t *)edid,
+- (edid->extensions + 1) * EDID_LENGTH,
++ (uint8_t *)aconnector->edid,
++ (aconnector->edid->extensions + 1) * EDID_LENGTH,
+ &init_params);
+
+ dc_sink->priv = aconnector;
+@@ -263,7 +265,7 @@ static int dm_dp_mst_get_modes(struct drm_connector *connector)
+
+ if (aconnector->dc_sink)
+ amdgpu_dm_update_freesync_caps(
+- connector, edid);
++ connector, aconnector->edid);
+ }
+
+ drm_mode_connector_update_edid_property(
+--
+2.7.4
+