From mboxrd@z Thu Jan 1 00:00:00 1970 From: Liam Breck Subject: [PATCH v11 0/10] devicetree battery support and client bq27xxx_battery Date: Mon, 20 Mar 2017 02:43:25 -0700 Message-ID: <20170320094335.19224-1-liam@networkimprov.net> Return-path: Received: from mail-pf0-f194.google.com ([209.85.192.194]:36033 "EHLO mail-pf0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753179AbdCTJoM (ORCPT ); Mon, 20 Mar 2017 05:44:12 -0400 Received: by mail-pf0-f194.google.com with SMTP id r137so12553866pfr.3 for ; Mon, 20 Mar 2017 02:44:12 -0700 (PDT) Sender: linux-pm-owner@vger.kernel.org List-Id: linux-pm@vger.kernel.org To: Sebastian Reichel Cc: "Andrew F. Davis" , linux-pm@vger.kernel.org, Matt Ranostay Overview: * new devicetree battery node specifies static battery data * fuel gauge and charger nodes shall use monitored-battery=<&battery_node> * new power_supply_get_battery_info() reads battery data from devicetree * new struct power_supply_battery_info provides battery data to drivers * drivers surface battery data in sysfs via related power_supply_prop_* fields * bq27xxx driver calls the above and writes battery data to RAM/NVM for params essential to correct operation: energy-full-design-microwatt-hours, charge-full-design-microamp-hours, voltage-min-design-microvolt Changes in v11: power_supply_core: * switch to compatible = "simple-battery" * add docs to power_supply_class.txt Documentation/devicetree/.../battery.txt: * add description, drop refs to Linux, "simple-battery" bq27xxx_battery: * reset flash chips after DM update * add bq27xxx_write/xfer() * polishing from Andrew's feedback * new patch to clean up error reporting * new patch to consolidate duplicate register/property arrays Changes in v10: bq27xxx_battery: * pass actual chip ID into _setup() * add di->unseal_key & di->dm_regs; drop static arrays * support bq27425, 441, 621 Changes in v9: bq27xxx_battery: * fix set_cfgupdate() * support bq27500, 545, 421; defer others * drop print_dm_blocks() patch * minor polishing Documentation/devicetree/.../battery.txt: * describe rationale for enum power_supply_property names Changes in v8: bq27xxx_battery: * wait on flag after set_cfgupdate & soft_reset * drop print_config(), report status in update_dm_block() * clarify error messages * cleanup from Andrew's feedback; minor polishing Changes in v7: bq27xxx_battery: * support chips where terminate_voltage & design_* live in separate blocks * draft support for 421, 441, 621 chips * new patch to log chip memory fields * report bus I/O errors; return error code in bq27xxx_battery_i2c * verify checksum in read_dm_block() * use set_cfgupdate only if chip provides it, soft_reset on I/O error * block_data_control=0 only in write_dm_block() * note toxic code from TI bqtool in write_dm_block() * lots of functionally neutral polishing Documentation/devicetree/.../battery.txt: * mention power_supply_get_battery_info() Changes in v6: * Documentation/devictree/... fixes * bq27xxx_battery: clarify names * bq27xxx_battery: verify that selected registers are supported * bq27xxx_battery: allocate NVM buffer on stack * bq27xxx_battery_i2c: fix return code of bulk_read Changes in v5: * incorporate feedback into Documentation/devicetree/.../battery.txt * use power_supply_prop_* names in devicetree and power_supply_battery_info * default fields to -EINVAL in power_supply_battery_info * power_supply_get_battery_info() always looks for "monitored-battery" * power_supply_get_battery_info() emits a warning if !psy->of_node * squash patches for power_supply_battery_info * bq27xxx_battery: check power_supply_battery_info values * bq27xxx_battery: note missing power_supply_prop_* features * bq27xxx_battery: new patch for access methods Changes in v4: * add "fixed-battery" compatible field to be be more consistant with devicetree Changes in v3: * split i2c changes into respective patches * add documentation for battery information for fuel gauge * rebased documentation patches on change on the list * abstracted the battery configuration for the state machine to an generic struct and platform data access function Changes in v2: * add documentation for uWh and uAh property units * change devicetree entries to match new property units Liam Breck (8): devicetree: power: Add battery.txt devicetree: power: bq27xxx: Add monitored-battery documentation power: power_supply: Add power_supply_battery_info and API power: bq27xxx_battery: Make error reporting consistent power: bq27xxx_battery: Define access methods to write chip registers power: bq27xxx_battery: Keep track of specific chip id power: bq27xxx_battery: Add power_supply_battery_info support power: bq27xxx_battery: Remove duplicate register arrays Matt Ranostay (2): devicetree: property-units: Add uWh and uAh units power: bq27xxx_battery_i2c: Add I2C bulk read/write functions .../devicetree/bindings/power/supply/battery.txt | 43 ++ .../devicetree/bindings/power/supply/bq27xxx.txt | 11 +- .../devicetree/bindings/property-units.txt | 2 + Documentation/power/power_supply_class.txt | 12 + drivers/power/supply/bq27xxx_battery.c | 707 +++++++++++++++++---- drivers/power/supply/bq27xxx_battery_i2c.c | 98 ++- drivers/power/supply/power_supply_core.c | 45 ++ include/linux/power/bq27xxx_battery.h | 26 +- include/linux/power_supply.h | 18 + 9 files changed, 806 insertions(+), 156 deletions(-) create mode 100644 Documentation/devicetree/bindings/power/supply/battery.txt -- 2.9.3