[Intel-gfx] [PATCH 2/2] drm/i915: Switch intel_crtc_disable_noatomic() to intel_ types
Lucas De Marchi
lucas.demarchi at intel.com
Mon Dec 2 15:24:00 UTC 2019
On Tue, Nov 05, 2019 at 07:14:47PM +0200, Ville Syrjälä wrote:
>From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
>It's hard to see what is going on when the function mixes drm_
>and intel_ types. Switch to intel_ types.
>
>Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
Reviewed-by: Lucas De Marchi <lucas.demarchi at intel.com>
Lucas De Marchi
>---
> drivers/gpu/drm/i915/display/intel_display.c | 65 ++++++++++----------
> 1 file changed, 33 insertions(+), 32 deletions(-)
>
>diff --git a/drivers/gpu/drm/i915/display/intel_display.c b/drivers/gpu/drm/i915/display/intel_display.c
>index 1f93860fb897..8e75e7028403 100644
>--- a/drivers/gpu/drm/i915/display/intel_display.c
>+++ b/drivers/gpu/drm/i915/display/intel_display.c
>@@ -7183,46 +7183,46 @@ static void i9xx_crtc_disable(struct intel_crtc_state *old_crtc_state,
> i830_enable_pipe(dev_priv, pipe);
> }
>
>-static void intel_crtc_disable_noatomic(struct drm_crtc *crtc,
>+static void intel_crtc_disable_noatomic(struct intel_crtc *crtc,
> struct drm_modeset_acquire_ctx *ctx)
> {
> struct intel_encoder *encoder;
>- struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
>- struct drm_i915_private *dev_priv = to_i915(crtc->dev);
>+ struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
> struct intel_bw_state *bw_state =
> to_intel_bw_state(dev_priv->bw_obj.state);
> struct intel_crtc_state *crtc_state =
>- to_intel_crtc_state(crtc->state);
>+ to_intel_crtc_state(crtc->base.state);
> enum intel_display_power_domain domain;
> struct intel_plane *plane;
>- u64 domains;
> struct drm_atomic_state *state;
> struct intel_crtc_state *temp_crtc_state;
>+ enum pipe pipe = crtc->pipe;
>+ u64 domains;
> int ret;
>
>- if (!intel_crtc->active)
>+ if (!crtc_state->hw.active)
> return;
>
>- for_each_intel_plane_on_crtc(&dev_priv->drm, intel_crtc, plane) {
>+ for_each_intel_plane_on_crtc(&dev_priv->drm, crtc, plane) {
> const struct intel_plane_state *plane_state =
> to_intel_plane_state(plane->base.state);
>
> if (plane_state->uapi.visible)
>- intel_plane_disable_noatomic(intel_crtc, plane);
>+ intel_plane_disable_noatomic(crtc, plane);
> }
>
>- state = drm_atomic_state_alloc(crtc->dev);
>+ state = drm_atomic_state_alloc(&dev_priv->drm);
> if (!state) {
> DRM_DEBUG_KMS("failed to disable [CRTC:%d:%s], out of memory",
>- crtc->base.id, crtc->name);
>+ crtc->base.base.id, crtc->base.name);
> return;
> }
>
> state->acquire_ctx = ctx;
>
> /* Everything's already locked, -EDEADLK can't happen. */
>- temp_crtc_state = intel_atomic_get_crtc_state(state, intel_crtc);
>- ret = drm_atomic_add_affected_connectors(state, crtc);
>+ temp_crtc_state = intel_atomic_get_crtc_state(state, crtc);
>+ ret = drm_atomic_add_affected_connectors(state, &crtc->base);
>
> WARN_ON(IS_ERR(temp_crtc_state) || ret);
>
>@@ -7231,35 +7231,36 @@ static void intel_crtc_disable_noatomic(struct drm_crtc *crtc,
> drm_atomic_state_put(state);
>
> DRM_DEBUG_KMS("[CRTC:%d:%s] hw state adjusted, was enabled, now disabled\n",
>- crtc->base.id, crtc->name);
>-
>- WARN_ON(drm_atomic_set_mode_for_crtc(crtc->state, NULL) < 0);
>- crtc->state->active = false;
>- intel_crtc->active = false;
>- crtc->enabled = false;
>- crtc->state->connector_mask = 0;
>- crtc->state->encoder_mask = 0;
>+ crtc->base.base.id, crtc->base.name);
>+
>+ crtc->active = false;
>+ crtc->base.enabled = false;
>+
>+ WARN_ON(drm_atomic_set_mode_for_crtc(&crtc_state->uapi, NULL) < 0);
>+ crtc_state->uapi.active = false;
>+ crtc_state->uapi.connector_mask = 0;
>+ crtc_state->uapi.encoder_mask = 0;
> intel_crtc_free_hw_state(crtc_state);
> memset(&crtc_state->hw, 0, sizeof(crtc_state->hw));
>
>- for_each_encoder_on_crtc(crtc->dev, crtc, encoder)
>+ for_each_encoder_on_crtc(&dev_priv->drm, &crtc->base, encoder)
> encoder->base.crtc = NULL;
>
>- intel_fbc_disable(intel_crtc);
>- intel_update_watermarks(intel_crtc);
>- intel_disable_shared_dpll(to_intel_crtc_state(crtc->state));
>+ intel_fbc_disable(crtc);
>+ intel_update_watermarks(crtc);
>+ intel_disable_shared_dpll(crtc_state);
>
>- domains = intel_crtc->enabled_power_domains;
>+ domains = crtc->enabled_power_domains;
> for_each_power_domain(domain, domains)
> intel_display_power_put_unchecked(dev_priv, domain);
>- intel_crtc->enabled_power_domains = 0;
>+ crtc->enabled_power_domains = 0;
>
>- dev_priv->active_pipes &= ~BIT(intel_crtc->pipe);
>- dev_priv->min_cdclk[intel_crtc->pipe] = 0;
>- dev_priv->min_voltage_level[intel_crtc->pipe] = 0;
>+ dev_priv->active_pipes &= ~BIT(pipe);
>+ dev_priv->min_cdclk[pipe] = 0;
>+ dev_priv->min_voltage_level[pipe] = 0;
>
>- bw_state->data_rate[intel_crtc->pipe] = 0;
>- bw_state->num_active_planes[intel_crtc->pipe] = 0;
>+ bw_state->data_rate[pipe] = 0;
>+ bw_state->num_active_planes[pipe] = 0;
> }
>
> /*
>@@ -17240,7 +17241,7 @@ static void intel_sanitize_crtc(struct intel_crtc *crtc,
> /* Adjust the state of the output pipe according to whether we
> * have active connectors/encoders. */
> if (crtc_state->hw.active && !intel_crtc_has_encoders(crtc))
>- intel_crtc_disable_noatomic(&crtc->base, ctx);
>+ intel_crtc_disable_noatomic(crtc, ctx);
>
> if (crtc_state->hw.active || HAS_GMCH(dev_priv)) {
> /*
>--
>2.23.0
>
>_______________________________________________
>Intel-gfx mailing list
>Intel-gfx at lists.freedesktop.org
>https://lists.freedesktop.org/mailman/listinfo/intel-gfx
More information about the Intel-gfx
mailing list