From: Jonathan Cameron <jic23@kernel.org>
To: Slawomir Stepien <sst@poczta.fm>
Cc: lars@metafoo.de, Michael.Hennerich@analog.com, knaack.h@gmx.de,
pmeerw@pmeerw.net, linux-iio@vger.kernel.org,
gregkh@linuxfoundation.org
Subject: Re: [PATCH v3 1/1] staging: iio: adc: ad7280a: use devm_* APIs
Date: Sun, 28 Oct 2018 12:16:46 +0000 [thread overview]
Message-ID: <20181028121646.5e12814f@archlinux> (raw)
In-Reply-To: <20181023133234.GA9359@x220.localdomain>
On Tue, 23 Oct 2018 15:32:34 +0200
Slawomir Stepien <sst@poczta.fm> wrote:
> On pa=C5=BA 21, 2018 14:26, Jonathan Cameron wrote:
> > On Fri, 19 Oct 2018 20:20:13 +0200
> > Slawomir Stepien <sst@poczta.fm> wrote:
> > =20
> > > devm_* APIs are device managed and make code simpler.
> > >=20
> > > Signed-off-by: Slawomir Stepien <sst@poczta.fm> =20
> >=20
> > Hi Slawomir,
> >=20
> > There are some complexities in using the managed allocators, almost
> > always around possible race conditions. See inline. =20
>=20
> Thank you so much for pointing the problems!
>=20
> > > @@ -692,7 +691,8 @@ static irqreturn_t ad7280_event_handler(int irq, =
void *private)
> > > unsigned int *channels;
> > > int i, ret;
> > > =20
> > > - channels =3D kcalloc(st->scan_cnt, sizeof(*channels), GFP_KERNEL);
> > > + channels =3D devm_kcalloc(&st->spi->dev, st->scan_cnt, sizeof(*chan=
nels),
> > > + GFP_KERNEL);
> > > if (!channels)
> > > return IRQ_HANDLED;
> > > =20
> > > @@ -744,7 +744,7 @@ static irqreturn_t ad7280_event_handler(int irq, =
void *private)
> > > }
> > > =20
> > > out:
> > > - kfree(channels);
> > > + devm_kfree(&st->spi->dev, channels); =20
> >=20
> > Now this I really don't want to see.
> > Using the managed framework is far from free. Please don't do it when t=
he
> > normal path is to free the buffer like this... =20
>=20
> OK
>=20
> > > return IRQ_HANDLED;
> > > }
> > > static int ad7280_remove(struct spi_device *spi)
> > > @@ -958,16 +948,9 @@ static int ad7280_remove(struct spi_device *spi)
> > > struct iio_dev *indio_dev =3D spi_get_drvdata(spi);
> > > struct ad7280_state *st =3D iio_priv(indio_dev);
> > > =20
> > > - if (spi->irq > 0)
> > > - free_irq(spi->irq, indio_dev);
> > > - iio_device_unregister(indio_dev);
> > > -
> > > ad7280_write(st, AD7280A_DEVADDR_MASTER, AD7280A_CONTROL_HB, 1,
> > > AD7280A_CTRL_HB_PWRDN_SW | st->ctrl_hb); =20
> > So here, you need to think very carefully about what the various
> > steps are doing. By moving to devm_iio_device_unregister
> > what difference has it made to the sequence of calls in remove?
> >=20
> > The upshot is you just turned the device off before removing the
> > interfaces which would allow userspace / kernel consumers to
> > access the device. A classic race condition that 'might' open
> > up opportunities for problems.
> >=20
> > Often the reality is that these sorts of races have very minimal
> > impact, but they do break the cardinal rule that code should be
> > obviously right (if possible). Hence you can't do this sort
> > of conversion so simply. You can consider using the devm_add_action
> > approach to ensure the tear down is in the right order though... =20
>=20
> Yes I understand the problem here. I have some questions regarding
> devm_add_action that might solve the problem here:
>=20
> 1. My understanding is that the action has to be added on the devres list=
before
> the devm_iio_device_register call, so during unwinding the action will be=
called
> after the call to devm_iio_device_unreg. Other order will be still not co=
rrect.
> Am I thinking correctly here?
Yes. That's correct.
>=20
> Please note that doing the action from probe is changing the current beha=
viour
> of the driver - we will put the device into power-down software state als=
o from
> probe() (if irq setup fails).
True. In the case an irq being specified but not probing successfully we wi=
ll
fail the probe and put the device into a power down state. However, to my
mind that's the right thing to do anyway. I can't see why we would want
the device powered up having decided to abandon the attempt to load a driver
for it? (am I missing something?)
The more 'interesting' question is why we are registering the interrupts
after iio_device_register in the first place. We have exposed our userspace
interfaces, but not yet an interrupt that I assume has something to do with=
them?
iio_device_register should almost always be the last thing run in probe.
>=20
> 2. devm_iio_device_unregister from what I see could be used here in place=
of
> iio_device_unregister. Maybe that is the best way to go?
>=20
Definitely not this one. The only rare case for manually using the
counter parts to the devm_ setup functions is to replace some data or
configuration rather to manually unwind the steps for some error path.
Thanks,
Jonathan
next prev parent reply other threads:[~2018-10-28 21:01 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-10-19 18:20 [PATCH v3 1/1] staging: iio: adc: ad7280a: use devm_* APIs Slawomir Stepien
2018-10-21 13:26 ` Jonathan Cameron
2018-10-23 13:32 ` Slawomir Stepien
2018-10-28 12:16 ` Jonathan Cameron [this message]
2018-10-29 16:47 ` Slawomir Stepien
2018-11-03 10:18 ` Jonathan Cameron
2018-11-09 18:23 ` Slawomir Stepien
2018-11-11 15:27 ` Jonathan Cameron
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20181028121646.5e12814f@archlinux \
--to=jic23@kernel.org \
--cc=Michael.Hennerich@analog.com \
--cc=gregkh@linuxfoundation.org \
--cc=knaack.h@gmx.de \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=pmeerw@pmeerw.net \
--cc=sst@poczta.fm \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox