Commit 2f2a4b18 authored by George Shen's avatar George Shen Committed by Alex Deucher

drm/amd/display: Skip vendor specific LTTPR w/a outside link training

[Why]
Vendor specific link rate toggle workaround should not be
applied outside of link training scenario, such as when
outputting PHY test pattern.

[How]
Add flag to indicate when link training is occuring.
Make workaround a no-op when flag is not set.
Reviewed-by: default avatarJun Lei <Jun.Lei@amd.com>
Acked-by: default avatarBhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Signed-off-by: default avatarGeorge Shen <George.Shen@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent c11099b0
...@@ -444,24 +444,26 @@ static void vendor_specific_lttpr_wa_one_two( ...@@ -444,24 +444,26 @@ static void vendor_specific_lttpr_wa_one_two(
struct dc_link *link, struct dc_link *link,
const uint8_t rate) const uint8_t rate)
{ {
uint8_t toggle_rate = 0x0; if (link->apply_vendor_specific_lttpr_link_rate_wa) {
uint8_t toggle_rate = 0x0;
if (rate == 0x6) if (rate == 0x6)
toggle_rate = 0xA; toggle_rate = 0xA;
else else
toggle_rate = 0x6; toggle_rate = 0x6;
if (link->vendor_specific_lttpr_link_rate_wa == rate) { if (link->vendor_specific_lttpr_link_rate_wa == rate) {
/* W/A for certain LTTPR to reset internal state for link training */ /* W/A for certain LTTPR to reset internal state for link training */
core_link_write_dpcd( core_link_write_dpcd(
link, link,
DP_LINK_BW_SET, DP_LINK_BW_SET,
&toggle_rate, &toggle_rate,
1); 1);
} }
/* Store the last attempted link rate for this link */ /* Store the last attempted link rate for this link */
link->vendor_specific_lttpr_link_rate_wa = rate; link->vendor_specific_lttpr_link_rate_wa = rate;
}
} }
static void vendor_specific_lttpr_wa_three( static void vendor_specific_lttpr_wa_three(
...@@ -2383,10 +2385,12 @@ enum link_training_result dc_link_dp_perform_link_training( ...@@ -2383,10 +2385,12 @@ enum link_training_result dc_link_dp_perform_link_training(
/* reset previous training states */ /* reset previous training states */
if (link->dc->debug.apply_vendor_specific_lttpr_wa && if (link->dc->debug.apply_vendor_specific_lttpr_wa &&
(link->chip_caps & EXT_DISPLAY_PATH_CAPS__DP_FIXED_VS_EN) && (link->chip_caps & EXT_DISPLAY_PATH_CAPS__DP_FIXED_VS_EN) &&
link->lttpr_mode == LTTPR_MODE_TRANSPARENT) link->lttpr_mode == LTTPR_MODE_TRANSPARENT) {
link->apply_vendor_specific_lttpr_link_rate_wa = true;
vendor_specific_lttpr_wa_four(link, true); vendor_specific_lttpr_wa_four(link, true);
else } else {
dpcd_exit_training_mode(link); dpcd_exit_training_mode(link);
}
/* configure link prior to entering training mode */ /* configure link prior to entering training mode */
dpcd_configure_lttpr_mode(link, &lt_settings); dpcd_configure_lttpr_mode(link, &lt_settings);
...@@ -2409,10 +2413,12 @@ enum link_training_result dc_link_dp_perform_link_training( ...@@ -2409,10 +2413,12 @@ enum link_training_result dc_link_dp_perform_link_training(
/* exit training mode */ /* exit training mode */
if (link->dc->debug.apply_vendor_specific_lttpr_wa && if (link->dc->debug.apply_vendor_specific_lttpr_wa &&
(link->chip_caps & EXT_DISPLAY_PATH_CAPS__DP_FIXED_VS_EN) && (link->chip_caps & EXT_DISPLAY_PATH_CAPS__DP_FIXED_VS_EN) &&
link->lttpr_mode == LTTPR_MODE_TRANSPARENT) link->lttpr_mode == LTTPR_MODE_TRANSPARENT) {
link->apply_vendor_specific_lttpr_link_rate_wa = false;
vendor_specific_lttpr_wa_four(link, (status != LINK_TRAINING_SUCCESS)); vendor_specific_lttpr_wa_four(link, (status != LINK_TRAINING_SUCCESS));
else } else {
dpcd_exit_training_mode(link); dpcd_exit_training_mode(link);
}
/* switch to video idle */ /* switch to video idle */
if ((status == LINK_TRAINING_SUCCESS) || !skip_video_pattern) if ((status == LINK_TRAINING_SUCCESS) || !skip_video_pattern)
......
...@@ -188,6 +188,7 @@ struct dc_link { ...@@ -188,6 +188,7 @@ struct dc_link {
/* Vendor specific LTTPR workaround variables */ /* Vendor specific LTTPR workaround variables */
uint8_t vendor_specific_lttpr_link_rate_wa; uint8_t vendor_specific_lttpr_link_rate_wa;
bool apply_vendor_specific_lttpr_link_rate_wa;
/* MST record stream using this link */ /* MST record stream using this link */
struct link_flags { struct link_flags {
......
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