From: Matteo Martelli <matteomartelli3@gmail.com>
To: Marius.Cristea@microchip.com, jic23@kernel.org,
matteomartelli3@gmail.com
Cc: robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org,
devicetree@vger.kernel.org, lars@metafoo.de,
linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 2/2] iio: adc: add support for pac1921
Date: Thu, 11 Jul 2024 09:08:18 +0200 [thread overview]
Message-ID: <668f84e2f3e10_2b423707a@njaxe.notmuch> (raw)
In-Reply-To: <88a54c736e0c39ead34dbde53c813526484d767d.camel@microchip.com>
Hi Marius,
Marius.Cristea@ wrote:
> > I think that the OUT pin might not be used at all in many use cases
> > so I would
> > leave the OUT pin setting as fixed for now and maybe extend it in the
> > future
> > when more use cases arise. I am open to reconsider this though.
> >
>
> The OUT functionality could be set from the device tree.
I think this should to be controlled during runtime since it's a configuration
that changes the device operation mode and so also what measurements are
exposed to the user. An additional DT property could be useful but I am not
sure it would fit in the DT scope.
Anyway I will leave this for future extensions.
...
> > > > ---
> > > > .../ABI/testing/sysfs-bus-iio-adc-pac1921 | 45 +
> > > > MAINTAINERS | 7 +
> > > > drivers/iio/adc/Kconfig | 10 +
> > > > drivers/iio/adc/Makefile | 1 +
> > > > drivers/iio/adc/pac1921.c | 1038
> > > > ++++++++++++++++++++
> > > > 5 files changed, 1101 insertions(+)
> > > >
> > > > diff --git a/Documentation/ABI/testing/sysfs-bus-iio-adc-pac1921
> > > > b/Documentation/ABI/testing/sysfs-bus-iio-adc-pac1921
> > > > new file mode 100644
> > > > index 000000000000..4a32e2d4207b
> > > > --- /dev/null
> > > > +++ b/Documentation/ABI/testing/sysfs-bus-iio-adc-pac1921
> > > Quite a bit of custom ABI in here.
> > >
> > > Rule of thumb is that custom ABI is more or less pointless ABI for
> > > 99% of users
> > > because standard userspace won't use it. So keep that in mind when
> > > defining it.
> > >
> > > > @@ -0,0 +1,45 @@
> > > > +What:
> > > > /sys/bus/iio/devices/iio:deviceX/resolution_bits
> > > > +KernelVersion: 6.10
> > > > +Contact: linux-iio@vger.kernel.org
> > > > +Description:
> > > > + ADC measurement resolution. Can be either 11 bits or
> > > > 14 bits
> > > > + (default). The driver sets the same resolution for
> > > > both VBUS and
> > > > + VSENSE measurements even if the hardware could be
> > > > configured to
> > > > + measure VBUS and VSENSE with different resolutions.
> > > > + This attribute affects the integration time: with 14
> > > > bits
> > > > + resolution the integration time is increased by a
> > > > factor of
> > > > + 1.9 (the driver considers a factor of 2). See Table
> > > > 4-5 in
> > > > + device datasheet for details.
> > >
> > > Is the integration time ever high enough that it matters?
> > > People tend not to do power measurement 'quickly'.
> > >
> > > If we are doing it quickly then you'll probably want to be
> > > providing buffered
> > > support and that does allow you to 'read' the resolution for a part
> > > where
> > > it changes for some other reason. I haven't yet understood this
> > > case.
> >
> > I will remove this control and fix the resolution bits to 14 (highest
> > value),
> > same as the HW default.
>
> The resolution could be set from the device tree. As default it could
> be 14 bits like into the hardware. The user could add
> "microchip,low_resolution_voltage" into the device tree in order to use
> only 11 bits for voltage samples.
I think this should be controlled during runtime since it does not depend on
the HW design but more on the user preferences about measurements precision.
As Jonathan pointed out, since custom ABIs should be avoided when possible, I
will leave it out from now until it becomes necessary and fix the resolution to
14 bits, as the HW default.
...
> > > > +What: /sys/bus/iio/devices/iio:devices/filters_en
> > > > +KernelVersion: 6.10
> > > > +Contact: linux-iio@vger.kernel.org
> > > > +Description:
> > > > + Attribute to enable/disable ADC post filters. Enabled
> > > > by
> > > > + default.
> > > > + This attribute affects the integration time: with
> > > > filters
> > > > + enabled the integration time is increased by 50%. See
> > > > Table 4-5
> > > > + in device datasheet for details.
> > >
> > > Do we have any idea what this filter is? Datasheet seems very vague
> > > indeed and from
> > > a control point of view that makes this largely useless. How does
> > > userspace know
> > > whether to turn it on?
> > >
> > > We have an existing filter ABI but with so little information no
> > > way to fit this in.
> > > Gut feeling, leave it on all the time and drop the control
> > > interface.
> >
> > I will remove this control and leave it on all the time as the HW
> > default.
> >
>
> The filters could be enabled from the device tree. As default it could
> be disabled.
> As a small detail here this is a post processing digital filter that
> could be enabled/disabled inside the PAC module.
>
Same reasoning of the resolution_bits parameter applies here. I will fix the
filters to enabled, as the HW default. If there is any particular reason to
prefer the filters fixed as disabled I will change that.
...
> Thanks,
> Marius
Thanks,
Matteo
next prev parent reply other threads:[~2024-07-11 7:08 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-07-04 17:42 [PATCH v2 0/2] iio: adc: add support for pac1921 Matteo Martelli
2024-07-04 17:42 ` [PATCH v2 1/2] dt-bindings: iio: adc: add binding " Matteo Martelli
2024-07-09 16:05 ` Rob Herring (Arm)
2024-07-04 17:42 ` [PATCH v2 2/2] iio: adc: add support " Matteo Martelli
2024-07-07 15:04 ` Jonathan Cameron
2024-07-08 13:39 ` Matteo Martelli
2024-07-08 16:34 ` Jonathan Cameron
2024-07-09 8:21 ` Matteo Martelli
2024-07-10 15:25 ` Marius.Cristea
2024-07-13 10:21 ` Jonathan Cameron
2024-07-16 9:20 ` Matteo Martelli
2024-07-16 11:19 ` Marius.Cristea
2024-07-16 17:00 ` Jonathan Cameron
2024-07-17 14:22 ` Matteo Martelli
2024-07-20 9:48 ` Jonathan Cameron
2024-07-10 16:01 ` Marius.Cristea
2024-07-11 7:08 ` Matteo Martelli [this message]
2024-07-12 14:41 ` Marius.Cristea
2024-07-12 17:02 ` Conor Dooley
2024-07-13 10:36 ` 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=668f84e2f3e10_2b423707a@njaxe.notmuch \
--to=matteomartelli3@gmail.com \
--cc=Marius.Cristea@microchip.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=jic23@kernel.org \
--cc=krzk+dt@kernel.org \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--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).