Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp3056735ybe; Sun, 15 Sep 2019 06:39:49 -0700 (PDT) X-Google-Smtp-Source: APXvYqxS2JkO1MwotvRgqKrySrsRrtCvcmuFeFSgQt+JDj1gYO08/OZXvQBcKska7fdJT1VTV28x X-Received: by 2002:a17:906:31c6:: with SMTP id f6mr12793623ejf.41.1568554789640; Sun, 15 Sep 2019 06:39:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568554789; cv=none; d=google.com; s=arc-20160816; b=DUYAk8NZ7Rab1nBsIM72FbyrsrO6cLMrcCtd8NeMQZi4GKxkkwtgW+ohtXDg1ZP1GA YQKncVzO8JRO8xD7bWrAlBYK5WtNvjabIDTJGRJSbcVh4v9iaapIyzddyIZ0I+jhRMVO QiVr4S2DYQUvTO0ClUHGbuzJZF2ctzLA934Rr3vLe2XHMWKABmcGnJdg/8bDOT/pd356 zKDogLPKN7cWLJG/LeH7rjkGbYSWYoAl4DG+5JErjvjWG4t8xe7efABeqntByxar0VwK e2z74E2qW0ZKdekZIvemk/zQ07IVJyxEYlJx3H98Uvpn+ARHmVxIzSo+bnoeWyBrpPDb n1SA== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=MkKBFREPM7yaN6/rX+J0iTalPNf8YIZGSiqwlisbjfQ=; b=kB1s5P2SPm6U69154dXi9vN4srIQaUtZtmZHIiZ/ZcHi5NKF9RwggtV+gt30oiwdSk lX/Ske3irL/xV5DexI+6zwXHJB5DnE65sSfClnlc1tkOpplWXi+blBmDxgStNd6RkCW2 WsratHn092C2m641jS1R12ZLf1ybYLpae1FxxbozakhS1Dz0UQeYhEvS89N0+w6/helD qPv51MR+mPbCAJnn5Zlc6yeJ4oSTvLLl9inlC6wkj0wy+O5YJXIvsmHFj0PlOy2eHcMw RocsIfuHIHe/f8ZzA1cr6ohPCAKoDYMb5o+7AF5Drde3VP/4F9w2DkhkTe0t0/e9wfY4 KPsg== 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 k24si1284152ejz.284.2019.09.15.06.39.25; Sun, 15 Sep 2019 06:39:49 -0700 (PDT) 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 S1730646AbfIOMzs (ORCPT + 99 others); Sun, 15 Sep 2019 08:55:48 -0400 Received: from saturn.retrosnub.co.uk ([46.235.226.198]:58130 "EHLO saturn.retrosnub.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726268AbfIOMzs (ORCPT ); Sun, 15 Sep 2019 08:55:48 -0400 Received: from archlinux (cpc149474-cmbg20-2-0-cust94.5-4.cable.virginm.net [82.4.196.95]) by saturn.retrosnub.co.uk (Postfix; Retrosnub mail submission) with ESMTPSA id 68DE29E7ACD; Sun, 15 Sep 2019 13:55:46 +0100 (BST) Date: Sun, 15 Sep 2019 13:55:43 +0100 From: Jonathan Cameron To: Andreas Klinger Cc: knaack.h@gmx.de, lars@metafoo.de, pmeerw@pmeerw.net, linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 1/3] iio: adc: hx711: fix bug in sampling of data Message-ID: <20190915135543.3811a974@archlinux> In-Reply-To: <20190915135326.69551618@archlinux> References: <20190909123720.qdew2c4evxd6dpyk@arbad> <20190915135326.69551618@archlinux> X-Mailer: Claws Mail 3.17.4 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 15 Sep 2019 13:53:26 +0100 Jonathan Cameron wrote: > On Mon, 9 Sep 2019 14:37:21 +0200 > Andreas Klinger wrote: > > > Fix bug in sampling function hx711_cycle() when interrupt occures while > > PD_SCK is high. If PD_SCK is high for at least 60 us power down mode of > > the sensor is entered which in turn leads to a wrong measurement. > > > > Switch off interrupts during a PD_SCK high period and move query of DOUT > > to the latest point of time which is at the end of PD_SCK low period. > > > > This bug exists in the driver since it's initial addition. The more > > interrupts on the system the higher is the probability that it happens. > > > > Fixes: c3b2fdd0ea7e ("iio: adc: hx711: Add IIO driver for AVIA HX711") > > > > Signed-off-by: Andreas Klinger > > Applied to the fixes-togreg branch of iio.git and marked for stable. > > Thanks, I should have waited for my local tests to finish. This result in val being unused, so I've removed it. Thanks, Jonathan > > Jonathan > > > --- > > drivers/iio/adc/hx711.c | 9 +++++---- > > 1 file changed, 5 insertions(+), 4 deletions(-) > > > > diff --git a/drivers/iio/adc/hx711.c b/drivers/iio/adc/hx711.c > > index 88c7fe15003b..0678964dbd21 100644 > > --- a/drivers/iio/adc/hx711.c > > +++ b/drivers/iio/adc/hx711.c > > @@ -101,13 +101,14 @@ struct hx711_data { > > static int hx711_cycle(struct hx711_data *hx711_data) > > { > > int val; > > + unsigned long flags; > > > > /* > > * if preempted for more then 60us while PD_SCK is high: > > * hx711 is going in reset > > * ==> measuring is false > > */ > > - preempt_disable(); > > + local_irq_save(flags); > > gpiod_set_value(hx711_data->gpiod_pd_sck, 1); > > > > /* > > @@ -117,7 +118,6 @@ static int hx711_cycle(struct hx711_data *hx711_data) > > */ > > ndelay(hx711_data->data_ready_delay_ns); > > > > - val = gpiod_get_value(hx711_data->gpiod_dout); > > /* > > * here we are not waiting for 0.2 us as suggested by the datasheet, > > * because the oscilloscope showed in a test scenario > > @@ -125,7 +125,7 @@ static int hx711_cycle(struct hx711_data *hx711_data) > > * and 0.56 us for PD_SCK low on TI Sitara with 800 MHz > > */ > > gpiod_set_value(hx711_data->gpiod_pd_sck, 0); > > - preempt_enable(); > > + local_irq_restore(flags); > > > > /* > > * make it a square wave for addressing cases with capacitance on > > @@ -133,7 +133,8 @@ static int hx711_cycle(struct hx711_data *hx711_data) > > */ > > ndelay(hx711_data->data_ready_delay_ns); > > > > - return val; > > + /* sample as late as possible */ > > + return gpiod_get_value(hx711_data->gpiod_dout); > > } > > > > static int hx711_read(struct hx711_data *hx711_data) >