Commit ad952982 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Use intel_ddi_clk_select() for FDI

We want to put all DDI clock routing code into one place.
Unify the FDI enable sequence to use the standard function
instead of hand rolling its own. The disable sequence already
uses the normal thing.

Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210205214634.19341-2-ville.syrjala@linux.intel.comReviewed-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
parent f3243b75
...@@ -186,7 +186,7 @@ static void intel_wait_ddi_buf_active(struct drm_i915_private *dev_priv, ...@@ -186,7 +186,7 @@ static void intel_wait_ddi_buf_active(struct drm_i915_private *dev_priv,
port_name(port)); port_name(port));
} }
u32 hsw_pll_to_ddi_pll_sel(const struct intel_shared_dpll *pll) static u32 hsw_pll_to_ddi_pll_sel(const struct intel_shared_dpll *pll)
{ {
switch (pll->info->id) { switch (pll->info->id) {
case DPLL_ID_WRPLL1: case DPLL_ID_WRPLL1:
...@@ -1847,8 +1847,8 @@ void icl_sanitize_encoder_pll_mapping(struct intel_encoder *encoder) ...@@ -1847,8 +1847,8 @@ void icl_sanitize_encoder_pll_mapping(struct intel_encoder *encoder)
icl_sanitize_port_clk_off(dev_priv, port_mask, ddi_clk_needed); icl_sanitize_port_clk_off(dev_priv, port_mask, ddi_clk_needed);
} }
static void intel_ddi_clk_select(struct intel_encoder *encoder, void intel_ddi_clk_select(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state) const struct intel_crtc_state *crtc_state)
{ {
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev); struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
enum port port = encoder->port; enum port port = encoder->port;
......
...@@ -28,7 +28,8 @@ void intel_ddi_fdi_post_disable(struct intel_atomic_state *state, ...@@ -28,7 +28,8 @@ void intel_ddi_fdi_post_disable(struct intel_atomic_state *state,
struct intel_encoder *intel_encoder, struct intel_encoder *intel_encoder,
const struct intel_crtc_state *old_crtc_state, const struct intel_crtc_state *old_crtc_state,
const struct drm_connector_state *old_conn_state); const struct drm_connector_state *old_conn_state);
u32 hsw_pll_to_ddi_pll_sel(const struct intel_shared_dpll *pll); void intel_ddi_clk_select(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state);
void intel_prepare_dp_ddi_buffers(struct intel_encoder *encoder, void intel_prepare_dp_ddi_buffers(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state); const struct intel_crtc_state *crtc_state);
void intel_wait_ddi_buf_idle(struct drm_i915_private *dev_priv, void intel_wait_ddi_buf_idle(struct drm_i915_private *dev_priv,
......
...@@ -565,7 +565,7 @@ void hsw_fdi_link_train(struct intel_encoder *encoder, ...@@ -565,7 +565,7 @@ void hsw_fdi_link_train(struct intel_encoder *encoder,
{ {
struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc); struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev); struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
u32 temp, i, rx_ctl_val, ddi_pll_sel; u32 temp, i, rx_ctl_val;
int n_entries; int n_entries;
intel_ddi_get_buf_trans_fdi(dev_priv, &n_entries); intel_ddi_get_buf_trans_fdi(dev_priv, &n_entries);
...@@ -595,9 +595,8 @@ void hsw_fdi_link_train(struct intel_encoder *encoder, ...@@ -595,9 +595,8 @@ void hsw_fdi_link_train(struct intel_encoder *encoder,
intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), rx_ctl_val); intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), rx_ctl_val);
/* Configure Port Clock Select */ /* Configure Port Clock Select */
ddi_pll_sel = hsw_pll_to_ddi_pll_sel(crtc_state->shared_dpll); drm_WARN_ON(&dev_priv->drm, crtc_state->shared_dpll->info->id != DPLL_ID_SPLL);
intel_de_write(dev_priv, PORT_CLK_SEL(PORT_E), ddi_pll_sel); intel_ddi_clk_select(encoder, crtc_state);
drm_WARN_ON(&dev_priv->drm, ddi_pll_sel != PORT_CLK_SEL_SPLL);
/* Start the training iterating through available voltages and emphasis, /* Start the training iterating through available voltages and emphasis,
* testing each value twice. */ * testing each value twice. */
......
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