All battery related data could be important for user-space.  For example
time-to-full could be shown to user on the screen or health could be
monitored for any issues.  Instead of comparing few selected old/new
values, just check if anything changed in the cache.

Signed-off-by: Krzysztof Kozlowski <[email protected]>
---
 drivers/power/supply/bq27xxx_battery.c | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)

diff --git a/drivers/power/supply/bq27xxx_battery.c 
b/drivers/power/supply/bq27xxx_battery.c
index 942c92127b6d..33c26d42cd02 100644
--- a/drivers/power/supply/bq27xxx_battery.c
+++ b/drivers/power/supply/bq27xxx_battery.c
@@ -1612,12 +1612,10 @@ void bq27xxx_battery_update(struct bq27xxx_device_info 
*di)
                        di->charge_design_full = bq27xxx_battery_read_dcap(di);
        }
 
-       if ((di->cache.capacity != cache.capacity) ||
-           (di->cache.flags != cache.flags))
+       if (memcmp(&di->cache, &cache, sizeof(cache)) != 0) {
                power_supply_changed(di->bat);
-
-       if (memcmp(&di->cache, &cache, sizeof(cache)) != 0)
                di->cache = cache;
+       }
 
        di->last_update = jiffies;
 }
-- 
2.17.1

Reply via email to