On Mon, 2025-09-08 at 09:51 -0300, Gustavo Sousa wrote: > 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?
Very true. I had more text here, describing the method 1 case below too, but after removing that, this became mostly irrelevant. I'll remove it. > > > 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. Right, I moved this to a fallthrough in a later patch. -- Cheers, Luca.