Commit 98ea24e6 authored by Paul Hsieh's avatar Paul Hsieh Committed by Alex Deucher

drm/amd/display: change fastboot timing validation

[Why]
VBIOS light up eDP with 6bpc but driver use 8bpc without
disable valid stream then re-enable valid stream. Some
panels can't runtime change color depth.

[How]
Change fastboot timing validation function. Not only check
LANE_COUNT, LINK_RATE...etc
Reviewed-by: default avatarAnthony Koo <Anthony.Koo@amd.com>
Acked-by: default avatarJasdeep Dhillon <jdhillon@amd.com>
Signed-off-by: default avatarPaul Hsieh <paul.hsieh@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent ca7f9d0a
...@@ -1462,7 +1462,7 @@ static bool context_changed( ...@@ -1462,7 +1462,7 @@ static bool context_changed(
return false; return false;
} }
bool dc_validate_seamless_boot_timing(const struct dc *dc, bool dc_validate_boot_timing(const struct dc *dc,
const struct dc_sink *sink, const struct dc_sink *sink,
struct dc_crtc_timing *crtc_timing) struct dc_crtc_timing *crtc_timing)
{ {
......
...@@ -2168,7 +2168,7 @@ static void mark_seamless_boot_stream( ...@@ -2168,7 +2168,7 @@ static void mark_seamless_boot_stream(
if (dc->config.allow_seamless_boot_optimization && if (dc->config.allow_seamless_boot_optimization &&
!dcb->funcs->is_accelerated_mode(dcb)) { !dcb->funcs->is_accelerated_mode(dcb)) {
if (dc_validate_seamless_boot_timing(dc, stream->sink, &stream->timing)) if (dc_validate_boot_timing(dc, stream->sink, &stream->timing))
stream->apply_seamless_boot_optimization = true; stream->apply_seamless_boot_optimization = true;
} }
} }
......
...@@ -1126,7 +1126,7 @@ struct dc_validation_set { ...@@ -1126,7 +1126,7 @@ struct dc_validation_set {
uint8_t plane_count; uint8_t plane_count;
}; };
bool dc_validate_seamless_boot_timing(const struct dc *dc, bool dc_validate_boot_timing(const struct dc *dc,
const struct dc_sink *sink, const struct dc_sink *sink,
struct dc_crtc_timing *crtc_timing); struct dc_crtc_timing *crtc_timing);
......
...@@ -1761,7 +1761,8 @@ void dce110_enable_accelerated_mode(struct dc *dc, struct dc_state *context) ...@@ -1761,7 +1761,8 @@ void dce110_enable_accelerated_mode(struct dc *dc, struct dc_state *context)
edp_link->link_status.link_active) { edp_link->link_status.link_active) {
struct dc_stream_state *edp_stream = edp_streams[0]; struct dc_stream_state *edp_stream = edp_streams[0];
can_apply_edp_fast_boot = !is_edp_ilr_optimization_required(edp_stream->link, &edp_stream->timing); can_apply_edp_fast_boot = dc_validate_boot_timing(dc,
edp_stream->sink, &edp_stream->timing);
edp_stream->apply_edp_fast_boot_optimization = can_apply_edp_fast_boot; edp_stream->apply_edp_fast_boot_optimization = can_apply_edp_fast_boot;
if (can_apply_edp_fast_boot) if (can_apply_edp_fast_boot)
DC_LOG_EVENT_LINK_TRAINING("eDP fast boot disabled to optimize link rate\n"); DC_LOG_EVENT_LINK_TRAINING("eDP fast boot disabled to optimize link rate\n");
......
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