]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915: Switch intel_usecs_to_scanlines() to 64bit maths
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Tue, 28 May 2024 18:56:46 +0000 (21:56 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Fri, 31 May 2024 10:43:56 +0000 (13:43 +0300)
Dotclocks can reach ~1GHz these days, so intel_usecs_to_scanlines(),
with its 32bit maths, is currently limited to a few milliseconds.
I want bigger numbers in DSB selftests, so switch over to 64bit
maths.

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

index bf6e74e99f5c5c2206db56b7e810c48ae295151d..54b529bfc93521380cf6cdc3811bcceefd9375da 100644 (file)
@@ -454,8 +454,8 @@ int intel_usecs_to_scanlines(const struct drm_display_mode *adjusted_mode,
        if (!adjusted_mode->crtc_htotal)
                return 1;
 
-       return DIV_ROUND_UP(usecs * adjusted_mode->crtc_clock,
-                           1000 * adjusted_mode->crtc_htotal);
+       return DIV_ROUND_UP_ULL(mul_u32_u32(usecs, adjusted_mode->crtc_clock),
+                               1000 * adjusted_mode->crtc_htotal);
 }
 
 /**