Received: by 10.223.176.5 with SMTP id f5csp988918wra; Fri, 2 Feb 2018 09:18:56 -0800 (PST) X-Google-Smtp-Source: AH8x224gOd5Y4lqKNlgMBmPGT1/mKSnJa58BFFRYxhEw8NcmrN44f0gY39ZKWqRiYUcTgy5RSMvy X-Received: by 10.99.174.7 with SMTP id q7mr31675956pgf.170.1517591936548; Fri, 02 Feb 2018 09:18:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517591936; cv=none; d=google.com; s=arc-20160816; b=Lee82gv30k+LfaiPpDwLF8ygtvN2EYlDP2G+M1Flwzo4dU665Vwed/rA6cUabz1q3C oHu41oALpYm4JdNxtgcekAGR4yAz6ZidWzoMaIrTzzkw+kDP9D0Yrn8E6FyOlpcnGKnb EkUS1gG5nLdIxDktx3rM1UU08Hi4622N0rk/j7HY2LRZ7PBzHAyYq1uUB2xQtWhp7372 RRGBbawGYCwYEqS5fsNfnpf7VyItdqKwnYj102aNyu2LavSmej99yIX1LNztf2Fmhdl8 Hyz6+Jh9Q6dxESkOnCmxQrxlsqm93pDGWmjKPPmJlpMYom5Syxliq8qbkrRiM52Qk4nQ 6uRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=7XbTVWiSOrdzLAJrSKlnBU0cNrBpoedcMd0p1ZzakY0=; b=B7Eh0Pd/BynVyWjEFYVuvqpbTyeU0RorUFk+fUb+BMoULwJcmAypjKhN4tCQps+CNV oLHjsZVdHpZT5zPc9dlAGW0B00fiqGuhVJZ5OZrT6M4JJHzc+R/Agn/H0bqQ859nixHJ 9ZhPEg7pG1MKJhVCQ5G96YxMMeuqYkHWz74Xk/Vx0SvklO6szhUGIKgJt8WTJPkLQHd9 bqqvLRHu9VPH+ru5jiDRxTkQ4UIexD1u9UcH9k9o9qxlNZK1lH9dwArtOQwipjSFRBxn vM3ra14/EItjiTUWQ6w0aUDSvFHUTwpczQRINEWb7CS99kTMTwgwu7Z/Lirc0OdYmBUH BmTA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a8-v6si48949ple.375.2018.02.02.09.18.42; Fri, 02 Feb 2018 09:18:56 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753911AbeBBRSG (ORCPT + 99 others); Fri, 2 Feb 2018 12:18:06 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:38560 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752802AbeBBRLL (ORCPT ); Fri, 2 Feb 2018 12:11:11 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 0C66AEF7; Fri, 2 Feb 2018 17:11:10 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Robert Lippert , Guenter Roeck , Sasha Levin Subject: [PATCH 4.14 091/156] hwmon: (pmbus) Use 64bit math for DIRECT format values Date: Fri, 2 Feb 2018 17:57:52 +0100 Message-Id: <20180202140844.363195508@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180202140840.242829545@linuxfoundation.org> References: <20180202140840.242829545@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Robert Lippert [ Upstream commit bd467e4eababe4c04272c1e646f066db02734c79 ] Power values in the 100s of watt range can easily blow past 32bit math limits when processing everything in microwatts. Use 64bit math instead to avoid these issues on common 32bit ARM BMC platforms. Fixes: 442aba78728e ("hwmon: PMBus device driver") Signed-off-by: Robert Lippert Signed-off-by: Guenter Roeck Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/hwmon/pmbus/pmbus_core.c | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) --- a/drivers/hwmon/pmbus/pmbus_core.c +++ b/drivers/hwmon/pmbus/pmbus_core.c @@ -21,6 +21,7 @@ #include #include +#include #include #include #include @@ -499,8 +500,8 @@ static long pmbus_reg2data_linear(struct static long pmbus_reg2data_direct(struct pmbus_data *data, struct pmbus_sensor *sensor) { - long val = (s16) sensor->data; - long m, b, R; + s64 b, val = (s16)sensor->data; + s32 m, R; m = data->info->m[sensor->class]; b = data->info->b[sensor->class]; @@ -528,11 +529,12 @@ static long pmbus_reg2data_direct(struct R--; } while (R < 0) { - val = DIV_ROUND_CLOSEST(val, 10); + val = div_s64(val + 5LL, 10L); /* round closest */ R++; } - return (val - b) / m; + val = div_s64(val - b, m); + return clamp_val(val, LONG_MIN, LONG_MAX); } /* @@ -656,7 +658,8 @@ static u16 pmbus_data2reg_linear(struct static u16 pmbus_data2reg_direct(struct pmbus_data *data, struct pmbus_sensor *sensor, long val) { - long m, b, R; + s64 b, val64 = val; + s32 m, R; m = data->info->m[sensor->class]; b = data->info->b[sensor->class]; @@ -673,18 +676,18 @@ static u16 pmbus_data2reg_direct(struct R -= 3; /* Adjust R and b for data in milli-units */ b *= 1000; } - val = val * m + b; + val64 = val64 * m + b; while (R > 0) { - val *= 10; + val64 *= 10; R--; } while (R < 0) { - val = DIV_ROUND_CLOSEST(val, 10); + val64 = div_s64(val64 + 5LL, 10L); /* round closest */ R++; } - return val; + return (u16)clamp_val(val64, S16_MIN, S16_MAX); } static u16 pmbus_data2reg_vid(struct pmbus_data *data,