From: Quentin Schulz <foss+kernel@0leil.net>
To: Evgeny Boger <boger@wirenboard.com>
Cc: linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
Jonathan Cameron <jic23@kernel.org>,
Lars-Peter Clausen <lars@metafoo.de>,
Chen-Yu Tsai <wens@csie.org>,
Jernej Skrabec <jernej.skrabec@gmail.com>,
Maxime Ripard <maxime@cerno.tech>,
linux-sunxi@lists.linux.dev
Subject: Re: [PATCH 1/2] iio:adc:axp20x: add support for NTC thermistor
Date: Wed, 1 Dec 2021 11:42:15 +0100 [thread overview]
Message-ID: <20211201104215.usstwfbvrv7pamqp@fiqs> (raw)
In-Reply-To: <20211118141233.247907-2-boger@wirenboard.com>
Hi Evgeny,
On Thu, Nov 18, 2021 at 05:12:32PM +0300, Evgeny Boger wrote:
> Most AXPxxx-based reference designs place a 10k NTC thermistor on a
> TS pin. When appropriately configured, AXP PMICs will inject fixed
> current (80uA by default) into TS pin and measure the voltage across a
> thermistor. The PMIC itself will by default compare this voltage with
> predefined thresholds and disable battery charging whenever
They actually are configurable, we just don't have the knobs for this in
the kernel.
"In the diagram above, VTH/VTL refers to the high temperature threshold
and low temperature threshold, which is programmable via registers
REG38H/39H/3CH/3DH respectively. " in AXP209 datasheet, section
"Battery temperature detection".
> the battery is too hot or too cold.
>
> Alternatively, the TS pin can be configured as general-purpose
> ADC input. This mode is not supported by the driver.
>
> This patch allows reading the voltage on the TS pin. It can be then
> either processed by userspace or used by kernel consumer like hwmon
> ntc thermistor driver.
>
> Signed-off-by: Evgeny Boger <boger@wirenboard.com>
> ---
> drivers/iio/adc/axp20x_adc.c | 45 +++++++++++++++++++++++++++++++-----
> 1 file changed, 39 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/iio/adc/axp20x_adc.c b/drivers/iio/adc/axp20x_adc.c
> index 3e0c0233b431..12d469a52cea 100644
> --- a/drivers/iio/adc/axp20x_adc.c
> +++ b/drivers/iio/adc/axp20x_adc.c
[...]
> +static int axp22x_adc_scale_voltage(int channel, int *val, int *val2)
> +{
> + switch (channel) {
> + case AXP22X_BATT_V:
> + /* 1.1 mV per LSB */
> + *val = 1;
> + *val2 = 100000;
> + return IIO_VAL_INT_PLUS_MICRO;
> +
> + case AXP22X_TS_IN:
> + /* 0.8 mV per LSB */
> + *val = 0;
> + *val2 = 800000;
> + return IIO_VAL_INT_PLUS_MICRO;
> +
> + default:
> + return -EINVAL;
> + }
> +}
> static int axp813_adc_scale_voltage(int channel, int *val, int *val2)
> {
> switch (channel) {
[...]
> @@ -378,12 +415,7 @@ static int axp22x_adc_scale(struct iio_chan_spec const *chan, int *val,
> {
> switch (chan->type) {
> case IIO_VOLTAGE:
> - if (chan->channel != AXP22X_BATT_V)
> - return -EINVAL;
> -
> - *val = 1;
> - *val2 = 100000;
> - return IIO_VAL_INT_PLUS_MICRO;
> + return axp22x_adc_scale_voltage(chan->channel, val, val2);
>
I would have personally split the move to a separate
axp22x_adc_scale_voltage function in a separate commit. I was a bit
confused at first why in the diff above there was a AXP22X_BATT_V
addition since this commit is about AXP22X_TS_IN.
If the maintainers are ok with it, I don't mind too much.
I don't have the HW to test this, but changes look ok.
Reviewed-by: Quentin Schulz <foss+kernel@0leil.net>
Thanks!
Quentin
next prev parent reply other threads:[~2021-12-01 10:42 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-11-18 14:12 [PATCH 0/2] iio: adc: axp20x: add support for NTC thermistor Evgeny Boger
2021-11-18 14:12 ` [PATCH 1/2] iio:adc:axp20x: " Evgeny Boger
2021-11-22 10:48 ` Maxime Ripard
2021-12-01 10:11 ` Quentin Schulz
2021-12-01 10:42 ` Quentin Schulz [this message]
2021-11-18 14:12 ` [PATCH 2/2] dt-bindings: iio: adc: document TS voltage in AXP PMICs Evgeny Boger
2021-11-22 10:49 ` Maxime Ripard
2021-11-22 11:17 ` Evgeny Boger
2021-11-22 11:35 ` Samuel Holland
2021-11-22 11:51 ` Evgeny Boger
2021-11-29 23:58 ` Evgeny Boger
2021-12-01 10:03 ` Quentin Schulz
2021-12-01 11:02 ` Quentin Schulz
2021-12-01 15:45 ` Evgeny Boger
2021-12-03 20:47 ` Sebastian Reichel
2021-12-04 15:26 ` Jonathan Cameron
2021-12-05 1:02 ` Linus Walleij
2021-12-05 10:50 ` Evgeny Boger
2021-12-05 19:46 ` Linus Walleij
2021-11-29 23:10 ` Rob Herring
2021-12-04 15:28 ` 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=20211201104215.usstwfbvrv7pamqp@fiqs \
--to=foss+kernel@0leil.net \
--cc=boger@wirenboard.com \
--cc=devicetree@vger.kernel.org \
--cc=jernej.skrabec@gmail.com \
--cc=jic23@kernel.org \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=linux-sunxi@lists.linux.dev \
--cc=maxime@cerno.tech \
--cc=wens@csie.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