Quoting Luca Coelho (2025-09-08 04:35:34-03:00)
>Make the code a bit clearer by using a switch-case to check the tiling
>mode in skl_compute_plane_wm(), because all the possible states and
>the calculations they use are explicitly handled.
>
>Signed-off-by: Luca Coelho <luciano.coe...@intel.com>
>---
> drivers/gpu/drm/i915/display/skl_watermark.c | 24 +++++++++++++++++---
> 1 file changed, 21 insertions(+), 3 deletions(-)
>
>diff --git a/drivers/gpu/drm/i915/display/skl_watermark.c 
>b/drivers/gpu/drm/i915/display/skl_watermark.c
>index dd4bed02c3c0..21f8d52ec1d2 100644
>--- a/drivers/gpu/drm/i915/display/skl_watermark.c
>+++ b/drivers/gpu/drm/i915/display/skl_watermark.c
>@@ -1833,21 +1833,39 @@ static void skl_compute_plane_wm(const struct 
>intel_crtc_state *crtc_state,
>                                  latency,
>                                  wp->plane_blocks_per_line);
> 
>-        if (wp->tiling == WM_TILING_Y_FAMILY) {
>+        switch (wp->tiling) {
>+        case WM_TILING_Y_FAMILY:
>                 selected_result = max_fixed16(method2, wp->y_tile_minimum);
>-        } else {
>+                break;
>+
>+        case WM_TILING_LINEAR:
>+        case WM_TILING_X_TILED:
>+                /*
>+                 * Special case for unrealistically small horizontal
>+                 * total with plane downscaling.
>+                 */
>                 if ((wp->cpp * crtc_state->hw.pipe_mode.crtc_htotal /
>                      wp->dbuf_block_size < 1) &&
>-                     (wp->plane_bytes_per_line / wp->dbuf_block_size < 1)) {
>+                    (wp->plane_bytes_per_line / wp->dbuf_block_size < 1)) {
>                         selected_result = method2;
>                 } else if (latency >= wp->linetime_us) {
>+                        /*
>+                         * With display version 9, we use the minimum
>+                         * of both methods.
>+                         */

Hm... Isn't this saying what is already clear in the code below?

>                         if (DISPLAY_VER(display) == 9)
>                                 selected_result = min_fixed16(method1, 
> method2);
>                         else
>                                 selected_result = method2;
>                 } else {
>+                        /* everything else with linear/X-tiled uses method 1 
>*/
>                         selected_result = method1;
>                 }
>+                break;
>+
>+        default:
>+                drm_err(display->drm, "Invalid tiling mode\n", wp->tiling);
>+                break;

If we decide to go with the enumeration solution, I think we should
change this into a warning and use some default behavior here (perhaps
WM_TILING_LINEAR?). Otherwise, selected_result would be used
uninitialized.

--
Gustavo Sousa

>         }
> 
>         blocks = fixed16_to_u32_round_up(selected_result);
>-- 
>2.50.1
>

Reply via email to