]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
drm/i915: Compute clocks earlier
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Wed, 7 Sep 2022 09:10:48 +0000 (12:10 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Thu, 8 Sep 2022 11:21:03 +0000 (14:21 +0300)
Do the DPLL computation before fastset checks. This should
allow us to get rid of all that horrible fuzzy clock handling
for fastsets. Who knows how many bugs there are caused by our
state not actually matching what the hardware will generate.

Reviewed-by: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220907091057.11572-9-ville.syrjala@linux.intel.com
drivers/gpu/drm/i915/display/intel_display.c

index d5649bb5cd187bb2b17ffa1ad48bebb8e8e435e3..0d068a2a365c932a495c47d88f312eb29ca29973 100644 (file)
@@ -2691,6 +2691,10 @@ static int intel_crtc_compute_config(struct intel_atomic_state *state,
                intel_atomic_get_new_crtc_state(state, crtc);
        int ret;
 
+       ret = intel_dpll_crtc_compute_clock(state, crtc);
+       if (ret)
+               return ret;
+
        ret = intel_crtc_compute_pipe_src(crtc_state);
        if (ret)
                return ret;
@@ -6895,10 +6899,6 @@ static int intel_atomic_check(struct drm_device *dev,
                if (intel_crtc_needs_modeset(new_crtc_state)) {
                        any_ms = true;
 
-                       ret = intel_dpll_crtc_compute_clock(state, crtc);
-                       if (ret)
-                               goto fail;
-
                        intel_release_shared_dplls(state, crtc);
                        continue;
                }