Commit 7a1bae87 authored by George Shen's avatar George Shen Committed by Alex Deucher

drm/amd/display: Refactor fixed VS w/a for PHY tests

[Why/How]
Refactor original w/a to unify naming and
simplify logic. This also re-enables the code
that was previously skipped due to the
disabling of the previous workaround logic.
Reviewed-by: default avatarWenjing Liu <Wenjing.Liu@amd.com>
Reviewed-by: default avatarNevenko Stupar <Nevenko.Stupar@amd.com>
Acked-by: default avatarAlan Liu <HaoPing.Liu@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 f70b88b9
...@@ -505,17 +505,24 @@ static void vendor_specific_lttpr_wa_four( ...@@ -505,17 +505,24 @@ static void vendor_specific_lttpr_wa_four(
} }
} }
static void vendor_specific_lttpr_wa_five( static void dp_fixed_vs_pe_set_retimer_lane_settings(
struct dc_link *link, struct dc_link *link,
const union dpcd_training_lane dpcd_lane_adjust[LANE_COUNT_DP_MAX], const union dpcd_training_lane dpcd_lane_adjust[LANE_COUNT_DP_MAX],
uint8_t lane_count) uint8_t lane_count)
{ {
const uint32_t vendor_lttpr_write_address = 0xF004F; const uint8_t offset = dp_convert_to_count(
link->dpcd_caps.lttpr_caps.phy_repeater_cnt);
const uint8_t vendor_lttpr_write_data_reset[4] = {0x1, 0x50, 0x63, 0xFF}; const uint8_t vendor_lttpr_write_data_reset[4] = {0x1, 0x50, 0x63, 0xFF};
uint32_t vendor_lttpr_write_address = 0xF004F;
uint8_t vendor_lttpr_write_data_vs[4] = {0x1, 0x51, 0x63, 0x0}; uint8_t vendor_lttpr_write_data_vs[4] = {0x1, 0x51, 0x63, 0x0};
uint8_t vendor_lttpr_write_data_pe[4] = {0x1, 0x52, 0x63, 0x0}; uint8_t vendor_lttpr_write_data_pe[4] = {0x1, 0x52, 0x63, 0x0};
uint8_t lane = 0; uint8_t lane = 0;
if (offset != 0xFF) {
vendor_lttpr_write_address +=
((DP_REPEATER_CONFIGURATION_AND_STATUS_SIZE) * (offset - 1));
}
for (lane = 0; lane < lane_count; lane++) { for (lane = 0; lane < lane_count; lane++) {
vendor_lttpr_write_data_vs[3] |= vendor_lttpr_write_data_vs[3] |=
dpcd_lane_adjust[lane].bits.VOLTAGE_SWING_SET << (2 * lane); dpcd_lane_adjust[lane].bits.VOLTAGE_SWING_SET << (2 * lane);
...@@ -5989,15 +5996,14 @@ bool dc_link_dp_set_test_pattern( ...@@ -5989,15 +5996,14 @@ bool dc_link_dp_set_test_pattern(
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) {
dpcd_set_lane_settings(link, p_link_settings, DPRX); dp_fixed_vs_pe_set_retimer_lane_settings(
vendor_specific_lttpr_wa_five(
link, link,
p_link_settings->dpcd_lane_settings, p_link_settings->dpcd_lane_settings,
p_link_settings->link_settings.lane_count); p_link_settings->link_settings.lane_count);
} else { } else {
dp_set_hw_lane_settings(link, &pipe_ctx->link_res, p_link_settings, DPRX); dp_set_hw_lane_settings(link, &pipe_ctx->link_res, p_link_settings, DPRX);
dpcd_set_lane_settings(link, p_link_settings, DPRX);
} }
dpcd_set_lane_settings(link, p_link_settings, DPRX);
} }
/* Blank stream if running test pattern */ /* Blank stream if running test pattern */
......
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