Re: [PATCH v4] staging: iio: adc: ad7192: use driver private lock to protect hardware state changes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Oct 7, 2017 at 4:59 PM, Jonathan Cameron <jic23@xxxxxxxxxx> wrote:
> On Fri, 6 Oct 2017 22:58:42 +0530
> Aastha Gupta <aastha.gupta4104@xxxxxxxxx> wrote:
>
>> On Wed, Sep 27, 2017 at 12:01 PM, Aastha Gupta
>> <aastha.gupta4104@xxxxxxxxx> wrote:
>> > The IIO subsystem is redefining iio_dev->mlock to be used by
>> > the IIO core only for protecting device operating mode changes.
>> > ie. Changes between INDIO_DIRECT_MODE, INDIO_BUFFER_* modes.
>> >
>> > In this driver, mlock was being used to protect hardware state
>> > changes.  Replace it with a driver private lock.
>> >
>> > Also, as there are state changes in the ad7192_ write_raw function, a lock
>> > is added to prevent the concurrent state changes.
>> >
>> > Signed-off-by: Aastha Gupta <aastha.gupta4104@xxxxxxxxx>
>> > ---
>> > changes in v4:
>> >         - added comment for mutex
>> >         - improved commit message
>> >  drivers/staging/iio/adc/ad7192.c | 9 +++++++--
>> >  1 file changed, 7 insertions(+), 2 deletions(-)
>> >
>> > diff --git a/drivers/staging/iio/adc/ad7192.c b/drivers/staging/iio/adc/ad7192.c
>> > index d11c6de..c1343ec 100644
>> > --- a/drivers/staging/iio/adc/ad7192.c
>> > +++ b/drivers/staging/iio/adc/ad7192.c
>> > @@ -162,6 +162,7 @@ struct ad7192_state {
>> >         u32                             scale_avail[8][2];
>> >         u8                              gpocon;
>> >         u8                              devid;
>> > +       struct mutex                    lock;   /* protect sensor state */
>> >
>> >         struct ad_sigma_delta           sd;
>> >  };
>> > @@ -463,10 +464,10 @@ static int ad7192_read_raw(struct iio_dev *indio_dev,
>> >         case IIO_CHAN_INFO_SCALE:
>> >                 switch (chan->type) {
>> >                 case IIO_VOLTAGE:
>> > -                       mutex_lock(&indio_dev->mlock);
>> > +                       mutex_lock(&st->lock);
>> >                         *val = st->scale_avail[AD7192_CONF_GAIN(st->conf)][0];
>> >                         *val2 = st->scale_avail[AD7192_CONF_GAIN(st->conf)][1];
>> > -                       mutex_unlock(&indio_dev->mlock);
>> > +                       mutex_unlock(&st->lock);
>> >                         return IIO_VAL_INT_PLUS_NANO;
>> >                 case IIO_TEMP:
>> >                         *val = 0;
>> > @@ -510,6 +511,7 @@ static int ad7192_write_raw(struct iio_dev *indio_dev,
>> >         switch (mask) {
>> >         case IIO_CHAN_INFO_SCALE:
>> >                 ret = -EINVAL;
>> > +               mutex_lock(&st->lock);
>> >                 for (i = 0; i < ARRAY_SIZE(st->scale_avail); i++)
>> >                         if (val2 == st->scale_avail[i][1]) {
>> >                                 ret = 0;
>> > @@ -523,6 +525,7 @@ static int ad7192_write_raw(struct iio_dev *indio_dev,
>> >                                 ad7192_calibrate_all(st);
>> >                                 break;
>> >                         }
>> > +               mutex_unlock(&st->lock);
>> >                 break;
>> >         case IIO_CHAN_INFO_SAMP_FREQ:
>> >                 if (!val) {
>> > @@ -634,6 +637,8 @@ static int ad7192_probe(struct spi_device *spi)
>> >
>> >         st = iio_priv(indio_dev);
>> >
>> > +       mutex_init(&st->lock);
>> > +
>> >         st->avdd = devm_regulator_get(&spi->dev, "avdd");
>> >         if (IS_ERR(st->avdd))
>> >                 return PTR_ERR(st->avdd);
>> > --
>> > 2.7.4
>> >
>>
>> Any update regarding this?
>
> Patch is fine, but Julia had an outstanding question on the commit message.
>
> <snip>
>
>> In this driver, mlock was being used to protect hardware state
>> changes.  Replace it with a driver private lock.
>>
>> Also, as there are state changes in the ad7192_ write_raw function, a lock
>> is added to prevent the concurrent state changes.
>
> Why was it not needed before?
>
> julia
>
> <snip>
>
> Lazy maintainer strategy 15, don't reply to a patch once someone else has
> raised an reasonably question that hasn't been answered ;)
>
> Jonathan
>
>

This was discussed but due to some mistake not everyone was CC'd.
I have attached discussion.

'''
> On 27 Sep 2017 12:37 pm, "Julia Lawall" <julia.lawall@xxxxxxx> wrote:
> >
> > On Wed, 27 Sep 2017, Aastha Gupta wrote:
> >
> > >
> > > On 27 Sep 2017 12:25 pm, "Julia Lawall" <julia.lawall@xxxxxxx> wrote:
> > > >
> > > >
> > > >
> > > > On Wed, 27 Sep 2017, Aastha Gupta wrote:
> > > >
> > > > > The IIO subsystem is redefining iio_dev->mlock to be used by
> > > > > the IIO core only for protecting device operating mode changes.
> > > > > ie. Changes between INDIO_DIRECT_MODE, INDIO_BUFFER_* modes.
> > > > >
> > > > > In this driver, mlock was being used to protect hardware state
> > > > > changes.  Replace it with a driver private lock.
> > > > >
> > > > > Also, as there are state changes in the ad7192_ write_raw function, a
> > > lock
> > > > > is added to prevent the concurrent state changes.
> > > >
> > > > Why was it not needed before?
> > > >
> > > > julia
> > > >
> > >
> > > It was not there in the file but I think it should be included because these
> > > state changes are read by ad7192_read_raw function. So to avoid reading of
> > > invalid state, while writing also there should be a lock.
> >
> > I thought someone told you to merge the patches because the second one was
> > fixing a problem that the first one introduced.  Do you happen to still
> > have that mail?
> >
> > julia
> Yes, But I think that was because in the second patch I was using the same lock that I introduced in the first patch, so he told me to combine those two.

OK

'''
--
To unsubscribe from this list: send the line "unsubscribe linux-iio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux