From: Simon Glass Date: Thu, 14 Jan 2021 03:29:45 +0000 (-0700) Subject: x86: tsc_timer: Correct overflow in __udelay() X-Git-Tag: v2025.01-rc5-pxa1908~2030^2~13 X-Git-Url: http://git.dujemihanovic.xyz/html/static/%7B%7B%20.Permalink%20%7D%7D?a=commitdiff_plain;h=9edf20f15649cda83214b3b6dc90ca9acff45abb;p=u-boot.git x86: tsc_timer: Correct overflow in __udelay() At present long delays such as msleep(2000) can cause an overflow in this function. There is no need for this, since it already uses a 64-bit int. Add a cast to correct this. Signed-off-by: Simon Glass Reviewed-by: Bin Meng --- diff --git a/drivers/timer/tsc_timer.c b/drivers/timer/tsc_timer.c index 706d52b830..7d0fc66cc7 100644 --- a/drivers/timer/tsc_timer.c +++ b/drivers/timer/tsc_timer.c @@ -372,7 +372,7 @@ void __udelay(unsigned long usec) u64 now = get_ticks(); u64 stop; - stop = now + usec * get_tbclk_mhz(); + stop = now + (u64)usec * get_tbclk_mhz(); while ((int64_t)(stop - get_ticks()) > 0) #if defined(CONFIG_QEMU) && defined(CONFIG_SMP)