Commit 1e116253 authored by Andrzej Hajda's avatar Andrzej Hajda Committed by Jani Nikula

drm/i915/display/pch: use intel_de_rmw if possible

The helper makes the code more compact and readable.
Signed-off-by: default avatarAndrzej Hajda <andrzej.hajda@intel.com>
Reviewed-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230105131046.2173431-5-andrzej.hajda@intel.com
parent bdfee324
...@@ -308,7 +308,6 @@ static void ilk_disable_pch_transcoder(struct intel_crtc *crtc) ...@@ -308,7 +308,6 @@ static void ilk_disable_pch_transcoder(struct intel_crtc *crtc)
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev); struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
enum pipe pipe = crtc->pipe; enum pipe pipe = crtc->pipe;
i915_reg_t reg; i915_reg_t reg;
u32 val;
/* FDI relies on the transcoder */ /* FDI relies on the transcoder */
assert_fdi_tx_disabled(dev_priv, pipe); assert_fdi_tx_disabled(dev_priv, pipe);
...@@ -318,21 +317,16 @@ static void ilk_disable_pch_transcoder(struct intel_crtc *crtc) ...@@ -318,21 +317,16 @@ static void ilk_disable_pch_transcoder(struct intel_crtc *crtc)
assert_pch_ports_disabled(dev_priv, pipe); assert_pch_ports_disabled(dev_priv, pipe);
reg = PCH_TRANSCONF(pipe); reg = PCH_TRANSCONF(pipe);
val = intel_de_read(dev_priv, reg); intel_de_rmw(dev_priv, reg, TRANS_ENABLE, 0);
val &= ~TRANS_ENABLE;
intel_de_write(dev_priv, reg, val);
/* wait for PCH transcoder off, transcoder state */ /* wait for PCH transcoder off, transcoder state */
if (intel_de_wait_for_clear(dev_priv, reg, TRANS_STATE_ENABLE, 50)) if (intel_de_wait_for_clear(dev_priv, reg, TRANS_STATE_ENABLE, 50))
drm_err(&dev_priv->drm, "failed to disable transcoder %c\n", drm_err(&dev_priv->drm, "failed to disable transcoder %c\n",
pipe_name(pipe)); pipe_name(pipe));
if (HAS_PCH_CPT(dev_priv)) { if (HAS_PCH_CPT(dev_priv))
/* Workaround: Clear the timing override chicken bit again. */ /* Workaround: Clear the timing override chicken bit again. */
reg = TRANS_CHICKEN2(pipe); intel_de_rmw(dev_priv, TRANS_CHICKEN2(pipe),
val = intel_de_read(dev_priv, reg); TRANS_CHICKEN2_TIMING_OVERRIDE, 0);
val &= ~TRANS_CHICKEN2_TIMING_OVERRIDE;
intel_de_write(dev_priv, reg, val);
}
} }
void ilk_pch_pre_enable(struct intel_atomic_state *state, void ilk_pch_pre_enable(struct intel_atomic_state *state,
...@@ -457,21 +451,14 @@ void ilk_pch_post_disable(struct intel_atomic_state *state, ...@@ -457,21 +451,14 @@ void ilk_pch_post_disable(struct intel_atomic_state *state,
ilk_disable_pch_transcoder(crtc); ilk_disable_pch_transcoder(crtc);
if (HAS_PCH_CPT(dev_priv)) { if (HAS_PCH_CPT(dev_priv)) {
i915_reg_t reg;
u32 temp;
/* disable TRANS_DP_CTL */ /* disable TRANS_DP_CTL */
reg = TRANS_DP_CTL(pipe); intel_de_rmw(dev_priv, TRANS_DP_CTL(pipe),
temp = intel_de_read(dev_priv, reg); TRANS_DP_OUTPUT_ENABLE | TRANS_DP_PORT_SEL_MASK,
temp &= ~(TRANS_DP_OUTPUT_ENABLE | TRANS_DP_PORT_SEL_NONE);
TRANS_DP_PORT_SEL_MASK);
temp |= TRANS_DP_PORT_SEL_NONE;
intel_de_write(dev_priv, reg, temp);
/* disable DPLL_SEL */ /* disable DPLL_SEL */
temp = intel_de_read(dev_priv, PCH_DPLL_SEL); intel_de_rmw(dev_priv, PCH_DPLL_SEL,
temp &= ~(TRANS_DPLL_ENABLE(pipe) | TRANS_DPLLB_SEL(pipe)); TRANS_DPLL_ENABLE(pipe) | TRANS_DPLLB_SEL(pipe), 0);
intel_de_write(dev_priv, PCH_DPLL_SEL, temp);
} }
ilk_fdi_pll_disable(crtc); ilk_fdi_pll_disable(crtc);
...@@ -581,20 +568,14 @@ static void lpt_enable_pch_transcoder(const struct intel_crtc_state *crtc_state) ...@@ -581,20 +568,14 @@ static void lpt_enable_pch_transcoder(const struct intel_crtc_state *crtc_state)
static void lpt_disable_pch_transcoder(struct drm_i915_private *dev_priv) static void lpt_disable_pch_transcoder(struct drm_i915_private *dev_priv)
{ {
u32 val; intel_de_rmw(dev_priv, LPT_TRANSCONF, TRANS_ENABLE, 0);
val = intel_de_read(dev_priv, LPT_TRANSCONF);
val &= ~TRANS_ENABLE;
intel_de_write(dev_priv, LPT_TRANSCONF, val);
/* wait for PCH transcoder off, transcoder state */ /* wait for PCH transcoder off, transcoder state */
if (intel_de_wait_for_clear(dev_priv, LPT_TRANSCONF, if (intel_de_wait_for_clear(dev_priv, LPT_TRANSCONF,
TRANS_STATE_ENABLE, 50)) TRANS_STATE_ENABLE, 50))
drm_err(&dev_priv->drm, "Failed to disable PCH transcoder\n"); drm_err(&dev_priv->drm, "Failed to disable PCH transcoder\n");
/* Workaround: clear timing override bit. */ /* Workaround: clear timing override bit. */
val = intel_de_read(dev_priv, TRANS_CHICKEN2(PIPE_A)); intel_de_rmw(dev_priv, TRANS_CHICKEN2(PIPE_A), TRANS_CHICKEN2_TIMING_OVERRIDE, 0);
val &= ~TRANS_CHICKEN2_TIMING_OVERRIDE;
intel_de_write(dev_priv, TRANS_CHICKEN2(PIPE_A), val);
} }
void lpt_pch_enable(struct intel_atomic_state *state, void lpt_pch_enable(struct intel_atomic_state *state,
......
...@@ -12,19 +12,13 @@ ...@@ -12,19 +12,13 @@
static void lpt_fdi_reset_mphy(struct drm_i915_private *dev_priv) static void lpt_fdi_reset_mphy(struct drm_i915_private *dev_priv)
{ {
u32 tmp; intel_de_rmw(dev_priv, SOUTH_CHICKEN2, 0, FDI_MPHY_IOSFSB_RESET_CTL);
tmp = intel_de_read(dev_priv, SOUTH_CHICKEN2);
tmp |= FDI_MPHY_IOSFSB_RESET_CTL;
intel_de_write(dev_priv, SOUTH_CHICKEN2, tmp);
if (wait_for_us(intel_de_read(dev_priv, SOUTH_CHICKEN2) & if (wait_for_us(intel_de_read(dev_priv, SOUTH_CHICKEN2) &
FDI_MPHY_IOSFSB_RESET_STATUS, 100)) FDI_MPHY_IOSFSB_RESET_STATUS, 100))
drm_err(&dev_priv->drm, "FDI mPHY reset assert timeout\n"); drm_err(&dev_priv->drm, "FDI mPHY reset assert timeout\n");
tmp = intel_de_read(dev_priv, SOUTH_CHICKEN2); intel_de_rmw(dev_priv, SOUTH_CHICKEN2, FDI_MPHY_IOSFSB_RESET_CTL, 0);
tmp &= ~FDI_MPHY_IOSFSB_RESET_CTL;
intel_de_write(dev_priv, SOUTH_CHICKEN2, tmp);
if (wait_for_us((intel_de_read(dev_priv, SOUTH_CHICKEN2) & if (wait_for_us((intel_de_read(dev_priv, SOUTH_CHICKEN2) &
FDI_MPHY_IOSFSB_RESET_STATUS) == 0, 100)) FDI_MPHY_IOSFSB_RESET_STATUS) == 0, 100))
......
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