The quilt patch titled Subject: include/linux/math.h: fix mult_frac() multiple argument evaluation bug has been removed from the -mm tree. Its filename was fix-mult_frac-multiple-argument-evaluation-bug.patch This patch was dropped because an updated version will be merged ------------------------------------------------------ From: Alexey Dobriyan <adobriyan@xxxxxxxxx> Subject: include/linux/math.h: fix mult_frac() multiple argument evaluation bug Date: Fri, 19 May 2023 23:24:54 +0300 mult_frac() evaluates _all_ arguments multiple times in the body. Clarify comment while I'm at it. Link: https://lkml.kernel.org/r/f522ad25-f899-4526-abc4-da35868b6a8b@p183 Signed-off-by: Alexey Dobriyan <adobriyan@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- include/linux/math.h | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) --- a/include/linux/math.h~fix-mult_frac-multiple-argument-evaluation-bug +++ a/include/linux/math.h @@ -118,17 +118,17 @@ __STRUCT_FRACT(s32) __STRUCT_FRACT(u32) #undef __STRUCT_FRACT -/* - * Multiplies an integer by a fraction, while avoiding unnecessary - * overflow or loss of precision. - */ -#define mult_frac(x, numer, denom)( \ -{ \ - typeof(x) quot = (x) / (denom); \ - typeof(x) rem = (x) % (denom); \ - (quot * (numer)) + ((rem * (numer)) / (denom)); \ -} \ -) +/* Calculate "x * n / d" without unnecessary overflow or loss of precision. */ +#define mult_frac(x, n, d) \ +({ \ + typeof(x) x_ = (x); \ + typeof(n) n_ = (n); \ + typeof(d) d_ = (d); \ + \ + typeof(x) q = x_ / d_; \ + typeof(x) r = x_ % d_; \ + q * n_ + r * n_ / d_; \ +}) #define sector_div(a, b) do_div(a, b) _ Patches currently in -mm which might be from adobriyan@xxxxxxxxx are add-intptr_t.patch