Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2659708imj; Mon, 11 Feb 2019 06:36:54 -0800 (PST) X-Google-Smtp-Source: AHgI3IY/TJnoP2aSb0agevkyW/F86Hx52JJ4/wMhuW2u9NlZeXd/iYYzSumhX5y0el06g+mpc1wS X-Received: by 2002:a63:2b03:: with SMTP id r3mr1012129pgr.1.1549895814505; Mon, 11 Feb 2019 06:36:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549895814; cv=none; d=google.com; s=arc-20160816; b=qAf9rj+HrNtkexhz6++ddRjdpWAqS1rwBCf38c25LVMjQ00xKX9yMVs1rNV08dGxxi tQTj/ojkuIJou5SDz12p9+58hw5nm1v4C51BiWURkjDvv9QkOeIqCYzOGMCLcVn4thXe OvPJ7SvgXQ8R7sHaeiTX4anjKVI2sxxoRAxoRv1SBt2gqUsNkFpjKnDn76DEeEUhHGrP MklZKbbUU5lAK/S5L6HZqUqKj3BVRt+OwiaSFVpM0cspSADI0SxRsiEcyNiOzDf676ok XsbHj0+tm1ak+6AHT9yoSYUEfSEth/oyyZv0Dm+PngIluGIwrIks4fBXbhNqeyFhI4Vy VoGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ahS6AbuMWxVq01v/2iNRwgGlse3KAP3gzINYcvsKv2g=; b=wRNyJQvhl7uouH4pgCxZCHSOcD97oLiA05QVQX92k7W8HnLWeJzM8kbA5379vT8gbD N7/f0+zdy4Q2Qwe5Y4yn2fFinG31Qw12SbybkMNfWRcGOdsx78mpxy0dfuV2cupfLIWE Iaq+GOWf8Bs8kx58iXpelK14tEfiyytg76MuauaVvZtpuQ+0LX7nFs1CytJWaiPrQ7o/ 0a7smxn5FC23XCbu4XkMfic2PtlkdrufHDxBQwgoUTcL1tJCcxb4VOx6AZFikLySQ+0C 4/97PD+jpSrTYAf7DpQFvLOGrj3VSpaJxHysRdIX7+Mt5GKqNVcqPesqjpNQrK0Bx48b V+4g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cE30sRyZ; 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 j22si9829086pfi.252.2019.02.11.06.36.37; Mon, 11 Feb 2019 06:36:54 -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; dkim=pass header.i=@kernel.org header.s=default header.b=cE30sRyZ; 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 S1731107AbfBKOfp (ORCPT + 99 others); Mon, 11 Feb 2019 09:35:45 -0500 Received: from mail.kernel.org ([198.145.29.99]:44370 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731076AbfBKOfi (ORCPT ); Mon, 11 Feb 2019 09:35:38 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9FB4620700; Mon, 11 Feb 2019 14:35:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1549895738; bh=E3fT51L7YF4Cqj+aCsb8x+Eq5msbVWATHLj/2M5L07E=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cE30sRyZ974jgaTbd4HXpIh4XTHTQg+5/Knqb8ip3VxX50VTujMCFbH0x/L+vosqb AACATugIMkAEyoON6A1yxhTtZF7fIkLcby/e0VK8p3ARZxB56WRdrfc9brYorA1U7C NlH1RmqhN9rCo9xR/OJVc9BdywfGCVwRfQIOXUS8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Laxman Dewangan , Bjorn Andersson , Eduardo Valentin , Sasha Levin Subject: [PATCH 4.20 279/352] thermal: generic-adc: Fix adc to temp interpolation Date: Mon, 11 Feb 2019 15:18:26 +0100 Message-Id: <20190211141904.721757286@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190211141846.543045703@linuxfoundation.org> References: <20190211141846.543045703@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.20-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 9d216211fded20fff301d0317af3238d8383634c ] First correct the edge case to return the last element if we're outside the range, rather than at the last element, so that interpolation is not omitted for points between the two last entries in the table. Then correct the formula to perform linear interpolation based the two points surrounding the read ADC value. The indices for temp are kept as "hi" and "lo" to pair with the adc indices, but there's no requirement that the temperature is provided in descendent order. mult_frac() is used to prevent issues with overflowing the int. Cc: Laxman Dewangan Signed-off-by: Bjorn Andersson Signed-off-by: Eduardo Valentin Signed-off-by: Sasha Levin --- drivers/thermal/thermal-generic-adc.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/drivers/thermal/thermal-generic-adc.c b/drivers/thermal/thermal-generic-adc.c index bf1c628d4a7a..e22fc60ad36d 100644 --- a/drivers/thermal/thermal-generic-adc.c +++ b/drivers/thermal/thermal-generic-adc.c @@ -26,7 +26,7 @@ struct gadc_thermal_info { static int gadc_thermal_adc_to_temp(struct gadc_thermal_info *gti, int val) { - int temp, adc_hi, adc_lo; + int temp, temp_hi, temp_lo, adc_hi, adc_lo; int i; for (i = 0; i < gti->nlookup_table; i++) { @@ -36,13 +36,17 @@ static int gadc_thermal_adc_to_temp(struct gadc_thermal_info *gti, int val) if (i == 0) { temp = gti->lookup_table[0]; - } else if (i >= (gti->nlookup_table - 1)) { + } else if (i >= gti->nlookup_table) { temp = gti->lookup_table[2 * (gti->nlookup_table - 1)]; } else { adc_hi = gti->lookup_table[2 * i - 1]; adc_lo = gti->lookup_table[2 * i + 1]; - temp = gti->lookup_table[2 * i]; - temp -= ((val - adc_lo) * 1000) / (adc_hi - adc_lo); + + temp_hi = gti->lookup_table[2 * i - 2]; + temp_lo = gti->lookup_table[2 * i]; + + temp = temp_hi + mult_frac(temp_lo - temp_hi, val - adc_hi, + adc_lo - adc_hi); } return temp; -- 2.19.1