From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934831AbdEVSUo (ORCPT ); Mon, 22 May 2017 14:20:44 -0400 Received: from mail-lf0-f41.google.com ([209.85.215.41]:34666 "EHLO mail-lf0-f41.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758646AbdEVSUj (ORCPT ); Mon, 22 May 2017 14:20:39 -0400 Subject: Re: [PATCH 2/4] iio: hi8435: avoid garbage event at first enable To: Nikita Yushchenko , Jonathan Cameron , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , Matt Ranostay , Gregor Boirie , Sanchayan Maity References: <20170519144802.14427-1-nikita.yoush@cogentembedded.com> <20170519144802.14427-2-nikita.yoush@cogentembedded.com> Cc: linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, Jeff White , Chris Healy From: Vladimir Barinov Message-ID: <1df453fe-3ea4-a2fb-94e4-7462c2a2fad2@cogentembedded.com> Date: Mon, 22 May 2017 21:20:30 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.4.0 MIME-Version: 1.0 In-Reply-To: <20170519144802.14427-2-nikita.yoush@cogentembedded.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Nikita, On 19.05.2017 17:48, Nikita Yushchenko wrote: > Currently, driver generates events for channels if new reading differs > from previous one. This "previous value" is initialized to zero, which > results into event if value is constant-one. > > Fix that by initializing "previous value" by reading at event enable > time. > > This provides reliable sequence for userspace: > - enable event, > - AFTER THAT read current value, > - AFTER THAT each event will correspond to change. > > Signed-off-by: Nikita Yushchenko > --- > drivers/iio/adc/hi8435.c | 15 +++++++++++++-- > 1 file changed, 13 insertions(+), 2 deletions(-) > > diff --git a/drivers/iio/adc/hi8435.c b/drivers/iio/adc/hi8435.c > index cb8e6342eddf..45a92e3e8f2b 100644 > --- a/drivers/iio/adc/hi8435.c > +++ b/drivers/iio/adc/hi8435.c > @@ -141,10 +141,21 @@ static int hi8435_write_event_config(struct iio_dev *idev, > enum iio_event_direction dir, int state) > { > struct hi8435_priv *priv = iio_priv(idev); > + int ret; > + u32 tmp; > + > + if (state) { > + ret = hi8435_readl(priv, HI8435_SO31_0_REG, &tmp); > + if (ret < 0) > + return ret; > + if (tmp & BIT(chan->channel)) > + priv->event_prev_val |= BIT(chan->channel); > + else > + priv->event_prev_val &= ~BIT(chan->channel); > > - priv->event_scan_mask &= ~BIT(chan->channel); > - if (state) > priv->event_scan_mask |= BIT(chan->channel); > + } else > + priv->event_scan_mask &= ~BIT(chan->channel); > This will race with hi8435_iio_push_event for priv->event_scan_mask. Since you adding raw access then it is reasonable to initialize priv->event_prev_val in hi8435_read_raw. Then use the following sequence for your application: 1. read raw value 2. enable events Regards, Vladimir