From: Jonathan Cameron <jic23@kernel.org>
To: Rodrigo Alencar via B4 Relay
<devnull+rodrigo.alencar.analog.com@kernel.org>
Cc: rodrigo.alencar@analog.com, linux-iio@vger.kernel.org,
linux-kernel@vger.kernel.org,
Stefan Popa <stefan.popa@analog.com>,
Jonathan Cameron <jic23@cam.ac.uk>,
Greg Kroah-Hartman <gregkh@suse.de>,
Michael Auchter <michael.auchter@ni.com>,
Lars-Peter Clausen <lars@metafoo.de>,
Michael Hennerich <Michael.Hennerich@analog.com>,
David Lechner <dlechner@baylibre.com>,
Andy Shevchenko <andy@kernel.org>
Subject: Re: [PATCH v5 04/12] iio: dac: ad5686: fix powerdown control on dual-channel devices
Date: Tue, 5 May 2026 12:16:52 +0100 [thread overview]
Message-ID: <20260505121652.5f7ac73d@jic23-huawei> (raw)
In-Reply-To: <20260501-ad5686-fixes-v5-4-0b2f45488418@analog.com>
On Fri, 01 May 2026 10:14:57 +0100
Rodrigo Alencar via B4 Relay <devnull+rodrigo.alencar.analog.com@kernel.org> wrote:
> From: Rodrigo Alencar <rodrigo.alencar@analog.com>
>
> Fix powerdown control by using a proper bit shift for the powerdown mask
> values. During initialization, powerdown bits are initialized so that
> unused bits are set to 1 and the correct bit shift is used. Dual-channel
> devices use one-hot encoding in the address and that reflects on the
> position of the powerdown bits, which are not channel-index based
> for that case. Quad-channel devices also use one-hot encoding for the
> channel address but the result of log2(address) coincides with the channel
> index value. The issue was introduced when first adding support for
> dual-channel devices, which overlooked powerdown control differences.
>
> Fixes: 7dc8faeab3e3 ("iio: dac: ad5686: add support for AD5338R")
> Signed-off-by: Rodrigo Alencar <rodrigo.alencar@analog.com>
Just for reference I think the sashiko bug report on this one is spurious
due to -fwrapv (signed integer overflow being defined for kernel).
It is non obvious though! So this one is fine but the guard() I'm suggesting
in the previous patch review to protect get_powerdown_mode() against races
would add some mess to this one so I won't apply it until that's addressed
(or argued against!)
> ---
> drivers/iio/dac/ad5686.c | 40 ++++++++++++++++++++++++++++++----------
> 1 file changed, 30 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/iio/dac/ad5686.c b/drivers/iio/dac/ad5686.c
> index 69358dd66cbc..c607251b82a0 100644
> --- a/drivers/iio/dac/ad5686.c
> +++ b/drivers/iio/dac/ad5686.c
> @@ -25,24 +25,35 @@ static const char * const ad5686_powerdown_modes[] = {
> "three_state"
> };
>
> +static inline unsigned int ad5686_pd_mask_shift(const struct iio_chan_spec *chan)
> +{
> + if (chan->channel == chan->address)
> + return chan->channel * 2;
> +
> + /* one-hot encoding is used in dual/quad channel devices */
> + return __ffs(chan->address) * 2;
> +}
> +
> static int ad5686_get_powerdown_mode(struct iio_dev *indio_dev,
> const struct iio_chan_spec *chan)
> {
> + unsigned int shift = ad5686_pd_mask_shift(chan);
> struct ad5686_state *st = iio_priv(indio_dev);
>
> - return ((st->pwr_down_mode >> (chan->channel * 2)) & 0x3) - 1;
> + return ((st->pwr_down_mode >> shift) & 0x3) - 1;
> }
>
> static int ad5686_set_powerdown_mode(struct iio_dev *indio_dev,
> const struct iio_chan_spec *chan,
> unsigned int mode)
> {
> + unsigned int shift = ad5686_pd_mask_shift(chan);
> struct ad5686_state *st = iio_priv(indio_dev);
>
> guard(mutex)(&st->lock);
>
> - st->pwr_down_mode &= ~(0x3 << (chan->channel * 2));
> - st->pwr_down_mode |= ((mode + 1) << (chan->channel * 2));
> + st->pwr_down_mode &= ~(0x3 << shift);
The bug reported is that 0x3 is singed and shift can be 30 which
would overflow. However that should be fine in the kernel.
Bit odd though so maybe force that 0x3 to be unsigned.
> + st->pwr_down_mode |= (mode + 1) << shift;
>
> return 0;
> }
next prev parent reply other threads:[~2026-05-05 11:17 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-01 9:14 [PATCH v5 00/12] Fixes and cleanups for the AD5686 IIO driver Rodrigo Alencar via B4 Relay
2026-05-01 9:14 ` [PATCH v5 01/12] iio: dac: ad5686: fix ref bit initialization for single-channel parts Rodrigo Alencar via B4 Relay
2026-05-05 11:06 ` Jonathan Cameron
2026-05-01 9:14 ` [PATCH v5 02/12] iio: dac: ad5686: fix input raw value check Rodrigo Alencar via B4 Relay
2026-05-05 11:08 ` Jonathan Cameron
2026-05-01 9:14 ` [PATCH v5 03/12] iio: dac: ad5686: acquire lock when doing powerdown control Rodrigo Alencar via B4 Relay
2026-05-05 11:05 ` Jonathan Cameron
2026-05-05 11:16 ` Rodrigo Alencar
2026-05-05 12:09 ` Jonathan Cameron
2026-05-01 9:14 ` [PATCH v5 04/12] iio: dac: ad5686: fix powerdown control on dual-channel devices Rodrigo Alencar via B4 Relay
2026-05-05 11:16 ` Jonathan Cameron [this message]
2026-05-01 9:14 ` [PATCH v5 05/12] iio: dac: ad5686: refactor include headers Rodrigo Alencar via B4 Relay
2026-05-01 9:14 ` [PATCH v5 06/12] iio: dac: ad5686: remove redundant register definition Rodrigo Alencar via B4 Relay
2026-05-01 9:15 ` [PATCH v5 07/12] iio: dac: ad5686: drop enum id Rodrigo Alencar via B4 Relay
2026-05-01 9:15 ` [PATCH v5 08/12] iio: dac: ad5686: add of_match table to the spi driver Rodrigo Alencar via B4 Relay
2026-05-01 9:15 ` [PATCH v5 09/12] iio: dac: ad5686: add helpers to handle powerdown masks Rodrigo Alencar via B4 Relay
2026-05-04 8:25 ` Andy Shevchenko
2026-05-01 9:15 ` [PATCH v5 10/12] iio: dac: ad5686: add control_sync() for single-channel devices Rodrigo Alencar via B4 Relay
2026-05-04 8:29 ` Andy Shevchenko
2026-05-01 9:15 ` [PATCH v5 11/12] iio: dac: ad5686: cleanup doc header of local structs Rodrigo Alencar via B4 Relay
2026-05-01 9:15 ` [PATCH v5 12/12] iio: dac: ad5686: create bus ops struct Rodrigo Alencar via B4 Relay
2026-05-05 12:06 ` 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=20260505121652.5f7ac73d@jic23-huawei \
--to=jic23@kernel.org \
--cc=Michael.Hennerich@analog.com \
--cc=andy@kernel.org \
--cc=devnull+rodrigo.alencar.analog.com@kernel.org \
--cc=dlechner@baylibre.com \
--cc=gregkh@suse.de \
--cc=jic23@cam.ac.uk \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=michael.auchter@ni.com \
--cc=rodrigo.alencar@analog.com \
--cc=stefan.popa@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