From: Abhinav Kumar <[email protected]>

dp_display_enable() currently re-trains the link if needed and then
enables the pixel clock, programs the controller to start sending the
pixel stream. Split these two parts into prepare/enable APIs, to support
MST bridges_enable insert the MST payloads funcs between enable
stream_clks and program register.

Signed-off-by: Abhinav Kumar <[email protected]>
Signed-off-by: Yongxing Mou <[email protected]>
Reviewed-by: Dmitry Baryshkov <[email protected]>
---
 drivers/gpu/drm/msm/dp/dp_ctrl.c    |  48 +++++++++++------
 drivers/gpu/drm/msm/dp/dp_ctrl.h    |   3 +-
 drivers/gpu/drm/msm/dp/dp_display.c | 105 +++++++++++++++++++++++-------------
 3 files changed, 102 insertions(+), 54 deletions(-)

diff --git a/drivers/gpu/drm/msm/dp/dp_ctrl.c b/drivers/gpu/drm/msm/dp/dp_ctrl.c
index ac0a2c387f03..002141a02073 100644
--- a/drivers/gpu/drm/msm/dp/dp_ctrl.c
+++ b/drivers/gpu/drm/msm/dp/dp_ctrl.c
@@ -2505,27 +2505,19 @@ static void msm_dp_ctrl_config_msa(struct 
msm_dp_ctrl_private *ctrl,
        msm_dp_write_link(ctrl, REG_DP_SOFTWARE_NVID, nvid);
 }
 
