]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/i915: Fix WARN_ON condition for cursor plane ddb allocation
authorVandita Kulkarni <vandita.kulkarni@intel.com>
Mon, 16 Dec 2019 08:06:19 +0000 (13:36 +0530)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Mon, 16 Dec 2019 21:17:57 +0000 (23:17 +0200)
In some cases like latency[level]==0, wm[level].res_lines>31,
min_ddb_alloc can be U16_MAX, exclude it from the WARN_ON.

v2: Specify the cases in which we hit U16_MAX, indentation (Ville)

Fixes: a524dd820af6 ("drm/i915: Make sure cursor has enough ddb for the selected wm level")
Suggested-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Vandita Kulkarni <vandita.kulkarni@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191216080619.10945-1-vandita.kulkarni@intel.com
drivers/gpu/drm/i915/intel_pm.c

index 7aa5824b15d2579dd59db78db46bb417ead00e0c..00f9f51876696f06a69a46e69801bf3a46c20a26 100644 (file)
@@ -4312,8 +4312,8 @@ skl_allocate_pipe_ddb(struct intel_crtc_state *crtc_state,
                                &crtc_state->wm.skl.optimal.planes[plane_id];
 
                        if (plane_id == PLANE_CURSOR) {
-                               if (WARN_ON(wm->wm[level].min_ddb_alloc >
-                                           total[PLANE_CURSOR])) {
+                               if (wm->wm[level].min_ddb_alloc > total[PLANE_CURSOR]) {
+                                       WARN_ON(wm->wm[level].min_ddb_alloc != U16_MAX);
                                        blocks = U32_MAX;
                                        break;
                                }