From: Javi Merino Date: Wed, 6 Apr 2016 18:30:18 +0000 (+0100) Subject: UPSTREAM: thermal: power_allocator: req_range multiplication should be a 64 bit type X-Git-Tag: firefly_0821_release~2656 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8985e0cc58a4a8075cd709291914749f432c271e;p=firefly-linux-kernel-4.4.55.git UPSTREAM: thermal: power_allocator: req_range multiplication should be a 64 bit type req_range is declared as a u64 to cope with overflows in the multiplication of two u32. As both req_power and power_range are u32, we need to make sure the multiplication is done with u64 types. Change-Id: I1aea92f12e48338be2681a9b2ba84756b6cc8cf8 Reported-by: Dan Carpenter Cc: Zhang Rui Cc: Eduardo Valentin Signed-off-by: Javi Merino Signed-off-by: Eduardo Valentin Signed-off-by: Finley Xiao (cherry picked from commit f9d038144a171d42e057143b247ff7a12a5b06f5) --- diff --git a/drivers/thermal/power_allocator.c b/drivers/thermal/power_allocator.c index 1246aa6fcab0..2f1a863a8e15 100644 --- a/drivers/thermal/power_allocator.c +++ b/drivers/thermal/power_allocator.c @@ -301,7 +301,7 @@ static void divvy_up_power(u32 *req_power, u32 *max_power, int num_actors, capped_extra_power = 0; extra_power = 0; for (i = 0; i < num_actors; i++) { - u64 req_range = req_power[i] * power_range; + u64 req_range = (u64)req_power[i] * power_range; granted_power[i] = DIV_ROUND_CLOSEST_ULL(req_range, total_req_power);