Message ID | 20190527022258.32748-6-matheus@castello.eng.br (mailing list archive) |
---|---|
State | Not Applicable, archived |
Headers | show |
Series | power: supply: MAX17040: Add IRQ for low level and alert SOC changes | expand |
On Mon, 27 May 2019 at 04:23, Matheus Castello <matheus@castello.eng.br> wrote: > > Notify core through power_supply_changed() in case of changes in state > of charge and power supply status. This is useful for user-space to > efficiently update current battery level. > > Signed-off-by: Matheus Castello <matheus@castello.eng.br> > --- > drivers/power/supply/max17040_battery.c | 14 ++++++++++++++ > 1 file changed, 14 insertions(+) > > diff --git a/drivers/power/supply/max17040_battery.c b/drivers/power/supply/max17040_battery.c > index 61e6fcfea8a1..34278845cfe5 100644 > --- a/drivers/power/supply/max17040_battery.c > +++ b/drivers/power/supply/max17040_battery.c > @@ -176,6 +176,9 @@ static void max17040_get_online(struct i2c_client *client) > static void max17040_get_status(struct i2c_client *client) > { > struct max17040_chip *chip = i2c_get_clientdata(client); > + int last_status; > + > + last_status = chip->status; > > if (!chip->pdata || !chip->pdata->charger_online > || !chip->pdata->charger_enable) { > @@ -194,6 +197,9 @@ static void max17040_get_status(struct i2c_client *client) > > if (chip->soc > MAX17040_BATTERY_FULL) > chip->status = POWER_SUPPLY_STATUS_FULL; > + > + if (last_status != chip->status) > + power_supply_changed(chip->battery); Why splitting it from max17040_work()? It seems logical to check soc and status at the same time. Best regards, Krzysztof > } > > static void max17040_get_of_data(struct max17040_chip *chip) > @@ -217,10 +223,18 @@ static void max17040_check_changes(struct i2c_client *client) > static void max17040_work(struct work_struct *work) > { > struct max17040_chip *chip; > + int last_soc; > > chip = container_of(work, struct max17040_chip, work.work); > + > + /* store SOC for check change */ > + last_soc = chip->soc; > max17040_check_changes(chip->client); > > + /* check changes and send uevent */ > + if (chip->soc >= 0 && last_soc != chip->soc) > + power_supply_changed(chip->battery); > + > queue_delayed_work(system_power_efficient_wq, &chip->work, > MAX17040_DELAY); > } > -- > 2.20.1 >
diff --git a/drivers/power/supply/max17040_battery.c b/drivers/power/supply/max17040_battery.c index 61e6fcfea8a1..34278845cfe5 100644 --- a/drivers/power/supply/max17040_battery.c +++ b/drivers/power/supply/max17040_battery.c @@ -176,6 +176,9 @@ static void max17040_get_online(struct i2c_client *client) static void max17040_get_status(struct i2c_client *client) { struct max17040_chip *chip = i2c_get_clientdata(client); + int last_status; + + last_status = chip->status; if (!chip->pdata || !chip->pdata->charger_online || !chip->pdata->charger_enable) { @@ -194,6 +197,9 @@ static void max17040_get_status(struct i2c_client *client) if (chip->soc > MAX17040_BATTERY_FULL) chip->status = POWER_SUPPLY_STATUS_FULL; + + if (last_status != chip->status) + power_supply_changed(chip->battery); } static void max17040_get_of_data(struct max17040_chip *chip) @@ -217,10 +223,18 @@ static void max17040_check_changes(struct i2c_client *client) static void max17040_work(struct work_struct *work) { struct max17040_chip *chip; + int last_soc; chip = container_of(work, struct max17040_chip, work.work); + + /* store SOC for check change */ + last_soc = chip->soc; max17040_check_changes(chip->client); + /* check changes and send uevent */ + if (chip->soc >= 0 && last_soc != chip->soc) + power_supply_changed(chip->battery); + queue_delayed_work(system_power_efficient_wq, &chip->work, MAX17040_DELAY); }
Notify core through power_supply_changed() in case of changes in state of charge and power supply status. This is useful for user-space to efficiently update current battery level. Signed-off-by: Matheus Castello <matheus@castello.eng.br> --- drivers/power/supply/max17040_battery.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) -- 2.20.1