Received: by 10.223.176.5 with SMTP id f5csp2840402wra; Mon, 5 Feb 2018 10:45:03 -0800 (PST) X-Google-Smtp-Source: AH8x225fT/bO1oAuw8M4KiJqA/U/50GKnbjc40z8/BQv0FkWqvKoDh8rWBZc0nvxBEPABwbFjrTB X-Received: by 2002:a17:902:8282:: with SMTP id y2-v6mr23601678pln.75.1517856303091; Mon, 05 Feb 2018 10:45:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517856303; cv=none; d=google.com; s=arc-20160816; b=Luml8FrKaYfVxtMA4bKZQpMsorFkJ8IAU65y5zF8h60rU6pbapIREc9xr5bDaWMic7 XInvBodl+5g+2+6aLBJOQfzryPISdV5RwaXq4oXmFeP/qjgzgRroX3wsZ660Tlx+lP/Q HwfCYI9TQovogOkxM0EQ01MIPt4BrJ7m/Y6ICOHzdDTAvWN496HXwL98Kb6gI5BAZoxX 8uJhddOSeaKdSE+ppdqRTbuQ377IzPFiKl1DoSZZu/h8o+6LwVosWjgP1DnBG8N1Iljd uiEyX5TVmznGFRXQo1uuMMbCIEFOX4OPIxoassSCpZ2O8WGu1dXbj/I9gneq0zB5z04v GVsw== 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=NRnD/sbQbPrUxqLDM9ocaHdMng5izaXY9exfNzxwWoY=; b=Xka1poA7hHSc8f/HXQIij4maVIMIs7KB7siORjEWPo3kqCyBjqNoETLVDl3PFb796i P+C4gHCWMgOI6Cp9Plmp42YMOXUOjB0aaUZgIWSjQmtnWqS2EQTEbUaWnVjFtTERyepg aIix6G5wTIK+phGRzK1mmaclGt0J+tCvbx507xkjEV5VfC6/UnF3zpmrVR9mQ01g+p9C UwXLqp33hqXIgE1s9N8YIb5/gZPMmmXRo0mg6lIX5cjo6z2AwhzIWiInGxnTsRPsK7Ab vrUErWVCRI3yQx+m8M0Hr4xjQnurDzN0LKDS8Pg8vXxM/RzutJFLiSxX35GR+fZ481Zr kNiQ== 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 f80si1226216pfa.111.2018.02.05.10.44.48; Mon, 05 Feb 2018 10:45:03 -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 S1753955AbeBESn0 (ORCPT + 99 others); Mon, 5 Feb 2018 13:43:26 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:53306 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753894AbeBES0Q (ORCPT ); Mon, 5 Feb 2018 13:26:16 -0500 Received: from localhost (unknown [104.132.1.108]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id E0AF9FD0; Mon, 5 Feb 2018 18:26:11 +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 3.18 18/36] hwmon: (pmbus) Use 64bit math for DIRECT format values Date: Mon, 5 Feb 2018 10:23:46 -0800 Message-Id: <20180205182352.530993019@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180205182351.774761393@linuxfoundation.org> References: <20180205182351.774761393@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 3.18-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 @@ -20,6 +20,7 @@ */ #include +#include #include #include #include @@ -443,8 +444,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]; @@ -472,11 +473,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); } /* @@ -588,7 +590,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]; @@ -605,18 +608,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,