From: Jonathan Cameron <jic23@kernel.org>
To: Julien Stephan <jstephan@baylibre.com>
Cc: "Lars-Peter Clausen" <lars@metafoo.de>,
"Michael Hennerich" <Michael.Hennerich@analog.com>,
"Nuno Sá" <nuno.sa@analog.com>,
"David Lechner" <dlechner@baylibre.com>,
"Jonathan Corbet" <corbet@lwn.net>,
linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org,
linux-doc@vger.kernel.org
Subject: Re: [PATCH RFC v2 1/4] iio: adc: ad7380: do not use iio_device_claim_direct_scoped anymore
Date: Sat, 28 Dec 2024 13:49:34 +0000 [thread overview]
Message-ID: <20241228134934.38e69020@jic23-huawei> (raw)
In-Reply-To: <20241224-ad7380-add-alert-support-v2-1-7c89b2bf7cb3@baylibre.com>
On Tue, 24 Dec 2024 10:34:30 +0100
Julien Stephan <jstephan@baylibre.com> wrote:
> Rollback and remove the scoped version of iio_dvice_claim_direct_mode.
>
> Signed-off-by: Julien Stephan <jstephan@baylibre.com>
> ---
> drivers/iio/adc/ad7380.c | 89 ++++++++++++++++++++++++++++--------------------
> 1 file changed, 53 insertions(+), 36 deletions(-)
>
> diff --git a/drivers/iio/adc/ad7380.c b/drivers/iio/adc/ad7380.c
> index 4f32cb22f140442b831dc9a4f275e88e4ab2388e..4e26e0e7ac1d5a1c4c67118dbc34f2921fc171a4 100644
> --- a/drivers/iio/adc/ad7380.c
> +++ b/drivers/iio/adc/ad7380.c
> @@ -675,15 +675,21 @@ static const struct regmap_config ad7380_regmap_config = {
> static int ad7380_debugfs_reg_access(struct iio_dev *indio_dev, u32 reg,
> u32 writeval, u32 *readval)
> {
> - iio_device_claim_direct_scoped(return -EBUSY, indio_dev) {
> - struct ad7380_state *st = iio_priv(indio_dev);
> + struct ad7380_state *st = iio_priv(indio_dev);
> + int ret;
>
> - if (readval)
> - return regmap_read(st->regmap, reg, readval);
> - else
> - return regmap_write(st->regmap, reg, writeval);
> - }
> - unreachable();
> + ret = iio_device_claim_direct_mode(indio_dev);
> + if (ret)
> + return ret;
> +
> + if (readval)
> + ret = regmap_read(st->regmap, reg, readval);
> + else
> + ret = regmap_write(st->regmap, reg, writeval);
> +
> + iio_device_release_direct_mode(indio_dev);
> +
> + return ret;
> }
>
> /*
> @@ -920,6 +926,7 @@ static int ad7380_read_raw(struct iio_dev *indio_dev,
> {
> struct ad7380_state *st = iio_priv(indio_dev);
> const struct iio_scan_type *scan_type;
> + int ret;
>
> scan_type = iio_get_current_scan_type(indio_dev, chan);
>
> @@ -928,11 +935,16 @@ static int ad7380_read_raw(struct iio_dev *indio_dev,
>
> switch (info) {
> case IIO_CHAN_INFO_RAW:
> - iio_device_claim_direct_scoped(return -EBUSY, indio_dev) {
> - return ad7380_read_direct(st, chan->scan_index,
> - scan_type, val);
> - }
> - unreachable();
> + ret = iio_device_claim_direct_mode(indio_dev);
> + if (ret)
> + return ret;
> +
> + ret = ad7380_read_direct(st, chan->scan_index,
> + scan_type, val);
> +
> + iio_device_release_direct_mode(indio_dev);
> +
> + return ret;
> case IIO_CHAN_INFO_SCALE:
> /*
> * According to the datasheet, the LSB size is:
> @@ -1024,31 +1036,36 @@ static int ad7380_write_raw(struct iio_dev *indio_dev,
> /* always enable resolution boost when oversampling is enabled */
> boost = osr > 0 ? 1 : 0;
>
> - iio_device_claim_direct_scoped(return -EBUSY, indio_dev) {
> - ret = regmap_update_bits(st->regmap,
> - AD7380_REG_ADDR_CONFIG1,
> - AD7380_CONFIG1_OSR | AD7380_CONFIG1_RES,
> - FIELD_PREP(AD7380_CONFIG1_OSR, osr) |
> - FIELD_PREP(AD7380_CONFIG1_RES, boost));
> + ret = iio_device_claim_direct_mode(indio_dev);
> + if (ret)
> + return ret;
>
> - if (ret)
> - return ret;
> + ret = regmap_update_bits(st->regmap,
> + AD7380_REG_ADDR_CONFIG1,
> + AD7380_CONFIG1_OSR | AD7380_CONFIG1_RES,
> + FIELD_PREP(AD7380_CONFIG1_OSR, osr) |
> + FIELD_PREP(AD7380_CONFIG1_RES, boost));
>
> - st->oversampling_ratio = val;
> - st->resolution_boost_enabled = boost;
> -
> - /*
> - * Perform a soft reset. This will flush the oversampling
> - * block and FIFO but will maintain the content of the
> - * configurable registers.
> - */
> - return regmap_update_bits(st->regmap,
> - AD7380_REG_ADDR_CONFIG2,
> - AD7380_CONFIG2_RESET,
> - FIELD_PREP(AD7380_CONFIG2_RESET,
> - AD7380_CONFIG2_RESET_SOFT));
> - }
> - unreachable();
> + if (ret)
> + goto err;
> +
> + st->oversampling_ratio = val;
> + st->resolution_boost_enabled = boost;
> +
> + /*
> + * Perform a soft reset. This will flush the oversampling
> + * block and FIFO but will maintain the content of the
> + * configurable registers.
> + */
> + ret = regmap_update_bits(st->regmap,
> + AD7380_REG_ADDR_CONFIG2,
> + AD7380_CONFIG2_RESET,
> + FIELD_PREP(AD7380_CONFIG2_RESET,
> + AD7380_CONFIG2_RESET_SOFT));
> +err:
Labels within switch statements can become hard to maintainer / read.
Id' suggest factoring out the bits between claim and release as a single
__ad7380_write_oversample() or something along those lines.
Otherwise looks good to me and thanks for doing this.
Jonathan
> + iio_device_release_direct_mode(indio_dev);
> +
> + return ret;
> default:
> return -EINVAL;
> }
>
next prev parent reply other threads:[~2024-12-28 13:49 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-24 9:34 [PATCH RFC v2 0/4] iio: adc: ad7380: add alert support Julien Stephan
2024-12-24 9:34 ` [PATCH RFC v2 1/4] iio: adc: ad7380: do not use iio_device_claim_direct_scoped anymore Julien Stephan
2024-12-27 8:43 ` Uwe Kleine-König
2024-12-28 13:51 ` Jonathan Cameron
2024-12-28 13:49 ` Jonathan Cameron [this message]
2024-12-24 9:34 ` [PATCH RFC v2 2/4] iio: adc: ad7380: enable regmap cache Julien Stephan
2024-12-27 8:48 ` Uwe Kleine-König
2024-12-28 14:07 ` Jonathan Cameron
2024-12-28 14:02 ` Jonathan Cameron
2024-12-24 9:34 ` [PATCH RFC v2 3/4] iio: adc: ad7380: add alert support Julien Stephan
2024-12-27 9:39 ` Uwe Kleine-König
2024-12-28 14:24 ` Jonathan Cameron
2025-01-06 15:29 ` David Lechner
2025-01-07 8:51 ` Julien Stephan
2025-01-11 12:51 ` Jonathan Cameron
2025-01-12 11:40 ` Jonathan Cameron
2024-12-24 9:34 ` [PATCH RFC v2 4/4] docs: iio: " Julien Stephan
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=20241228134934.38e69020@jic23-huawei \
--to=jic23@kernel.org \
--cc=Michael.Hennerich@analog.com \
--cc=corbet@lwn.net \
--cc=dlechner@baylibre.com \
--cc=jstephan@baylibre.com \
--cc=lars@metafoo.de \
--cc=linux-doc@vger.kernel.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=nuno.sa@analog.com \
/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