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

drm/i915: Extract ilk_update_pll_dividers()

Make the PCH dpll code match the gmch code by splitting
the FP register handling out from ilk_compute_dpll().
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210715093530.31711-4-ville.syrjala@linux.intel.comReviewed-by: default avatarJani Nikula <jani.nikula@intel.com>
parent 6501e6bb
...@@ -948,12 +948,12 @@ static bool ilk_needs_fb_cb_tune(struct dpll *dpll, int factor) ...@@ -948,12 +948,12 @@ static bool ilk_needs_fb_cb_tune(struct dpll *dpll, int factor)
} }
static void ilk_compute_dpll(struct intel_crtc *crtc, static void ilk_update_pll_dividers(struct intel_crtc *crtc,
struct intel_crtc_state *crtc_state, struct intel_crtc_state *crtc_state,
struct dpll *reduced_clock) struct dpll *reduced_clock)
{ {
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev); struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
u32 dpll, fp, fp2; u32 fp, fp2 = 0;
int factor; int factor;
/* Enable autotuning of the PLL clock (if permissible) */ /* Enable autotuning of the PLL clock (if permissible) */
...@@ -978,10 +978,21 @@ static void ilk_compute_dpll(struct intel_crtc *crtc, ...@@ -978,10 +978,21 @@ static void ilk_compute_dpll(struct intel_crtc *crtc,
if (reduced_clock->m < factor * reduced_clock->n) if (reduced_clock->m < factor * reduced_clock->n)
fp2 |= FP_CB_TUNE; fp2 |= FP_CB_TUNE;
} else {
fp2 = fp;
} }
crtc_state->dpll_hw_state.fp0 = fp;
crtc_state->dpll_hw_state.fp1 = reduced_clock ? fp2 : fp;
}
static void ilk_compute_dpll(struct intel_crtc *crtc,
struct intel_crtc_state *crtc_state,
struct dpll *reduced_clock)
{
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
u32 dpll;
ilk_update_pll_dividers(crtc, crtc_state, reduced_clock);
dpll = 0; dpll = 0;
if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_LVDS)) if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_LVDS))
...@@ -1046,8 +1057,6 @@ static void ilk_compute_dpll(struct intel_crtc *crtc, ...@@ -1046,8 +1057,6 @@ static void ilk_compute_dpll(struct intel_crtc *crtc,
dpll |= DPLL_VCO_ENABLE; dpll |= DPLL_VCO_ENABLE;
crtc_state->dpll_hw_state.dpll = dpll; crtc_state->dpll_hw_state.dpll = dpll;
crtc_state->dpll_hw_state.fp0 = fp;
crtc_state->dpll_hw_state.fp1 = fp2;
} }
static int ilk_crtc_compute_clock(struct intel_crtc *crtc, static int ilk_crtc_compute_clock(struct intel_crtc *crtc,
......
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