mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-23 13:32:50 +07:00
drm/i915/icl: split combo and mg pll disable
Like was done in the enable case, split the implementation of the disable for MG and Combo PLLs. Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190309035727.25389-4-lucas.demarchi@intel.com
This commit is contained in:
parent
036f8d567b
commit
9be8644a14
@ -3193,10 +3193,9 @@ static void mg_pll_enable(struct drm_i915_private *dev_priv,
|
||||
}
|
||||
|
||||
static void icl_pll_disable(struct drm_i915_private *dev_priv,
|
||||
struct intel_shared_dpll *pll)
|
||||
struct intel_shared_dpll *pll,
|
||||
i915_reg_t enable_reg)
|
||||
{
|
||||
const enum intel_dpll_id id = pll->info->id;
|
||||
i915_reg_t enable_reg = icl_pll_id_to_enable_reg(id);
|
||||
u32 val;
|
||||
|
||||
/* The first steps are done by intel_ddi_post_disable(). */
|
||||
@ -3213,7 +3212,7 @@ static void icl_pll_disable(struct drm_i915_private *dev_priv,
|
||||
|
||||
/* Timeout is actually 1us. */
|
||||
if (intel_wait_for_register(dev_priv, enable_reg, PLL_LOCK, 0, 1))
|
||||
DRM_ERROR("PLL %d locked\n", id);
|
||||
DRM_ERROR("PLL %d locked\n", pll->info->id);
|
||||
|
||||
/* DVFS post sequence would be here. See the comment above. */
|
||||
|
||||
@ -3227,7 +3226,24 @@ static void icl_pll_disable(struct drm_i915_private *dev_priv,
|
||||
*/
|
||||
if (intel_wait_for_register(dev_priv, enable_reg, PLL_POWER_STATE, 0,
|
||||
1))
|
||||
DRM_ERROR("PLL %d Power not disabled\n", id);
|
||||
DRM_ERROR("PLL %d Power not disabled\n", pll->info->id);
|
||||
}
|
||||
|
||||
static void combo_pll_disable(struct drm_i915_private *dev_priv,
|
||||
struct intel_shared_dpll *pll)
|
||||
{
|
||||
i915_reg_t enable_reg = icl_pll_id_to_enable_reg(pll->info->id);
|
||||
|
||||
icl_pll_disable(dev_priv, pll, enable_reg);
|
||||
}
|
||||
|
||||
static void mg_pll_disable(struct drm_i915_private *dev_priv,
|
||||
struct intel_shared_dpll *pll)
|
||||
{
|
||||
i915_reg_t enable_reg =
|
||||
MG_PLL_ENABLE(icl_pll_id_to_tc_port(pll->info->id));
|
||||
|
||||
icl_pll_disable(dev_priv, pll, enable_reg);
|
||||
}
|
||||
|
||||
static void icl_dump_hw_state(struct drm_i915_private *dev_priv,
|
||||
@ -3254,13 +3270,13 @@ static void icl_dump_hw_state(struct drm_i915_private *dev_priv,
|
||||
|
||||
static const struct intel_shared_dpll_funcs icl_pll_funcs = {
|
||||
.enable = combo_pll_enable,
|
||||
.disable = icl_pll_disable,
|
||||
.disable = combo_pll_disable,
|
||||
.get_hw_state = icl_pll_get_hw_state,
|
||||
};
|
||||
|
||||
static const struct intel_shared_dpll_funcs mg_pll_funcs = {
|
||||
.enable = mg_pll_enable,
|
||||
.disable = icl_pll_disable,
|
||||
.disable = mg_pll_disable,
|
||||
.get_hw_state = mg_pll_get_hw_state,
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user