drm/dp/mst: Reverse order of MST enable and clearing VC payload table.
commit c175cd16df upstream.
On DELL U3014 if you clear the table before enabling MST it sometimes
hangs the receiver.
Signed-off-by: Andrey Grodzovsky <Andrey.Grodzovsky@amd.com>
Reviewed-by: Harry Wentland <harry.wentland@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
ad9421d86e
commit
a252d13f41
@@ -1976,6 +1976,12 @@ int drm_dp_mst_topology_mgr_set_mst(struct drm_dp_mst_topology_mgr *mgr, bool ms
|
|||||||
mgr->mst_primary = mstb;
|
mgr->mst_primary = mstb;
|
||||||
kref_get(&mgr->mst_primary->kref);
|
kref_get(&mgr->mst_primary->kref);
|
||||||
|
|
||||||
|
ret = drm_dp_dpcd_writeb(mgr->aux, DP_MSTM_CTRL,
|
||||||
|
DP_MST_EN | DP_UP_REQ_EN | DP_UPSTREAM_IS_SRC);
|
||||||
|
if (ret < 0) {
|
||||||
|
goto out_unlock;
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
struct drm_dp_payload reset_pay;
|
struct drm_dp_payload reset_pay;
|
||||||
reset_pay.start_slot = 0;
|
reset_pay.start_slot = 0;
|
||||||
@@ -1983,12 +1989,6 @@ int drm_dp_mst_topology_mgr_set_mst(struct drm_dp_mst_topology_mgr *mgr, bool ms
|
|||||||
drm_dp_dpcd_write_payload(mgr, 0, &reset_pay);
|
drm_dp_dpcd_write_payload(mgr, 0, &reset_pay);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = drm_dp_dpcd_writeb(mgr->aux, DP_MSTM_CTRL,
|
|
||||||
DP_MST_EN | DP_UP_REQ_EN | DP_UPSTREAM_IS_SRC);
|
|
||||||
if (ret < 0) {
|
|
||||||
goto out_unlock;
|
|
||||||
}
|
|
||||||
|
|
||||||
queue_work(system_long_wq, &mgr->work);
|
queue_work(system_long_wq, &mgr->work);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|||||||
Reference in New Issue
Block a user