OSDN Git Service

drm/amd/display: display connected to dp-1 does not light up
authorHersen Wu <hersenxs.wu@amd.com>
Fri, 27 Jul 2018 18:52:37 +0000 (14:52 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 6 Aug 2018 20:57:51 +0000 (15:57 -0500)
[why]
for vega, dp set_panel_mode is
handled by psp firmware. dal should not program the
register again.

[how]
dal does not program panel mode.

Signed-off-by: Hersen Wu <hersenxs.wu@amd.com>
Reviewed-by: Charlene Liu <Charlene.Liu@amd.com>
Acked-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/dc.h
drivers/gpu/drm/amd/display/dc/dce/dce_link_encoder.c
drivers/gpu/drm/amd/display/dc/dce120/dce120_resource.c

index 3ecd2d6..e2f033d 100644 (file)
@@ -79,6 +79,7 @@ struct dc_caps {
        bool post_blend_color_processing;
        bool force_dp_tps4_for_cp2520;
        bool disable_dp_clk_share;
+       bool psp_setup_panel_mode;
 };
 
 struct dc_dcc_surface_param {
index 60e3c6a..752b3d6 100644 (file)
@@ -256,6 +256,11 @@ static void setup_panel_mode(
        enum dp_panel_mode panel_mode)
 {
        uint32_t value;
+       struct dc_context *ctx = enc110->base.ctx;
+
+       /* if psp set panel mode, dal should be program it */
+       if (ctx->dc->caps.psp_setup_panel_mode)
+               return;
 
        ASSERT(REG(DP_DPHY_INTERNAL_CTRL));
        value = REG_READ(DP_DPHY_INTERNAL_CTRL);
index 61d8e22..d43f37d 100644 (file)
@@ -883,6 +883,7 @@ static bool construct(
        dc->caps.i2c_speed_in_khz = 100;
        dc->caps.max_cursor_size = 128;
        dc->caps.dual_link_dvi = true;
+       dc->caps.psp_setup_panel_mode = true;
 
        dc->debug = debug_defaults;