提交 359441cd 编写于 作者: I Imre Deak

drm/i915: Sanitize open-coded power well enable()/disable() calls

Instead of open-coding the call of the power wells' enable()/disable()
hooks use the corresponding helper functions. This will also ensure that
the power well's cached-enable state is always up-to-date. Luckily the
lack of this updating hasn't been a problem, since the state either
didn't change (in intel_display_power_set_target_dc_state()), or got
updated subsequently (for vlv_cmnlane_wa(), in the following
intel_power_domains_sync_hw()).
Signed-off-by: NImre Deak <imre.deak@intel.com>
Reviewed-by: NJouni Högander <jouni.hogander@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220222165137.1004194-3-imre.deak@intel.com
上级 492c1ae2
...@@ -1130,12 +1130,12 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv, ...@@ -1130,12 +1130,12 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv,
* DC off power well to effect target DC state. * DC off power well to effect target DC state.
*/ */
if (!dc_off_enabled) if (!dc_off_enabled)
power_well->desc->ops->enable(dev_priv, power_well); intel_power_well_enable(dev_priv, power_well);
dev_priv->dmc.target_dc_state = state; dev_priv->dmc.target_dc_state = state;
if (!dc_off_enabled) if (!dc_off_enabled)
power_well->desc->ops->disable(dev_priv, power_well); intel_power_well_disable(dev_priv, power_well);
unlock: unlock:
mutex_unlock(&power_domains->lock); mutex_unlock(&power_domains->lock);
...@@ -6073,7 +6073,7 @@ static void vlv_cmnlane_wa(struct drm_i915_private *dev_priv) ...@@ -6073,7 +6073,7 @@ static void vlv_cmnlane_wa(struct drm_i915_private *dev_priv)
drm_dbg_kms(&dev_priv->drm, "toggling display PHY side reset\n"); drm_dbg_kms(&dev_priv->drm, "toggling display PHY side reset\n");
/* cmnlane needs DPLL registers */ /* cmnlane needs DPLL registers */
disp2d->desc->ops->enable(dev_priv, disp2d); intel_power_well_enable(dev_priv, disp2d);
/* /*
* From VLV2A0_DP_eDP_HDMI_DPIO_driver_vbios_notes_11.docx: * From VLV2A0_DP_eDP_HDMI_DPIO_driver_vbios_notes_11.docx:
...@@ -6082,7 +6082,7 @@ static void vlv_cmnlane_wa(struct drm_i915_private *dev_priv) ...@@ -6082,7 +6082,7 @@ static void vlv_cmnlane_wa(struct drm_i915_private *dev_priv)
* Simply ungating isn't enough to reset the PHY enough to get * Simply ungating isn't enough to reset the PHY enough to get
* ports and lanes running. * ports and lanes running.
*/ */
cmn->desc->ops->disable(dev_priv, cmn); intel_power_well_disable(dev_priv, cmn);
} }
static bool vlv_punit_is_power_gated(struct drm_i915_private *dev_priv, u32 reg0) static bool vlv_punit_is_power_gated(struct drm_i915_private *dev_priv, u32 reg0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册