lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250727133135.385fa7c5@jic23-huawei>
Date: Sun, 27 Jul 2025 13:31:35 +0100
From: Jonathan Cameron <jic23@...nel.org>
To: David Lechner <dlechner@...libre.com>
Cc: Michael Hennerich <Michael.Hennerich@...log.com>, Nuno Sá
 <nuno.sa@...log.com>, Andy Shevchenko <andy@...nel.org>, Uwe
 Kleine-König <u.kleine-koenig@...libre.com>, Jonathan
 Cameron <Jonathan.Cameron@...wei.com>, linux-iio@...r.kernel.org,
 linux-kernel@...r.kernel.org
Subject: Re: [PATCH] iio: adc: ad7124: fix channel lookup in syscalib
 functions

On Sat, 26 Jul 2025 11:28:48 -0500
David Lechner <dlechner@...libre.com> wrote:

> Fix possible incorrect channel lookup in the syscalib functions by using
> the correct channel address instead of the channel number.
> 
> In the ad7124 driver, the channel field of struct iio_chan_spec is the
> input pin number of the positive input of the channel. This can be, but
> is not always the same as the index in the channels array. The correct
> index in the channels array is stored in the address field (and also
> scan_index). We use the address field to perform the correct lookup.
> 
> Fixes: 47036a03a303 ("iio: adc: ad7124: Implement internal calibration at probe time")
> Signed-off-by: David Lechner <dlechner@...libre.com>
Seems fine to me and i'll queue it up, but I would welcome another set of
eyes on this one.

Thanks,

Jonathan

> ---
>  drivers/iio/adc/ad7124.c | 14 +++++++-------
>  1 file changed, 7 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/iio/adc/ad7124.c b/drivers/iio/adc/ad7124.c
> index 9808df2e92424283a86e9c105492c7447d071e44..4d8c6bafd1c3171054c72a0d2b13d6b1afc4e51a 100644
> --- a/drivers/iio/adc/ad7124.c
> +++ b/drivers/iio/adc/ad7124.c
> @@ -849,7 +849,7 @@ enum {
>  static int ad7124_syscalib_locked(struct ad7124_state *st, const struct iio_chan_spec *chan)
>  {
>  	struct device *dev = &st->sd.spi->dev;
> -	struct ad7124_channel *ch = &st->channels[chan->channel];
> +	struct ad7124_channel *ch = &st->channels[chan->address];
>  	int ret;
>  
>  	if (ch->syscalib_mode == AD7124_SYSCALIB_ZERO_SCALE) {
> @@ -865,8 +865,8 @@ static int ad7124_syscalib_locked(struct ad7124_state *st, const struct iio_chan
>  		if (ret < 0)
>  			return ret;
>  
> -		dev_dbg(dev, "offset for channel %d after zero-scale calibration: 0x%x\n",
> -			chan->channel, ch->cfg.calibration_offset);
> +		dev_dbg(dev, "offset for channel %lu after zero-scale calibration: 0x%x\n",
> +			chan->address, ch->cfg.calibration_offset);
>  	} else {
>  		ch->cfg.calibration_gain = st->gain_default;
>  
> @@ -880,8 +880,8 @@ static int ad7124_syscalib_locked(struct ad7124_state *st, const struct iio_chan
>  		if (ret < 0)
>  			return ret;
>  
> -		dev_dbg(dev, "gain for channel %d after full-scale calibration: 0x%x\n",
> -			chan->channel, ch->cfg.calibration_gain);
> +		dev_dbg(dev, "gain for channel %lu after full-scale calibration: 0x%x\n",
> +			chan->address, ch->cfg.calibration_gain);
>  	}
>  
>  	return 0;
> @@ -924,7 +924,7 @@ static int ad7124_set_syscalib_mode(struct iio_dev *indio_dev,
>  {
>  	struct ad7124_state *st = iio_priv(indio_dev);
>  
> -	st->channels[chan->channel].syscalib_mode = mode;
> +	st->channels[chan->address].syscalib_mode = mode;
>  
>  	return 0;
>  }
> @@ -934,7 +934,7 @@ static int ad7124_get_syscalib_mode(struct iio_dev *indio_dev,
>  {
>  	struct ad7124_state *st = iio_priv(indio_dev);
>  
> -	return st->channels[chan->channel].syscalib_mode;
> +	return st->channels[chan->address].syscalib_mode;
>  }
>  
>  static const struct iio_enum ad7124_syscalib_mode_enum = {
> 
> ---
> base-commit: e4d9886ad25adae72f38f2b12f41649b101581ae
> change-id: 20250726-iio-adc-ad7124-fix-channel-lookup-in-syscalib-e28c933ead2a
> 
> Best regards,


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