OSDN Git Service

drm/i915: Make the CRTC state consistent during sanitize-disabling
authorImre Deak <imre.deak@intel.com>
Wed, 10 May 2023 10:31:20 +0000 (13:31 +0300)
committerImre Deak <imre.deak@intel.com>
Tue, 16 May 2023 13:53:45 +0000 (16:53 +0300)
Make sure that the CRTC state is reset correctly, as expected after
disabling the CRTC.

In particular this change will:
- Zero all the CSC blob pointers after intel_crtc_free_hw_state()
  has freed them.
- Zero the shared DPLL and port PLL pointers and clear the
  corresponding CRTC reference flag in the PLL state.
- Reset all the transcoder and pipe fields.

v2:
- Reset fully the CRTC state. (Ville)
- Clear pipe active flags in the DPLL state.

v3:
- Clear only the CRTC reference flag and add a helper for this.
  (Ville)

v4:
- Rebased on previous patch, adding
  intel_unreference_shared_dpll_crtc() separately. (Ville)

Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230510103131.1618266-4-imre.deak@intel.com
drivers/gpu/drm/i915/display/intel_dpll_mgr.c
drivers/gpu/drm/i915/display/intel_dpll_mgr.h
drivers/gpu/drm/i915/display/intel_modeset_setup.c

index 98bde2c..6b2d8a1 100644 (file)
@@ -399,7 +399,7 @@ intel_reference_shared_dpll(struct intel_atomic_state *state,
  *
  * Drop a reference for @pll tracking the end of use of it by @crtc.
  */
-static void
+void
 intel_unreference_shared_dpll_crtc(const struct intel_crtc *crtc,
                                   const struct intel_shared_dpll *pll,
                                   struct intel_shared_dpll_state *shared_dpll_state)
index 3854f1b..ba62eb5 100644 (file)
@@ -341,6 +341,9 @@ int intel_reserve_shared_dplls(struct intel_atomic_state *state,
                               struct intel_encoder *encoder);
 void intel_release_shared_dplls(struct intel_atomic_state *state,
                                struct intel_crtc *crtc);
+void intel_unreference_shared_dpll_crtc(const struct intel_crtc *crtc,
+                                       const struct intel_shared_dpll *pll,
+                                       struct intel_shared_dpll_state *shared_dpll_state);
 void icl_set_active_port_dpll(struct intel_crtc_state *crtc_state,
                              enum icl_port_dpll_id port_dpll_id);
 void intel_update_active_dpll(struct intel_atomic_state *state,
index eefa401..6e55806 100644 (file)
@@ -88,13 +88,14 @@ static void intel_crtc_disable_noatomic(struct intel_crtc *crtc,
        crtc->active = false;
        crtc->base.enabled = false;
 
-       drm_WARN_ON(&i915->drm,
-                   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;
+       if (crtc_state->shared_dpll)
+               intel_unreference_shared_dpll_crtc(crtc,
+                                                  crtc_state->shared_dpll,
+                                                  &crtc_state->shared_dpll->state);
+
+       __drm_atomic_helper_crtc_destroy_state(&crtc_state->uapi);
        intel_crtc_free_hw_state(crtc_state);
-       memset(&crtc_state->hw, 0, sizeof(crtc_state->hw));
+       intel_crtc_state_reset(crtc_state, crtc);
 
        for_each_encoder_on_crtc(&i915->drm, &crtc->base, encoder)
                encoder->base.crtc = NULL;