Received: by 10.223.176.5 with SMTP id f5csp972864wra; Fri, 2 Feb 2018 09:05:06 -0800 (PST) X-Google-Smtp-Source: AH8x226YUW+3f4gThm2z7NvoeRJS91ZDrcz10iMQzFwj1BRpWR0mkWNznjGkB7HgWPOl5yA9jTJN X-Received: by 10.101.69.7 with SMTP id n7mr32294758pgq.62.1517591106130; Fri, 02 Feb 2018 09:05:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517591106; cv=none; d=google.com; s=arc-20160816; b=DGoNgAHw8ELzF89c/ZetNVuea/+KP9TH1J/+DoderJuNDlri+YEjlPIDr7b9ouIlgm N3O1woRSmYweVLPj829sTMFtyCqETrIJ03JiIWiRFvXE+rbfqxH25ptS+MAYyctsEkPM 3aeOGk9AUUxf/D07jyxNwsXri/ndAMZDy9GXrrxQ02FcxztMBQ+k2jVWjgJLpX3XriFT wHKKSBO2W5DP5vNAu01ULp35w+KAcnyfdTwnrKchonNsNVHLg6xuTbNSjBr4yxW9VEgI bHu2JCMRYA1PI6970Vd6togWfRKU+p1QeL3GkAVbMnN97hQEclfFaGkLE8VKIgQue7T2 a2Ww== 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=PCmAVYRWNvg0ylMSbLtXoLsn6rPyxKSNNSXivjHgtyQ=; b=SS1HvjykfjUy22u28RRKaKMYux9CbkMVe6+fZD+lH6cC0lK6ii1u00JQgkjzU/wFL+ KNYCu3uuJquQkCP2bZH4awhzZNR9IVecO1mFegE36LZ4Ia2zLvZ70FFV4p3a8lLmOCre HNcGT73REWe/RprH6gRULf2SEGd5TQiKqXfZnGFz8i0+SPLCb6lDgEBFta7XN2leDjwl YgdWfHJwyWUZT6GPHjcRnsHI70HndX3ZFlsYgwdnhGqtDKk+omXwqK9RZPsNyWzeDG+J zw2qXyZvxHBXDrmRe6n4g0i1RuHsWCNsgrt2hY2nfnk/ijJWVjIZIA4GOro1hr3hG36I hDiw== 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 s19-v6si2105765plp.116.2018.02.02.09.04.51; Fri, 02 Feb 2018 09:05:06 -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 S1752803AbeBBRDI (ORCPT + 99 others); Fri, 2 Feb 2018 12:03:08 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:35042 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752148AbeBBRBL (ORCPT ); Fri, 2 Feb 2018 12:01: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 D4B67E5E; Fri, 2 Feb 2018 17:01: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.4 43/67] hwmon: (pmbus) Use 64bit math for DIRECT format values Date: Fri, 2 Feb 2018 17:58:12 +0100 Message-Id: <20180202140820.188438063@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180202140815.091718203@linuxfoundation.org> References: <20180202140815.091718203@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.4-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 @@ -476,8 +477,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]; @@ -505,11 +506,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); } /* @@ -629,7 +631,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]; @@ -646,18 +649,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,