Commit b28ac419 authored by Tony Lindgren's avatar Tony Lindgren Committed by Sebastian Reichel

power: supply: cpcap-battery: Read and save integrator register CCI

We can simplify code in the later patches by reading and saving the
integrator register CCI. Let's also fix a comment typo for register range
naming while at it.

Cc: Merlijn Wajer <merlijn@wizzup.org>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
Acked-by: default avatarPavel Machek <pavel@ucw.cz>
Signed-off-by: default avatarSebastian Reichel <sebastian.reichel@collabora.com>
parent ac437c1c
...@@ -84,6 +84,7 @@ struct cpcap_coulomb_counter_data { ...@@ -84,6 +84,7 @@ struct cpcap_coulomb_counter_data {
s32 sample; /* 24 or 32 bits */ s32 sample; /* 24 or 32 bits */
s32 accumulator; s32 accumulator;
s16 offset; /* 9 bits */ s16 offset; /* 9 bits */
s16 integrator; /* 13 or 16 bits */
}; };
enum cpcap_battery_state { enum cpcap_battery_state {
...@@ -269,12 +270,13 @@ static int ...@@ -269,12 +270,13 @@ static int
cpcap_battery_read_accumulated(struct cpcap_battery_ddata *ddata, cpcap_battery_read_accumulated(struct cpcap_battery_ddata *ddata,
struct cpcap_coulomb_counter_data *ccd) struct cpcap_coulomb_counter_data *ccd)
{ {
u16 buf[7]; /* CPCAP_REG_CC1 to CCI */ u16 buf[7]; /* CPCAP_REG_CCS1 to CCI */
int error; int error;
ccd->sample = 0; ccd->sample = 0;
ccd->accumulator = 0; ccd->accumulator = 0;
ccd->offset = 0; ccd->offset = 0;
ccd->integrator = 0;
/* Read coulomb counter register range */ /* Read coulomb counter register range */
error = regmap_bulk_read(ddata->reg, CPCAP_REG_CCS1, error = regmap_bulk_read(ddata->reg, CPCAP_REG_CCS1,
...@@ -299,6 +301,12 @@ cpcap_battery_read_accumulated(struct cpcap_battery_ddata *ddata, ...@@ -299,6 +301,12 @@ cpcap_battery_read_accumulated(struct cpcap_battery_ddata *ddata,
ccd->offset = buf[4]; ccd->offset = buf[4];
ccd->offset = sign_extend32(ccd->offset, 9); ccd->offset = sign_extend32(ccd->offset, 9);
/* Integrator register CPCAP_REG_CCI */
if (ddata->vendor == CPCAP_VENDOR_TI)
ccd->integrator = sign_extend32(buf[6], 13);
else
ccd->integrator = (s16)buf[6];
return cpcap_battery_cc_to_uah(ddata, return cpcap_battery_cc_to_uah(ddata,
ccd->sample, ccd->sample,
ccd->accumulator, ccd->accumulator,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment