]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
drm/amd/display: Implement DPIA link configuration
authorJimmy Kizito <Jimmy.Kizito@amd.com>
Mon, 12 Apr 2021 20:03:11 +0000 (16:03 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 6 Oct 2021 19:51:45 +0000 (15:51 -0400)
[Why]
Training settings need to be applied to DPIA link at start of each
training loop. Note: FEC readiness should be configured before link
training while FEC enablement should be configured once training is
complete.

[How]
- Implement DPIA link configuration function.
- Account for dynamically assigned link encoders during link
configuration.

Reviewed-by: Jun Lei <Jun.Lei@amd.com>
Acked-by: Wayne Lin <Wayne.Lin@amd.com>
Acked-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Acked-by: Harry Wentland <harry.wentland@amd.com>
Signed-off-by: Jimmy Kizito <Jimmy.Kizito@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/core/dc_link_dpia.c
drivers/gpu/drm/amd/display/dc/dcn31/dcn31_dio_link_encoder.c

index afb18cba3efa5d99983b3fa45c91a2978970d38a..1184ff84b7679addec0ab75d5fc916258dcc0d62 100644 (file)
@@ -30,6 +30,9 @@
 #include "dc_link.h"
 #include "dc_link_dp.h"
 
+#define DC_LOGGER \
+       link->ctx->logger
+
 enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link)
 {
        /** @todo Read corresponding DPCD region and update link caps. */
@@ -38,17 +41,51 @@ enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link)
 
 /* Configure link as prescribed in link_setting; set LTTPR mode; and
  * Initialize link training settings.
+ * Abort link training if sink unplug detected.
+ *
+ * @param link DPIA link being trained.
+ * @param[in] link_setting Lane count, link rate and downspread control.
+ * @param[out] lt_settings Link settings and drive settings (voltage swing and pre-emphasis).
  */
 static enum link_training_result dpia_configure_link(struct dc_link *link,
                const struct dc_link_settings *link_setting,
                struct link_training_settings *lt_settings)
 {
-       enum link_training_result result;
-
-       /** @todo Fail until implemented. */
-       result = LINK_TRAINING_ABORT;
-
-       return result;
+       enum dc_status status;
+       bool fec_enable;
+
+       DC_LOG_HW_LINK_TRAINING("%s\n DPIA(%d) configuring\n - LTTPR mode(%d)\n",
+                               __func__,
+                               link->link_id.enum_id - ENUM_ID_1,
+                               link->lttpr_mode);
+
+       dp_decide_training_settings(link,
+               link_setting,
+               lt_settings);
+
+       status = dpcd_configure_channel_coding(link, lt_settings);
+       if (status != DC_OK && !link->hpd_status)
+               return LINK_TRAINING_ABORT;
+
+       /* Configure lttpr mode */
+       status = dpcd_configure_lttpr_mode(link, lt_settings);
+       if (status != DC_OK && !link->hpd_status)
+               return LINK_TRAINING_ABORT;
+
+       /* Set link rate, lane count and spread. */
+       status = dpcd_set_link_settings(link, lt_settings);
+       if (status != DC_OK && !link->hpd_status)
+               return LINK_TRAINING_ABORT;
+
+       if (link->preferred_training_settings.fec_enable)
+               fec_enable = *link->preferred_training_settings.fec_enable;
+       else
+               fec_enable = true;
+       status = dp_set_fec_ready(link, fec_enable);
+       if (status != DC_OK && !link->hpd_status)
+               return LINK_TRAINING_ABORT;
+
+       return LINK_TRAINING_SUCCESS;
 }
 
 /* Execute clock recovery phase of link training for specified hop in display
index f86d4446f3475d7cc37d66023d16bca97916c14f..a5266d5999d74ccd65928ffd2f24d77d390458fc 100644 (file)
@@ -428,6 +428,7 @@ void dcn31_link_encoder_enable_dp_output(
 
                if (link) {
                        dpia_control.dpia_id = link->ddc_hw_inst;
+                       dpia_control.fec_rdy = link->fec_state == dc_link_fec_ready ? 1 : 0;
                } else {
                        DC_LOG_ERROR("%s: Failed to execute DPIA enable DMUB command.\n", __func__);
                        BREAK_TO_DEBUGGER();
@@ -469,6 +470,7 @@ void dcn31_link_encoder_enable_dp_mst_output(
 
                if (link) {
                        dpia_control.dpia_id = link->ddc_hw_inst;
+                       dpia_control.fec_rdy = link->fec_state == dc_link_fec_ready ? 1 : 0;
                } else {
                        DC_LOG_ERROR("%s: Failed to execute DPIA enable DMUB command.\n", __func__);
                        BREAK_TO_DEBUGGER();