1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
From 6d9c0236d50e7730bcafb04c3c5855b9251249f7 Mon Sep 17 00:00:00 2001
From: Eric Yang <eric.yang2@amd.com>
Date: Wed, 23 Dec 2015 10:57:17 -0500
Subject: [PATCH 0647/1110] drm/amd/dal: Properly handle sink removal
This fixes assert in dc_link_remove_sink when unplug mst display
Signed-off-by: Eric Yang <eric.yang2@amd.com>
Acked-by: Jordan Lazare <Jordan.Lazare@amd.com>
---
drivers/gpu/drm/amd/dal/amdgpu_dm/amdgpu_dm_mst_types.c | 3 ++-
drivers/gpu/drm/amd/dal/dc/core/dc_link.c | 13 +++++--------
drivers/gpu/drm/amd/dal/dc/inc/core_types.h | 2 ++
3 files changed, 9 insertions(+), 9 deletions(-)
diff --git a/drivers/gpu/drm/amd/dal/amdgpu_dm/amdgpu_dm_mst_types.c b/drivers/gpu/drm/amd/dal/amdgpu_dm/amdgpu_dm_mst_types.c
index 7ef2e60..e765f57 100644
--- a/drivers/gpu/drm/amd/dal/amdgpu_dm/amdgpu_dm_mst_types.c
+++ b/drivers/gpu/drm/amd/dal/amdgpu_dm/amdgpu_dm_mst_types.c
@@ -347,7 +347,8 @@ static void dm_dp_destroy_mst_connector(
drm_connector_cleanup(connector);
drm_modeset_unlock_all(dev);
- dc_link_remove_sink(aconnector->dc_link, aconnector->dc_sink);
+ if (aconnector->dc_sink)
+ dc_link_remove_sink(aconnector->dc_link, aconnector->dc_sink);
kfree(aconnector);
DRM_DEBUG_KMS("\n");
diff --git a/drivers/gpu/drm/amd/dal/dc/core/dc_link.c b/drivers/gpu/drm/amd/dal/dc/core/dc_link.c
index 0bb3799..646706e 100644
--- a/drivers/gpu/drm/amd/dal/dc/core/dc_link.c
+++ b/drivers/gpu/drm/amd/dal/dc/core/dc_link.c
@@ -522,6 +522,7 @@ void dc_link_detect(const struct dc_link *dc_link)
if (dc_helpers_dp_mst_start_top_mgr(
link->ctx,
&link->public)) {
+ link->mst_enabled = true;
return;
} else {
/* MST not supported */
@@ -636,15 +637,11 @@ void dc_link_detect(const struct dc_link *dc_link)
} else {
/* From Connected-to-Disconnected. */
- switch (link->public.connector_signal) {
- case SIGNAL_TYPE_DISPLAY_PORT:
+ if (link->mst_enabled) {
dc_helpers_dp_mst_stop_top_mgr(link->ctx, &link->public);
- break;
- default:
- break;
- }
-
- link_disconnect_all_sinks(link);
+ link->mst_enabled = false;
+ } else
+ link_disconnect_all_sinks(link);
}
LINK_INFO("link=%d, dc_sink_in=%p is now %s\n",
diff --git a/drivers/gpu/drm/amd/dal/dc/inc/core_types.h b/drivers/gpu/drm/amd/dal/dc/inc/core_types.h
index 194b3e0..dc871ad 100644
--- a/drivers/gpu/drm/amd/dal/dc/inc/core_types.h
+++ b/drivers/gpu/drm/amd/dal/dc/inc/core_types.h
@@ -227,6 +227,8 @@ struct core_link {
/* MST record stream using this link */
const struct core_stream *enabled_streams[MAX_SINKS_PER_LINK];
uint8_t enabled_stream_count;
+
+ bool mst_enabled;
};
#define DC_LINK_TO_LINK(dc_link) container_of(dc_link, struct core_link, public)
--
2.7.4
|