Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp6925996rwn; Tue, 13 Sep 2022 10:57:55 -0700 (PDT) X-Google-Smtp-Source: AA6agR6o0R+3zixB4zDpDx5rFCpirKOSm34InRGh+wDJezv1P3jbt1d0mfcvotwgLD9H7pKnCDKG X-Received: by 2002:a05:6a00:248b:b0:542:6ae2:24d5 with SMTP id c11-20020a056a00248b00b005426ae224d5mr14630409pfv.65.1663091875105; Tue, 13 Sep 2022 10:57:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663091875; cv=none; d=google.com; s=arc-20160816; b=IcUC3al5ki8u70QJRM8pYfnQzFwkp9bEuJFPsFdtJJW+QzwAbiV992xNZG7ZdvVQg9 LgUkAF2BQQ+y0MSd91Zrmv5pmfHNgC+4IRHb+hu62hKr7KtGHT1JXFf8fmpHDDwFh27l sL6z2MXrKRyvs+ma/CkU8j9w/U0lGi7s8bYvpaZILMWlDxGQuG8iYqEo31+xzEtErDYW vtdQ2gZ6Z6z/XcgTYtGW2Mw8jp1l73rlOMLv9AzlxRn1xNq4zV2njkWhPD5VqhrlAw4+ 8hrUwwCV6PYqL8pw15jemqbHe7yf2QJ31wCSUoi5rhaDtjVg47yCKdr399GCcZolu9IU 2hug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=v7D2AK8HTXd/eGWbSFW61Y+MuHwu8x2MxY0yWEeHKe8=; b=AdziNyRyWscklQtZK99Z0aHaAyTb33N7JSO+dzR6vMtpkzSGfsk74hEFGZXl008di0 i3VQJrIjWAFPaybVBmoHrPiSz8gB6wr7wIFbsetSdZr1/tqfUHqeHDoxgRcUiJiFsr8f zs1es0AA7V1sEhNXngEPiXJ/JnavTMvlhqYYSsBoTRecQKRFQndUrGSXweFK0yoIHmLv VN+M/6YJQbj8nt+hxsSQ8+6ycWunQzvntp6fVc2lmoEFCCz0x7KwHjTZMpHUn8MIivlO XaKvn2KfKqIOwZMEjJbNv2AB6uqH1renMFALaGXerTAcH9MnbdVKJ2yFdhPJhpUXxLyT iifQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=w5o93PNf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q126-20020a634384000000b0042ac5a24f3fsi12841085pga.493.2022.09.13.10.57.43; Tue, 13 Sep 2022 10:57:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=w5o93PNf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231791AbiIMRMA (ORCPT + 99 others); Tue, 13 Sep 2022 13:12:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57170 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232532AbiIMRLc (ORCPT ); Tue, 13 Sep 2022 13:11:32 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1C5339568A; Tue, 13 Sep 2022 09:00:29 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 442CCB80F92; Tue, 13 Sep 2022 14:27:11 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B4F46C433D7; Tue, 13 Sep 2022 14:27:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1663079230; bh=mobJGZFcfs84x6ygQFCoWpjPrj+Z9cYKBuqWlUjkdtg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=w5o93PNfwh1sM9qGO3j/GCe5ttaiCr0evK7ibLMRZpHAZoSmVjKVQ5P/7yYMmur/4 83gzA7wWL0lYuTWHOZ1zmRVLKVXThYrPU0So2sB2wS0Qztv+fltJ0ps3sSV+nh4Wmb 0S2ziRoJ14x8Mu1rfvErm1m5IRfEpAVKKNbcilyE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marcus Folkesson , Andy Shevchenko , Stable@vger.kernel.org, Jonathan Cameron Subject: [PATCH 5.4 027/108] iio: adc: mcp3911: use correct formula for AD conversion Date: Tue, 13 Sep 2022 16:05:58 +0200 Message-Id: <20220913140354.803984066@linuxfoundation.org> X-Mailer: git-send-email 2.37.3 In-Reply-To: <20220913140353.549108748@linuxfoundation.org> References: <20220913140353.549108748@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Marcus Folkesson commit 9e2238e3ae40d371a1130226e0e740aa1601efa6 upstream. The ADC conversion is actually not rail-to-rail but with a factor 1.5. Make use of this factor when calculating actual voltage. Fixes: 3a89b289df5d ("iio: adc: add support for mcp3911") Signed-off-by: Marcus Folkesson Reviewed-by: Andy Shevchenko Link: https://lore.kernel.org/r/20220722130726.7627-4-marcus.folkesson@gmail.com Cc: Signed-off-by: Jonathan Cameron Signed-off-by: Greg Kroah-Hartman --- drivers/iio/adc/mcp3911.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) --- a/drivers/iio/adc/mcp3911.c +++ b/drivers/iio/adc/mcp3911.c @@ -38,8 +38,8 @@ #define MCP3911_CHANNEL(x) (MCP3911_REG_CHANNEL0 + x * 3) #define MCP3911_OFFCAL(x) (MCP3911_REG_OFFCAL_CH0 + x * 6) -/* Internal voltage reference in uV */ -#define MCP3911_INT_VREF_UV 1200000 +/* Internal voltage reference in mV */ +#define MCP3911_INT_VREF_MV 1200 #define MCP3911_REG_READ(reg, id) ((((reg) << 1) | ((id) << 5) | (1 << 0)) & 0xff) #define MCP3911_REG_WRITE(reg, id) ((((reg) << 1) | ((id) << 5) | (0 << 0)) & 0xff) @@ -137,11 +137,18 @@ static int mcp3911_read_raw(struct iio_d *val = ret / 1000; } else { - *val = MCP3911_INT_VREF_UV; + *val = MCP3911_INT_VREF_MV; } - *val2 = 24; - ret = IIO_VAL_FRACTIONAL_LOG2; + /* + * For 24bit Conversion + * Raw = ((Voltage)/(Vref) * 2^23 * Gain * 1.5 + * Voltage = Raw * (Vref)/(2^23 * Gain * 1.5) + */ + + /* val2 = (2^23 * 1.5) */ + *val2 = 12582912; + ret = IIO_VAL_FRACTIONAL; break; }