]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/msm/dpu: cast crtc_clk calculation to u64 in _dpu_core_perf_calc_clk()
authorZichen Xie <zichenxie0106@gmail.com>
Tue, 29 Oct 2024 19:42:10 +0000 (14:42 -0500)
committerDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Thu, 31 Oct 2024 21:27:07 +0000 (23:27 +0200)
There may be a potential integer overflow issue in
_dpu_core_perf_calc_clk(). crtc_clk is defined as u64, while
mode->vtotal, mode->hdisplay, and drm_mode_vrefresh(mode) are defined as
a smaller data type. The result of the calculation will be limited to
"int" in this case without correct casting. In screen with high
resolution and high refresh rate, integer overflow may happen.
So, we recommend adding an extra cast to prevent potential
integer overflow.

Fixes: c33b7c0389e1 ("drm/msm/dpu: add support for clk and bw scaling for display")
Signed-off-by: Zichen Xie <zichenxie0106@gmail.com>
Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
Patchwork: https://patchwork.freedesktop.org/patch/622206/
Link: https://lore.kernel.org/r/20241029194209.23684-1-zichenxie0106@gmail.com
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
drivers/gpu/drm/msm/disp/dpu1/dpu_core_perf.c

index 68fae048a9a837410eb6051f9af52a6e0c399585..260accc151d4b49383eb6fcaa3ca6616ca283991 100644 (file)
@@ -80,7 +80,7 @@ static u64 _dpu_core_perf_calc_clk(const struct dpu_perf_cfg *perf_cfg,
 
        mode = &state->adjusted_mode;
 
-       crtc_clk = mode->vtotal * mode->hdisplay * drm_mode_vrefresh(mode);
+       crtc_clk = (u64)mode->vtotal * mode->hdisplay * drm_mode_vrefresh(mode);
 
        drm_atomic_crtc_for_each_plane(plane, crtc) {
                pstate = to_dpu_plane_state(plane->state);