-int msm_dp_ctrl_on_stream(struct msm_dp_ctrl *msm_dp_ctrl, bool 
force_link_train)
+int msm_dp_ctrl_prepare_stream_on(struct msm_dp_ctrl *msm_dp_ctrl, bool 
force_link_train)
 {
        int ret = 0;
-       bool mainlink_ready = false;
        struct msm_dp_ctrl_private *ctrl;
-       unsigned long pixel_rate;
-       unsigned long pixel_rate_orig;
 
        if (!msm_dp_ctrl)
                return -EINVAL;
 
        ctrl = container_of(msm_dp_ctrl, struct msm_dp_ctrl_private, 
msm_dp_ctrl);
 
-       pixel_rate = pixel_rate_orig = ctrl->panel->msm_dp_mode.drm_mode.clock;
-
-       if (msm_dp_ctrl->wide_bus_en || 
ctrl->panel->msm_dp_mode.out_fmt_is_yuv_420)
-               pixel_rate >>= 1;
-
-       drm_dbg_dp(ctrl->drm_dev, "rate=%d, num_lanes=%d, pixel_rate=%lu\n",
-               ctrl->link->link_params.rate,
-               ctrl->link->link_params.num_lanes, pixel_rate);
+       drm_dbg_dp(ctrl->drm_dev, "rate=%d, num_lanes=%d\n",
+                  ctrl->link->link_params.rate,
+                  ctrl->link->link_params.num_lanes);
 
        drm_dbg_dp(ctrl->drm_dev,
                "core_clk_on=%d link_clk_on=%d stream_clk_on=%d\n",
@@ -2539,16 +2531,40 @@ int msm_dp_ctrl_on_stream(struct msm_dp_ctrl 
*msm_dp_ctrl, bool force_link_train
                }
        }
 
-       ret = msm_dp_ctrl_on_pixel_clk(ctrl, pixel_rate);
-       if (ret)
-               return ret;
-
        if (force_link_train || !msm_dp_ctrl_channel_eq_ok(ctrl))
                msm_dp_ctrl_link_retrain(ctrl);
 
        /* stop txing train pattern to end link training */
        msm_dp_ctrl_clear_training_pattern(ctrl, DP_PHY_DPRX);
 
+       return ret;
+}
+
+int msm_dp_ctrl_on_stream(struct msm_dp_ctrl *msm_dp_ctrl)
+{
+       int ret = 0;
+       bool mainlink_ready = false;
+       struct msm_dp_ctrl_private *ctrl;
+       unsigned long pixel_rate;
+       unsigned long pixel_rate_orig;
+
+       if (!msm_dp_ctrl)
+               return -EINVAL;
+
+       ctrl = container_of(msm_dp_ctrl, struct msm_dp_ctrl_private, 
msm_dp_ctrl);
+
+       pixel_rate_orig = ctrl->panel->msm_dp_mode.drm_mode.clock;
+       pixel_rate = pixel_rate_orig;
+
+       if (msm_dp_ctrl->wide_bus_en || 
ctrl->panel->msm_dp_mode.out_fmt_is_yuv_420)
+               pixel_rate >>= 1;
+
+       drm_dbg_dp(ctrl->drm_dev, "pixel_rate=%lu\n", pixel_rate);
+
+       ret = msm_dp_ctrl_on_pixel_clk(ctrl, pixel_rate);
+       if (ret)
+               return ret;
+
        /*
         * Set up transfer unit values and set controller state to send
         * video.
diff --git a/drivers/gpu/drm/msm/dp/dp_ctrl.h b/drivers/gpu/drm/msm/dp/dp_ctrl.h
index f68bee62713f..1497f1a8fc2f 100644
--- a/drivers/gpu/drm/msm/dp/dp_ctrl.h
+++ b/drivers/gpu/drm/msm/dp/dp_ctrl.h
@@ -17,7 +17,8 @@ struct msm_dp_ctrl {
 struct phy;
 
 int msm_dp_ctrl_on_link(struct msm_dp_ctrl *msm_dp_ctrl);
-int msm_dp_ctrl_on_stream(struct msm_dp_ctrl *msm_dp_ctrl, bool 
force_link_train);
+int msm_dp_ctrl_on_stream(struct msm_dp_ctrl *msm_dp_ctrl);
+int msm_dp_ctrl_prepare_stream_on(struct msm_dp_ctrl *msm_dp_ctrl, bool 
force_link_train);
 void msm_dp_ctrl_off_link_stream(struct msm_dp_ctrl *msm_dp_ctrl);
 void msm_dp_ctrl_off(struct msm_dp_ctrl *msm_dp_ctrl);
 void msm_dp_ctrl_push_idle(struct msm_dp_ctrl *msm_dp_ctrl);
diff --git a/drivers/gpu/drm/msm/dp/dp_display.c 
b/drivers/gpu/drm/msm/dp/dp_display.c
index f33c754b83c3..cf859f880943 100644
--- a/drivers/gpu/drm/msm/dp/dp_display.c
+++ b/drivers/gpu/drm/msm/dp/dp_display.c
@@ -617,7 +617,40 @@ static int msm_dp_display_set_mode(struct msm_dp 
*msm_dp_display,
        return 0;
 }
 
-static int msm_dp_display_enable(struct msm_dp_display_private *dp, bool 
force_link_train)
+static int msm_dp_display_prepare_link(struct msm_dp_display_private *dp)
+{
+       struct msm_dp *msm_dp_display = &dp->msm_dp_display;
+       int rc = 0;
+       bool force_link_train = false;
+
+       drm_dbg_dp(dp->drm_dev, "sink_count=%d\n", dp->link->sink_count);
+
+       if (msm_dp_display->is_edp)
+               msm_dp_hpd_plug_handle(dp);
+
+       rc = pm_runtime_resume_and_get(&msm_dp_display->pdev->dev);
+       if (rc) {
+               DRM_ERROR("failed to pm_runtime_resume\n");
+               return rc;
+       }
+
+       if (dp->link->sink_count == 0)
+               return rc;
+
+       if (!msm_dp_display->power_on) {
+               msm_dp_display_host_phy_init(dp);
+               force_link_train = true;
+       }
+
+       rc = msm_dp_ctrl_on_link(dp->ctrl);
+       if (rc)
+               DRM_ERROR("Failed link training (rc=%d)\n", rc);
+       // TODO: schedule drm_connector_set_link_status_property()
+
+       return msm_dp_ctrl_prepare_stream_on(dp->ctrl, force_link_train);
+}
+
+static int msm_dp_display_enable(struct msm_dp_display_private *dp)
 {
        int rc = 0;
        struct msm_dp *msm_dp_display = &dp->msm_dp_display;
@@ -628,7 +661,7 @@ static int msm_dp_display_enable(struct 
msm_dp_display_private *dp, bool force_l
                return 0;
        }
 
-       rc = msm_dp_ctrl_on_stream(dp->ctrl, force_link_train);
+       rc = msm_dp_ctrl_on_stream(dp->ctrl);
        if (!rc)
                msm_dp_display->power_on = true;
 
@@ -658,13 +691,10 @@ static int msm_dp_display_post_enable(struct msm_dp 
*msm_dp_display)
        return 0;
 }
 
-static int msm_dp_display_disable(struct msm_dp_display_private *dp)
+static void msm_dp_display_audio_notify_disable(struct msm_dp_display_private 
*dp)
 {
        struct msm_dp *msm_dp_display = &dp->msm_dp_display;
 
-       if (!msm_dp_display->power_on)
-               return 0;
-
        /* wait only if audio was enabled */
        if (msm_dp_display->audio_enabled) {
                /* signal the disconnect event */
@@ -675,6 +705,14 @@ static int msm_dp_display_disable(struct 
msm_dp_display_private *dp)
        }
 
        msm_dp_display->audio_enabled = false;
+}
+
+static int msm_dp_display_disable(struct msm_dp_display_private *dp)
+{
+       struct msm_dp *msm_dp_display = &dp->msm_dp_display;
+
+       if (!msm_dp_display->power_on)
+               return 0;
 
        if (dp->link->sink_count == 0) {
                /*
@@ -1371,14 +1409,13 @@ void msm_dp_bridge_atomic_enable(struct drm_bridge 
*drm_bridge,
                                 struct drm_atomic_commit *state)
 {
        struct msm_dp_bridge *msm_dp_bridge = to_dp_bridge(drm_bridge);
-       struct msm_dp *dp = msm_dp_bridge->msm_dp_display;
+       struct msm_dp *msm_dp_display = msm_dp_bridge->msm_dp_display;
        struct drm_crtc *crtc;
        struct drm_crtc_state *crtc_state;
        int rc = 0;
-       struct msm_dp_display_private *msm_dp_display;
-       bool force_link_train = false;
+       struct msm_dp_display_private *dp;
 
-       msm_dp_display = container_of(dp, struct msm_dp_display_private, 
msm_dp_display);
+       dp = container_of(msm_dp_display, struct msm_dp_display_private, 
msm_dp_display);
 
        crtc = drm_atomic_get_new_crtc_for_encoder(state,
                                                   drm_bridge->encoder);
@@ -1386,44 +1423,29 @@ void msm_dp_bridge_atomic_enable(struct drm_bridge 
*drm_bridge,
                return;
        crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
 
-       if (dp->is_edp)
-               msm_dp_hpd_plug_handle(msm_dp_display);
-
-       if (pm_runtime_resume_and_get(&dp->pdev->dev)) {
-               DRM_ERROR("failed to pm_runtime_resume\n");
-               return;
-       }
-
-       if (msm_dp_display->link->sink_count == 0)
-               return;
-
-       rc = msm_dp_display_set_mode(dp, &crtc_state->adjusted_mode, 
msm_dp_display->panel);
+       rc = msm_dp_display_set_mode(msm_dp_display, 
&crtc_state->adjusted_mode, dp->panel);
        if (rc) {
                DRM_ERROR("Failed to perform a mode set, rc=%d\n", rc);
                return;
        }
 
-       if (!dp->power_on) {
-               msm_dp_display_host_phy_init(msm_dp_display);
-               force_link_train = true;
-       }
-
-       rc = msm_dp_ctrl_on_link(msm_dp_display->ctrl);
+       rc = msm_dp_display_prepare_link(dp);
        if (rc) {
-               DRM_ERROR("Failed link training (rc=%d)\n", rc);
-               // TODO: schedule drm_connector_set_link_status_property()
+               DRM_ERROR("DP display prepare failed, rc=%d\n", rc);
                return;
        }
 
-       msm_dp_display_enable(msm_dp_display, force_link_train);
+       rc = msm_dp_display_enable(dp);
+       if (rc)
+               DRM_ERROR("DP display enable failed, rc=%d\n", rc);
 
-       rc = msm_dp_display_post_enable(dp);
+       rc = msm_dp_display_post_enable(msm_dp_display);
        if (rc) {
                DRM_ERROR("DP display post enable failed, rc=%d\n", rc);
-               msm_dp_display_disable(msm_dp_display);
+               msm_dp_display_disable(dp);
        }
 
-       drm_dbg_dp(dp->drm_dev, "type=%d Done\n", dp->connector_type);
+       drm_dbg_dp(msm_dp_display->drm_dev, "type=%d Done\n", 
msm_dp_display->connector_type);
 }
 
 void msm_dp_bridge_atomic_disable(struct drm_bridge *drm_bridge,
@@ -1438,6 +1460,15 @@ void msm_dp_bridge_atomic_disable(struct drm_bridge 
*drm_bridge,
        msm_dp_ctrl_push_idle(msm_dp_display->ctrl);
 }
 
+static void msm_dp_display_unprepare(struct msm_dp_display_private *dp)
+{
+       struct msm_dp *msm_dp_display = &dp->msm_dp_display;
+
+       pm_runtime_put_sync(&msm_dp_display->pdev->dev);
+
+       drm_dbg_dp(dp->drm_dev, "type=%d Done\n", 
msm_dp_display->connector_type);
+}
+
 void msm_dp_bridge_atomic_post_disable(struct drm_bridge *drm_bridge,
                                       struct drm_atomic_commit *state)
 {
@@ -1450,11 +1481,11 @@ void msm_dp_bridge_atomic_post_disable(struct 
drm_bridge *drm_bridge,
        if (dp->is_edp)
                msm_dp_hpd_unplug_handle(msm_dp_display);
 
-       msm_dp_display_disable(msm_dp_display);
+       msm_dp_display_audio_notify_disable(msm_dp_display);
 
-       drm_dbg_dp(dp->drm_dev, "type=%d Done\n", dp->connector_type);
+       msm_dp_display_disable(msm_dp_display);
 
-       pm_runtime_put_sync(&dp->pdev->dev);
+       msm_dp_display_unprepare(msm_dp_display);
 }
 
 void msm_dp_bridge_hpd_enable(struct drm_bridge *bridge)

-- 
2.43.0

Reply via email to