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

drm/i915: Eliminate pll->state usage from bxt_calc_pll_link()

We should be using the DPLL hw state we got from the current crtc state
to determine the corresponding port clock frequency rather than getting
it via the current state programmed into the DPLL.

v2: Rebase due to intel_dpll_id changes
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171027193128.14483-5-ville.syrjala@linux.intel.com
parent 0fce04c8
...@@ -1423,19 +1423,16 @@ static void hsw_ddi_clock_get(struct intel_encoder *encoder, ...@@ -1423,19 +1423,16 @@ static void hsw_ddi_clock_get(struct intel_encoder *encoder,
ddi_dotclock_get(pipe_config); ddi_dotclock_get(pipe_config);
} }
static int bxt_calc_pll_link(struct drm_i915_private *dev_priv, static int bxt_calc_pll_link(struct intel_crtc_state *crtc_state)
enum intel_dpll_id pll_id)
{ {
struct intel_shared_dpll *pll;
struct intel_dpll_hw_state *state; struct intel_dpll_hw_state *state;
struct dpll clock; struct dpll clock;
/* For DDI ports we always use a shared PLL. */ /* For DDI ports we always use a shared PLL. */
if (WARN_ON(pll_id == DPLL_ID_PRIVATE)) if (WARN_ON(!crtc_state->shared_dpll))
return 0; return 0;
pll = &dev_priv->shared_dplls[pll_id]; state = &crtc_state->dpll_hw_state;
state = &pll->state.hw_state;
clock.m1 = 2; clock.m1 = 2;
clock.m2 = (state->pll0 & PORT_PLL_M2_MASK) << 22; clock.m2 = (state->pll0 & PORT_PLL_M2_MASK) << 22;
...@@ -1449,13 +1446,9 @@ static int bxt_calc_pll_link(struct drm_i915_private *dev_priv, ...@@ -1449,13 +1446,9 @@ static int bxt_calc_pll_link(struct drm_i915_private *dev_priv,
} }
static void bxt_ddi_clock_get(struct intel_encoder *encoder, static void bxt_ddi_clock_get(struct intel_encoder *encoder,
struct intel_crtc_state *pipe_config) struct intel_crtc_state *pipe_config)
{ {
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev); pipe_config->port_clock = bxt_calc_pll_link(pipe_config);
enum port port = encoder->port;
enum intel_dpll_id pll_id = port;
pipe_config->port_clock = bxt_calc_pll_link(dev_priv, pll_id);
ddi_dotclock_get(pipe_config); ddi_dotclock_get(pipe_config);
} }
......
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