Commit efca0905 authored by Paul Hsieh's avatar Paul Hsieh Committed by Alex Deucher

drm/amd/display: check link status before disable stream

[Why]
1. Set second screen only then unplug external monitor
2. Enter to S4 then plug in external monitor
3. Resume from S4, eDP will not turn off when OS set
   second screen only
Sometimes OS will not set eDP power up cause eDP dpms_off
keep true then driver skipp disable stream

[How]
When drvier try to disable stream, add link status condition
Signed-off-by: default avatarPaul Hsieh <paul.hsieh@amd.com>
Reviewed-by: default avatarAnthony Koo <Anthony.Koo@amd.com>
Acked-by: default avatarRodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent db83e7ed
...@@ -860,6 +860,7 @@ static void dcn10_reset_back_end_for_pipe( ...@@ -860,6 +860,7 @@ static void dcn10_reset_back_end_for_pipe(
struct dc_state *context) struct dc_state *context)
{ {
int i; int i;
struct dc_link *link;
DC_LOGGER_INIT(dc->ctx->logger); DC_LOGGER_INIT(dc->ctx->logger);
if (pipe_ctx->stream_res.stream_enc == NULL) { if (pipe_ctx->stream_res.stream_enc == NULL) {
pipe_ctx->stream = NULL; pipe_ctx->stream = NULL;
...@@ -867,8 +868,14 @@ static void dcn10_reset_back_end_for_pipe( ...@@ -867,8 +868,14 @@ static void dcn10_reset_back_end_for_pipe(
} }
if (!IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment)) { if (!IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment)) {
/* DPMS may already disable */ link = pipe_ctx->stream->link;
if (!pipe_ctx->stream->dpms_off) /* DPMS may already disable or */
/* dpms_off status is incorrect due to fastboot
* feature. When system resume from S4 with second
* screen only, the dpms_off would be true but
* VBIOS lit up eDP, so check link status too.
*/
if (!pipe_ctx->stream->dpms_off || link->link_status.link_active)
core_link_disable_stream(pipe_ctx); core_link_disable_stream(pipe_ctx);
else if (pipe_ctx->stream_res.audio) else if (pipe_ctx->stream_res.audio)
dc->hwss.disable_audio_stream(pipe_ctx); dc->hwss.disable_audio_stream(pipe_ctx);
......
...@@ -2002,6 +2002,7 @@ static void dcn20_reset_back_end_for_pipe( ...@@ -2002,6 +2002,7 @@ static void dcn20_reset_back_end_for_pipe(
struct dc_state *context) struct dc_state *context)
{ {
int i; int i;
struct dc_link *link;
DC_LOGGER_INIT(dc->ctx->logger); DC_LOGGER_INIT(dc->ctx->logger);
if (pipe_ctx->stream_res.stream_enc == NULL) { if (pipe_ctx->stream_res.stream_enc == NULL) {
pipe_ctx->stream = NULL; pipe_ctx->stream = NULL;
...@@ -2009,8 +2010,14 @@ static void dcn20_reset_back_end_for_pipe( ...@@ -2009,8 +2010,14 @@ static void dcn20_reset_back_end_for_pipe(
} }
if (!IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment)) { if (!IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment)) {
/* DPMS may already disable */ link = pipe_ctx->stream->link;
if (!pipe_ctx->stream->dpms_off) /* DPMS may already disable or */
/* dpms_off status is incorrect due to fastboot
* feature. When system resume from S4 with second
* screen only, the dpms_off would be true but
* VBIOS lit up eDP, so check link status too.
*/
if (!pipe_ctx->stream->dpms_off || link->link_status.link_active)
core_link_disable_stream(pipe_ctx); core_link_disable_stream(pipe_ctx);
else if (pipe_ctx->stream_res.audio) else if (pipe_ctx->stream_res.audio)
dc->hwss.disable_audio_stream(pipe_ctx); dc->hwss.disable_audio_stream(pipe_ctx);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment