[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <b5mhivpuhyfj3knw3w5wmi2kxyyej7cdnh3kd6wyenumfy7qpr@vnfvfj5gsmtx>
Date: Wed, 11 Dec 2024 02:38:03 +0100
From: Sebastian Reichel <sebastian.reichel@...labora.com>
To: Kim Seer Paller <kimseer.paller@...log.com>
Cc: Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>, Conor Dooley <conor+dt@...nel.org>,
Mike Looijmans <mike.looijmans@...ic.nl>, linux-pm@...r.kernel.org, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH v5 2/2] power/supply: Add support for ltc4162-f/s and
ltc4015
Hi,
On Tue, Dec 10, 2024 at 02:05:06PM +0800, Kim Seer Paller wrote:
> static int ltc4162l_get_ibat(struct ltc4162l_info *info,
> union power_supply_propval *val)
> {
> + const struct ltc4162l_chip_info *chip_info = info->chip_info;
> unsigned int regval;
> int ret;
>
> @@ -249,9 +356,8 @@ static int ltc4162l_get_ibat(struct ltc4162l_info *info,
> if (ret)
> return ret;
>
> - /* Signed 16-bit number, 1.466μV / RSNSB amperes/LSB. */
> ret = (s16)(regval & 0xFFFF);
> - val->intval = 100 * mult_frac(ret, 14660, (int)info->rsnsb);
> + val->intval = mult_frac(ret, chip_info->ibat_resolution_uv, info->rsnsb);
ibat_resolution_uv is in picovolt as far as I can see:
1.466 uV / RSNSB = 1466 nV / RSNSB = 1466000 pV / RSNSB
RSNSB is provided in microOhm and picoVolt / microOhm equals
microAmp, which is the unit expected by the power-supply
subsystem.
> return 0;
> }
> @@ -260,6 +366,7 @@ static int ltc4162l_get_ibat(struct ltc4162l_info *info,
> static int ltc4162l_get_input_voltage(struct ltc4162l_info *info,
> union power_supply_propval *val)
> {
> + const struct ltc4162l_chip_info *chip_info = info->chip_info;
> unsigned int regval;
> int ret;
>
> @@ -267,8 +374,7 @@ static int ltc4162l_get_input_voltage(struct ltc4162l_info *info,
> if (ret)
> return ret;
>
> - /* 1.649mV/LSB */
> - val->intval = regval * 1694;
> + val->intval = regval * chip_info->vin_resolution_mv;
I believe it should be vin_resolution_uv. Microvolt is what the
power-supply subsystem wants and 1.649 mV (from the comment above) is
1649 uV (from the chip_info->vin_resolution_mv value) :)
>
> return 0;
> }
Otherwise LGTM.
-- Sebastian
Download attachment "signature.asc" of type "application/pgp-signature" (834 bytes)
Powered by blists - more mailing lists