On Fri, Jan 22, 2021 at 05:00:59PM +0800, Yu, Lang wrote:
> Replace "/" with div_u64 for 32-bit arch. On 32-bit arch,
> the use of "/" for 64-bit division will cause build error,
> i.e. "__udivdi3/__divdi3 undefined!".
> 
> Fixes: 27755cdf83f1
> drm/amd/display: Update dcn30_apply_idle_power_optimizations() code
> 
> Signed-off-by: Lang Yu <lang...@amd.com>

Acked-by: Huang Rui <ray.hu...@amd.com>

> ---
>  drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hwseq.c | 12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hwseq.c 
> b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hwseq.c
> index dff83c6a142a..9620fb8a27dc 100644
> --- a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hwseq.c
> +++ b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hwseq.c
> @@ -772,8 +772,8 @@ bool dcn30_apply_idle_power_optimizations(struct dc *dc, 
> bool enable)
>                                                       cursor_cache_enable ? 
> &cursor_attr : NULL)) {
>                               unsigned int v_total = 
> stream->adjust.v_total_max ?
>                                               stream->adjust.v_total_max : 
> stream->timing.v_total;
> -                             unsigned int refresh_hz = (unsigned long long) 
> stream->timing.pix_clk_100hz *
> -                                             100LL / (v_total * 
> stream->timing.h_total);
> +                             unsigned int refresh_hz = div_u64((unsigned 
> long long) stream->timing.pix_clk_100hz *
> +                                             100LL, (v_total * 
> stream->timing.h_total));
>  
>                               /*
>                                * one frame time in microsec:
> @@ -800,8 +800,8 @@ bool dcn30_apply_idle_power_optimizations(struct dc *dc, 
> bool enable)
>                               unsigned int denom = refresh_hz * 6528;
>                               unsigned int stutter_period = 
> dc->current_state->perf_params.stutter_period_us;
>  
> -                             tmr_delay = (((1000000LL + 2 * stutter_period * 
> refresh_hz) *
> -                                             (100LL + 
> dc->debug.mall_additional_timer_percent) + denom - 1) /
> +                             tmr_delay = div_u64(((1000000LL + 2 * 
> stutter_period * refresh_hz) *
> +                                             (100LL + 
> dc->debug.mall_additional_timer_percent) + denom - 1),
>                                               denom) - 64LL;
>  
>                               /* scale should be increased until it fits into 
> 6 bits */
> @@ -815,8 +815,8 @@ bool dcn30_apply_idle_power_optimizations(struct dc *dc, 
> bool enable)
>                                       }
>  
>                                       denom *= 2;
> -                                     tmr_delay = (((1000000LL + 2 * 
> stutter_period * refresh_hz) *
> -                                                     (100LL + 
> dc->debug.mall_additional_timer_percent) + denom - 1) /
> +                                     tmr_delay = div_u64(((1000000LL + 2 * 
> stutter_period * refresh_hz) *
> +                                                     (100LL + 
> dc->debug.mall_additional_timer_percent) + denom - 1),
>                                                       denom) - 64LL;
>                               }
>  
> -- 
> 2.25.1
> 
_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to