Re: [PATCH] staging: iio: ad9832: Use devm_iio_device_register

From: Jonathan Cameron
Date: Sun Aug 03 2014 - 09:23:12 EST




On August 3, 2014 11:45:00 AM GMT+01:00, Julia Lawall <julia.lawall@xxxxxxx> wrote:
>
>
>On Sun, 3 Aug 2014, Jonathan Cameron wrote:
>
>>
>>
>> On August 3, 2014 10:56:58 AM GMT+01:00, Himangi Saraogi
><himangi774@xxxxxxxxx> wrote:
>> >This patch introduces the use of devm_iio_device_register and does
>away
>> >with the unregister in the remove function.
>> >
>> And changes the resulting ordering so the regulator disable occurs
>before the user
>> space interface has been removed by the unregister.
>>
>> Please be very wary of using devm_iio_register. It is only correct if
>the remove function does nothing else.
>
>I wonder if there could be a way to document these constraints?
Perhaps though the simple rule of not doing anything that results in the remove sequence
not being the mirror image of the probe covers most cases. Whilst there are safe
ways to break this rule they make the code less obviously correct and so arguably
should not be used anyway.
>
>julia
>
>> Jonathan
>> >Signed-off-by: Himangi Saraogi <himangi774@xxxxxxxxx>
>> >Acked-by: Julia Lawall <julia.lawall@xxxxxxx>
>> >---
>> > drivers/staging/iio/frequency/ad9832.c | 3 +--
>> > 1 file changed, 1 insertion(+), 2 deletions(-)
>> >
>> >diff --git a/drivers/staging/iio/frequency/ad9832.c
>> >b/drivers/staging/iio/frequency/ad9832.c
>> >index cf68159..8a72c78 100644
>> >--- a/drivers/staging/iio/frequency/ad9832.c
>> >+++ b/drivers/staging/iio/frequency/ad9832.c
>> >@@ -304,7 +304,7 @@ static int ad9832_probe(struct spi_device *spi)
>> > if (ret)
>> > goto error_disable_reg;
>> >
>> >- ret = iio_device_register(indio_dev);
>> >+ ret = devm_iio_device_register(&spi->dev, indio_dev);
>> > if (ret)
>> > goto error_disable_reg;
>> >
>> >@@ -322,7 +322,6 @@ static int ad9832_remove(struct spi_device *spi)
>> > struct iio_dev *indio_dev = spi_get_drvdata(spi);
>> > struct ad9832_state *st = iio_priv(indio_dev);
>> >
>> >- iio_device_unregister(indio_dev);
>> > if (!IS_ERR(st->reg))
>> > regulator_disable(st->reg);
>> >
>>
>> --
>> Sent from my Android phone with K-9 Mail. Please excuse my brevity.
>>

--
Sent from my Android phone with K-9 Mail. Please excuse my brevity.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/