From: Lars-Peter Clausen <lars@metafoo.de>
To: "Kim, Milo" <Milo.Kim@ti.com>
Cc: "cbou@mail.ru" <cbou@mail.ru>,
Anton Vorontsov <anton.vorontsov@linaro.org>,
Jonathan Cameron <jic23@kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 3/3] lp8788-charger: fix wrong ADC conversion
Date: Thu, 18 Oct 2012 13:20:36 +0200 [thread overview]
Message-ID: <507FE604.8070404@metafoo.de> (raw)
In-Reply-To: <A874F61F95741C4A9BA573A70FE3998F64178FA7@DQHE02.ent.ti.com>
Hi,
On 10/18/2012 08:11 AM, Kim, Milo wrote:
> To get the battery voltage and temperature, IIO ADC functions are used.
> LP8788 ADC driver provides RAW and SCALE channel information.
> Both RAW with SCALE values are used for the ADC calculation.
> The scale is micro unit, additional conversions are required in each case.
> This patch fixes wrong ADC result.
>
> Signed-off-by: Milo(Woogyom) Kim <milo.kim@ti.com>
> ---
> drivers/power/lp8788-charger.c | 18 ++++++++++++++++--
> 1 file changed, 16 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/power/lp8788-charger.c b/drivers/power/lp8788-charger.c
> index 02fc9ab..3c739e6 100644
> --- a/drivers/power/lp8788-charger.c
> +++ b/drivers/power/lp8788-charger.c
> @@ -239,19 +239,26 @@ static int lp8788_get_vbatt_adc(struct lp8788_charger *pchg,
> unsigned int *result)
> {
> struct iio_channel *channel = pchg->chan[LP8788_VBATT];
> + int raw;
> int scaleint;
> int scalepart;
> int ret;
> + unsigned long tmp;
>
> if (!channel)
> return -EINVAL;
>
> + ret = iio_read_channel_raw(channel, &raw);
> + if (ret != IIO_VAL_INT)
> + return -EINVAL;
> +
> ret = iio_read_channel_scale(channel, &scaleint, &scalepart);
> if (ret != IIO_VAL_INT_PLUS_MICRO)
> return -EINVAL;
>
> /* unit: mV */
> - *result = (scaleint + scalepart * 1000000) / 1000;
> + tmp = raw * scaleint + div_u64(raw * scalepart, 1000000L);
> + *result = (unsigned int)tmp;
We now have a function in the IIO core which does the sampling + conversion
in one step: iio_read_channel_processed. This basically allows you to reduce
this function to
return iio_read_channel_processed(channel, result);
I'd also make the result parameter of lp8788_get_vbatt_adc signed, since
both power_supply_propval.intval and iio_read_channel_processed use a signed
int.
>
> return 0;
> }
> @@ -304,19 +311,26 @@ static int lp8788_get_battery_temperature(struct lp8788_charger *pchg,
> union power_supply_propval *val)
> {
> struct iio_channel *channel = pchg->chan[LP8788_BATT_TEMP];
> + int raw;
> int scaleint;
> int scalepart;
> int ret;
> + unsigned long tmp;
>
> if (!channel)
> return -EINVAL;
>
> + ret = iio_read_channel_raw(channel, &raw);
> + if (ret != IIO_VAL_INT)
> + return -EINVAL;
> +
> ret = iio_read_channel_scale(channel, &scaleint, &scalepart);
> if (ret != IIO_VAL_INT_PLUS_MICRO)
> return -EINVAL;
>
> /* unit: 0.1 'C */
> - val->intval = (scaleint + scalepart * 1000000) / 100;
> + tmp = raw * scaleint + div_u64(raw * scalepart, 1000000L);
> + val->intval = (unsigned int)tmp * 10;
>
Same here
> return 0;
> }
next prev parent reply other threads:[~2012-10-18 11:19 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-18 6:11 [PATCH 3/3] lp8788-charger: fix wrong ADC conversion Kim, Milo
2012-10-18 11:20 ` Lars-Peter Clausen [this message]
2012-10-18 23:03 ` Kim, Milo
2012-10-18 23:39 ` Kim, Milo
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=507FE604.8070404@metafoo.de \
--to=lars@metafoo.de \
--cc=Milo.Kim@ti.com \
--cc=anton.vorontsov@linaro.org \
--cc=cbou@mail.ru \
--cc=jic23@kernel.org \
--cc=linux-kernel@vger.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.