From: Jonathan Cameron <jic23@kernel.org>
To: Sachin Kamat <sachin.kamat@linaro.org>
Cc: linux-iio@vger.kernel.org, lars@metafoo.de, jic23@cam.ac.uk
Subject: Re: [PATCH 12/14] iio: dac: ad5791: Use devm_* APIs
Date: Mon, 19 Aug 2013 20:35:40 +0100 [thread overview]
Message-ID: <5212738C.9010305@kernel.org> (raw)
In-Reply-To: <1376912305-6423-12-git-send-email-sachin.kamat@linaro.org>
On 08/19/13 12:38, Sachin Kamat wrote:
> devm_* APIs are device managed and make code simpler.
>
> Signed-off-by: Sachin Kamat <sachin.kamat@linaro.org>
Applied to the togreg branch of iio.git
> ---
> drivers/iio/dac/ad5791.c | 35 +++++++++--------------------------
> 1 file changed, 9 insertions(+), 26 deletions(-)
>
> diff --git a/drivers/iio/dac/ad5791.c b/drivers/iio/dac/ad5791.c
> index 97c1e5d..ce74589 100644
> --- a/drivers/iio/dac/ad5791.c
> +++ b/drivers/iio/dac/ad5791.c
> @@ -349,17 +349,15 @@ static int ad5791_probe(struct spi_device *spi)
> struct ad5791_state *st;
> int ret, pos_voltage_uv = 0, neg_voltage_uv = 0;
>
> - indio_dev = iio_device_alloc(sizeof(*st));
> - if (indio_dev == NULL) {
> - ret = -ENOMEM;
> - goto error_ret;
> - }
> + indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
> + if (!indio_dev)
> + return -ENOMEM;
> st = iio_priv(indio_dev);
> - st->reg_vdd = regulator_get(&spi->dev, "vdd");
> + st->reg_vdd = devm_regulator_get(&spi->dev, "vdd");
> if (!IS_ERR(st->reg_vdd)) {
> ret = regulator_enable(st->reg_vdd);
> if (ret)
> - goto error_put_reg_pos;
> + return ret;
>
> ret = regulator_get_voltage(st->reg_vdd);
> if (ret < 0)
> @@ -368,11 +366,11 @@ static int ad5791_probe(struct spi_device *spi)
> pos_voltage_uv = ret;
> }
>
> - st->reg_vss = regulator_get(&spi->dev, "vss");
> + st->reg_vss = devm_regulator_get(&spi->dev, "vss");
> if (!IS_ERR(st->reg_vss)) {
> ret = regulator_enable(st->reg_vss);
> if (ret)
> - goto error_put_reg_neg;
> + goto error_disable_reg_pos;
>
> ret = regulator_get_voltage(st->reg_vss);
> if (ret < 0)
> @@ -428,19 +426,9 @@ static int ad5791_probe(struct spi_device *spi)
> error_disable_reg_neg:
> if (!IS_ERR(st->reg_vss))
> regulator_disable(st->reg_vss);
> -error_put_reg_neg:
> - if (!IS_ERR(st->reg_vss))
> - regulator_put(st->reg_vss);
> -
> error_disable_reg_pos:
> if (!IS_ERR(st->reg_vdd))
> regulator_disable(st->reg_vdd);
> -error_put_reg_pos:
> - if (!IS_ERR(st->reg_vdd))
> - regulator_put(st->reg_vdd);
> - iio_device_free(indio_dev);
> -error_ret:
> -
> return ret;
> }
>
> @@ -450,16 +438,11 @@ static int ad5791_remove(struct spi_device *spi)
> struct ad5791_state *st = iio_priv(indio_dev);
>
> iio_device_unregister(indio_dev);
> - if (!IS_ERR(st->reg_vdd)) {
> + if (!IS_ERR(st->reg_vdd))
> regulator_disable(st->reg_vdd);
> - regulator_put(st->reg_vdd);
> - }
>
> - if (!IS_ERR(st->reg_vss)) {
> + if (!IS_ERR(st->reg_vss))
> regulator_disable(st->reg_vss);
> - regulator_put(st->reg_vss);
> - }
> - iio_device_free(indio_dev);
>
> return 0;
> }
>
next prev parent reply other threads:[~2013-08-19 18:35 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-19 11:38 [PATCH 01/14] iio: dac: ad5064: Use devm_* APIs Sachin Kamat
2013-08-19 11:38 ` [PATCH 02/14] iio: dac: ad5360: " Sachin Kamat
2013-08-19 19:23 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 03/14] iio: dac: ad5380: " Sachin Kamat
2013-08-19 19:23 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 04/14] iio: dac: ad5421: " Sachin Kamat
2013-08-19 19:24 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 05/14] iio: dac: ad5446: " Sachin Kamat
2013-08-19 19:25 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 06/14] iio: dac: ad5449: " Sachin Kamat
2013-08-19 19:26 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 07/14] iio: dac: ad5504: " Sachin Kamat
2013-08-19 19:27 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 08/14] iio: dac: ad5624r_spi: " Sachin Kamat
2013-08-19 19:28 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 09/14] iio: dac: ad5686: " Sachin Kamat
2013-08-19 19:30 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 10/14] iio: dac: ad5755: Use devm_iio_device_alloc Sachin Kamat
2013-08-19 19:33 ` Jonathan Cameron
2013-08-20 13:47 ` Sachin Kamat
2013-08-19 11:38 ` [PATCH 11/14] iio: dac: ad5764: Use devm_* APIs Sachin Kamat
2013-08-19 19:33 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 12/14] iio: dac: ad5791: " Sachin Kamat
2013-08-19 19:35 ` Jonathan Cameron [this message]
2013-08-19 11:38 ` [PATCH 13/14] iio: dac: ad7303: " Sachin Kamat
2013-08-19 19:36 ` Jonathan Cameron
2013-08-19 11:38 ` [PATCH 14/14] iio: dac: max517: Use devm_iio_device_alloc Sachin Kamat
2013-08-19 19:38 ` Jonathan Cameron
2013-08-19 19:20 ` [PATCH 01/14] iio: dac: ad5064: Use devm_* APIs 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=5212738C.9010305@kernel.org \
--to=jic23@kernel.org \
--cc=jic23@cam.ac.uk \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=sachin.kamat@linaro.org \
/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;
as well as URLs for NNTP newsgroup(s).