From: Andy Shevchenko <andriy.shevchenko@intel.com>
To: Jorge Marques <gastmaier@gmail.com>
Cc: "Jorge Marques" <jorge.marques@analog.com>,
"Lars-Peter Clausen" <lars@metafoo.de>,
"Michael Hennerich" <Michael.Hennerich@analog.com>,
"Jonathan Cameron" <jic23@kernel.org>,
"David Lechner" <dlechner@baylibre.com>,
"Nuno Sá" <nuno.sa@analog.com>,
"Andy Shevchenko" <andy@kernel.org>,
"Rob Herring" <robh@kernel.org>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>,
"Jonathan Corbet" <corbet@lwn.net>,
"Linus Walleij" <linus.walleij@linaro.org>,
"Bartosz Golaszewski" <brgl@bgdev.pl>,
linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org,
linux-gpio@vger.kernel.org
Subject: Re: [PATCH v2 3/9] iio: adc: Add support for ad4062
Date: Fri, 28 Nov 2025 21:25:50 +0200 [thread overview]
Message-ID: <aSn3PthKIvFAhDS6@smile.fi.intel.com> (raw)
In-Reply-To: <zryqws2h2i4duejczo2rptwhlzhile7fa7brriqh2hmtarwjxn@cr2cyzymwpav>
On Fri, Nov 28, 2025 at 07:50:02PM +0100, Jorge Marques wrote:
> On Thu, Nov 27, 2025 at 10:58:24AM +0200, Andy Shevchenko wrote:
> > On Wed, Nov 26, 2025 at 12:40:00PM +0100, Jorge Marques wrote:
> > > On Mon, Nov 24, 2025 at 12:20:57PM +0200, Andy Shevchenko wrote:
> > > > On Mon, Nov 24, 2025 at 10:18:02AM +0100, Jorge Marques wrote:
Please, remove the context you are agree with or which has no need
to be answered, it helps to parse and reply.
...
> > > > > +static int ad4062_calc_sampling_frequency(int fosc, unsigned int n_avg)
> > > > > +{
> > > > > + /* See datasheet page 31 */
> > > > > + u64 duration = div_u64((u64)(n_avg - 1) * NSEC_PER_SEC, fosc) + AD4062_TCONV_NS;
> > > > > +
> > > > > + return DIV_ROUND_UP_ULL(NSEC_PER_SEC, duration);
> > > >
> > > > Why u64?
> > > >
> > > > The DIV_ROUND_UP_ULL() seems an overkill here. Or do you expect duration be
> > > > more than 4 billions?
> > > >
> > > This is necessary since at fosc 111 Hz and avg 4096 it does take longer
> > > than 4 seconds, even though I do timeout after 1 seconds in the raw
> > > acquisition.
> >
> > Values above NSEC_PER_SEC+1 do not make sense (it will return 0),
> > and that fits u32. Can you refactor to avoid 64-bit arithmetics?
>
> Ok, any frequency lower than 1 Hz does not make sense.
Depends on the cases, we have sub-Hz sensors or some other stuff.
So, "...does not make sense in _this_ case." That's what I implied.
> static int ad4062_calc_sampling_frequency(int fosc, unsigned int oversamp_ratio)
Shouldn't fosc be unsigned?
> {
> /* See datasheet page 31 */
It's fine, but better to add a formula here or more information about
the calculations done in the function.
> u32 period = NSEC_PER_SEC / fosc;
period_ns ?
(We usually add units to this kind of variables for better understanding
of the calculations)
> u32 n_avg = BIT(oversamp_ratio) - 1;
>
> /* Result is less than 1 Hz */
> if (n_avg >= fosc)
> return 1;
+ blank line.
> return NSEC_PER_SEC / (n_avg * period + AD4062_TCONV_NS);
> }
LGTM, thanks!
> > > > > +}
...
> > > static int ad4062_set_chan_calibscale(struct ad4062_state *st, int gain_int,
> > > int gain_frac)
> > > {
> > > u32 gain;
> > > int ret;
> > >
> > > if (gain_int < 0 || gain_frac < 0)
> > > return -EINVAL;
> > >
> > > gain = gain_int * MICRO + gain_frac;
> > > if (gain > 1999970)
> >
> > But this magic should be changed to what you explained to me
> > (as in 0xffff/0x8000 with the proper precision, and this
> > can be done in 32-bit space).
> >
> > Or even better
> >
> > if (gain_int < 0 || gain_int > 1)
> > return -EINVAL;
> >
> > if (gain_int == 1 && gain_frac > 0x7fff) // did I get this right?
> > return -EINVAL;
> gain_frac would be 999999 max, or 999970 for the limit that fits in the
> register after the math. I think > 1.999.970 is self explanatory.
On the place of unprepared reader this is a complete magic number without
scale, without understanding where it came from, etc.
So, can you define it as a derivative from the other constants and with
a comment perhaps?
> > > return -EINVAL;
> > >
> > > put_unaligned_be16(DIV_ROUND_CLOSEST_ULL((u64)gain * AD4062_MON_VAL_MIDDLE_POINT,
> > > MICRO),
> >
> > ...with temporary variable at minimum.
> >
> > But again, I still don't see the need for 64-bit space.
>
> Well, by dividing mon_val and micro values by a common divisor the
> operation fit in 32-bits:
>
> static int ad4062_set_chan_calibscale(struct ad4062_state *st, int gain_int,
> int gain_frac)
> {
/* Divide numerator and denumerator by known great common divider */
> const u32 mon_val = AD4062_MON_VAL_MIDDLE_POINT / 64;
> const u32 micro = MICRO / 64;
Yep, I suggested the same in another patch under review (not yours) for
the similar cases where we definitely may easily avoid overflow.
Alternatively you can use gcd().
> const u32 gain = gain_int * MICRO + gain_frac;
> int ret;
>
> if (gain_int < 0 || gain_frac < 0)
> return -EINVAL;
>
> if (gain > 1999970)
> return -EINVAL;
>
> put_unaligned_be16(DIV_ROUND_CLOSEST(gain * mon_val, micro), st->buf.bytes);
>
> ret = regmap_bulk_write(st->regmap, AD4062_REG_MON_VAL,
> &st->buf.be16, sizeof(st->buf.be16));
> if (ret)
> return ret;
>
> /* Enable scale if gain is not equal to one */
> return regmap_update_bits(st->regmap, AD4062_REG_ADC_CONFIG,
> AD4062_REG_ADC_CONFIG_SCALE_EN_MSK,
> FIELD_PREP(AD4062_REG_ADC_CONFIG_SCALE_EN_MSK,
> !(gain_int == 1 && gain_frac == 0)));
Btw, I think you can move this check up and save in a temporary variable which
might affect the binary size of the compiled object as accesses to the gain_int
and gain_frac will be grouped in the same place with potential of the reusing
the CPU register(s)..
> }
> > > st->buf.bytes);
> > >
> > > ret = regmap_bulk_write(st->regmap, AD4062_REG_MON_VAL,
> > > &st->buf.be16, sizeof(st->buf.be16));
> > > if (ret)
> > > return ret;
> > >
> > > /* Enable scale if gain is not equal to one */
> > > return regmap_update_bits(st->regmap, AD4062_REG_ADC_CONFIG,
> > > AD4062_REG_ADC_CONFIG_SCALE_EN_MSK,
> > > FIELD_PREP(AD4062_REG_ADC_CONFIG_SCALE_EN_MSK,
> > > !(gain_int == 1 && gain_frac == 0)));
> > > }
> > >
> > > To provide the enough resolution to compute every step (e.g., 0xFFFF and
> > > 0xFFFE) with the arbitrary user input.
--
With Best Regards,
Andy Shevchenko
next prev parent reply other threads:[~2025-11-28 19:25 UTC|newest]
Thread overview: 34+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-11-24 9:17 [PATCH v2 0/9] Add support for AD4062 device family Jorge Marques
2025-11-24 9:18 ` [PATCH v2 1/9] dt-bindings: iio: adc: Add adi,ad4062 Jorge Marques
2025-11-25 9:50 ` Krzysztof Kozlowski
2025-11-26 16:14 ` Jorge Marques
2025-11-24 9:18 ` [PATCH v2 2/9] docs: iio: New docs for ad4062 driver Jorge Marques
2025-11-24 9:18 ` [PATCH v2 3/9] iio: adc: Add support for ad4062 Jorge Marques
2025-11-24 10:20 ` Andy Shevchenko
2025-11-26 11:40 ` Jorge Marques
2025-11-27 8:58 ` Andy Shevchenko
2025-11-28 18:50 ` Jorge Marques
2025-11-28 19:25 ` Andy Shevchenko [this message]
2025-12-04 21:37 ` Jorge Marques
2025-12-04 22:23 ` Andy Shevchenko
2025-12-06 16:39 ` Jonathan Cameron
2025-11-24 9:18 ` [PATCH v2 4/9] docs: iio: ad4062: Add IIO Trigger support Jorge Marques
2025-11-24 9:18 ` [PATCH v2 5/9] iio: adc: " Jorge Marques
2025-11-24 9:36 ` Andy Shevchenko
2025-11-26 14:03 ` Jorge Marques
2025-11-24 9:18 ` [PATCH v2 6/9] docs: iio: ad4062: Add IIO Events support Jorge Marques
2025-11-24 9:18 ` [PATCH v2 7/9] iio: adc: " Jorge Marques
2025-11-24 10:33 ` Andy Shevchenko
2025-11-26 15:00 ` Jorge Marques
2025-11-27 9:13 ` Andy Shevchenko
2025-12-04 21:37 ` Jorge Marques
2025-11-24 9:18 ` [PATCH v2 8/9] docs: iio: ad4062: Add GPIO Controller support Jorge Marques
2025-11-24 9:18 ` [PATCH v2 9/9] iio: adc: " Jorge Marques
2025-11-24 9:51 ` Linus Walleij
2025-11-24 10:40 ` Andy Shevchenko
2025-11-26 15:55 ` Jorge Marques
2025-11-27 9:20 ` Andy Shevchenko
2025-12-04 21:38 ` Jorge Marques
2025-12-04 22:21 ` Andy Shevchenko
2025-12-05 11:53 ` Jorge Marques
2025-12-05 12:02 ` Andy Shevchenko
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=aSn3PthKIvFAhDS6@smile.fi.intel.com \
--to=andriy.shevchenko@intel.com \
--cc=Michael.Hennerich@analog.com \
--cc=andy@kernel.org \
--cc=brgl@bgdev.pl \
--cc=conor+dt@kernel.org \
--cc=corbet@lwn.net \
--cc=devicetree@vger.kernel.org \
--cc=dlechner@baylibre.com \
--cc=gastmaier@gmail.com \
--cc=jic23@kernel.org \
--cc=jorge.marques@analog.com \
--cc=krzk+dt@kernel.org \
--cc=lars@metafoo.de \
--cc=linus.walleij@linaro.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=nuno.sa@analog.com \
--cc=robh@kernel.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).