mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
power: supply: cpcap-battery: Simplify short term power average calculation
We can use sign_extend32() here to simplify things. And let's fix the comment for CCM register, that contains the calibration offset. Cc: Merlijn Wajer <merlijn@wizzup.org> Signed-off-by: Tony Lindgren <tony@atomide.com> Acked-by: Pavel Machek <pavel@ucw.cz> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
This commit is contained in:
parent
c59b3bad6f
commit
ac437c1c84
@ -312,31 +312,28 @@ cpcap_battery_read_accumulated(struct cpcap_battery_ddata *ddata,
|
|||||||
static int cpcap_battery_cc_get_avg_current(struct cpcap_battery_ddata *ddata)
|
static int cpcap_battery_cc_get_avg_current(struct cpcap_battery_ddata *ddata)
|
||||||
{
|
{
|
||||||
int value, acc, error;
|
int value, acc, error;
|
||||||
s32 sample = 1;
|
s32 sample;
|
||||||
s16 offset;
|
s16 offset;
|
||||||
|
|
||||||
if (ddata->vendor == CPCAP_VENDOR_ST)
|
|
||||||
sample = 4;
|
|
||||||
|
|
||||||
/* Coulomb counter integrator */
|
/* Coulomb counter integrator */
|
||||||
error = regmap_read(ddata->reg, CPCAP_REG_CCI, &value);
|
error = regmap_read(ddata->reg, CPCAP_REG_CCI, &value);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
if ((ddata->vendor == CPCAP_VENDOR_TI) && (value > 0x2000))
|
if (ddata->vendor == CPCAP_VENDOR_TI) {
|
||||||
value = value | 0xc000;
|
acc = sign_extend32(value, 13);
|
||||||
|
sample = 1;
|
||||||
|
} else {
|
||||||
|
acc = (s16)value;
|
||||||
|
sample = 4;
|
||||||
|
}
|
||||||
|
|
||||||
acc = (s16)value;
|
/* Coulomb counter calibration offset */
|
||||||
|
|
||||||
/* Coulomb counter sample time */
|
|
||||||
error = regmap_read(ddata->reg, CPCAP_REG_CCM, &value);
|
error = regmap_read(ddata->reg, CPCAP_REG_CCM, &value);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
if (value < 0x200)
|
offset = sign_extend32(value, 9);
|
||||||
offset = value;
|
|
||||||
else
|
|
||||||
offset = value | 0xfc00;
|
|
||||||
|
|
||||||
return cpcap_battery_cc_to_ua(ddata, sample, acc, offset);
|
return cpcap_battery_cc_to_ua(ddata, sample, acc, offset);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user