2010-05-25 00:55:27 +07:00
|
|
|
#ifndef __LINUX_BQ27X00_BATTERY_H__
|
|
|
|
#define __LINUX_BQ27X00_BATTERY_H__
|
|
|
|
|
2015-11-23 23:53:51 +07:00
|
|
|
enum bq27xxx_chip {
|
|
|
|
BQ27000 = 1, /* bq27000, bq27200 */
|
|
|
|
BQ27010, /* bq27010, bq27210 */
|
2017-01-11 08:44:38 +07:00
|
|
|
BQ2750X, /* bq27500 deprecated alias */
|
2017-01-11 08:44:39 +07:00
|
|
|
BQ2751X, /* bq27510, bq27520 deprecated alias */
|
2017-01-11 08:44:40 +07:00
|
|
|
BQ27500, /* bq27500/1 */
|
2017-01-11 08:44:41 +07:00
|
|
|
BQ27510G1, /* bq27510G1 */
|
2017-01-11 08:44:42 +07:00
|
|
|
BQ27510G2, /* bq27510G2 */
|
2017-01-11 08:44:43 +07:00
|
|
|
BQ27510G3, /* bq27510G3 */
|
2017-01-11 08:44:44 +07:00
|
|
|
BQ27520G1, /* bq27520G1 */
|
2017-01-11 08:44:45 +07:00
|
|
|
BQ27520G2, /* bq27520G2 */
|
2017-01-11 08:44:46 +07:00
|
|
|
BQ27520G3, /* bq27520G3 */
|
2017-01-11 08:44:47 +07:00
|
|
|
BQ27520G4, /* bq27520G4 */
|
2015-11-23 23:53:51 +07:00
|
|
|
BQ27530, /* bq27530, bq27531 */
|
|
|
|
BQ27541, /* bq27541, bq27542, bq27546, bq27742 */
|
|
|
|
BQ27545, /* bq27545 */
|
|
|
|
BQ27421, /* bq27421, bq27425, bq27441, bq27621 */
|
|
|
|
};
|
|
|
|
|
2010-05-25 00:55:27 +07:00
|
|
|
/**
|
2015-09-23 02:35:06 +07:00
|
|
|
* struct bq27xxx_plaform_data - Platform data for bq27xxx devices
|
2015-09-23 02:35:07 +07:00
|
|
|
* @name: Name of the battery.
|
|
|
|
* @chip: Chip class number of this device.
|
2010-05-25 00:55:27 +07:00
|
|
|
* @read: HDQ read callback.
|
|
|
|
* This function should provide access to the HDQ bus the battery is
|
|
|
|
* connected to.
|
|
|
|
* The first parameter is a pointer to the battery device, the second the
|
|
|
|
* register to be read. The return value should either be the content of
|
|
|
|
* the passed register or an error value.
|
|
|
|
*/
|
2015-09-23 02:35:06 +07:00
|
|
|
struct bq27xxx_platform_data {
|
2010-05-25 00:55:27 +07:00
|
|
|
const char *name;
|
2015-09-23 02:35:07 +07:00
|
|
|
enum bq27xxx_chip chip;
|
2010-05-25 00:55:27 +07:00
|
|
|
int (*read)(struct device *dev, unsigned int);
|
|
|
|
};
|
|
|
|
|
2015-11-23 23:53:51 +07:00
|
|
|
struct bq27xxx_device_info;
|
|
|
|
struct bq27xxx_access_methods {
|
|
|
|
int (*read)(struct bq27xxx_device_info *di, u8 reg, bool single);
|
2017-06-08 01:37:54 +07:00
|
|
|
int (*write)(struct bq27xxx_device_info *di, u8 reg, int value, bool single);
|
|
|
|
int (*read_bulk)(struct bq27xxx_device_info *di, u8 reg, u8 *data, int len);
|
|
|
|
int (*write_bulk)(struct bq27xxx_device_info *di, u8 reg, u8 *data, int len);
|
2015-11-23 23:53:51 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct bq27xxx_reg_cache {
|
|
|
|
int temperature;
|
|
|
|
int time_to_empty;
|
|
|
|
int time_to_empty_avg;
|
|
|
|
int time_to_full;
|
|
|
|
int charge_full;
|
|
|
|
int cycle_count;
|
|
|
|
int capacity;
|
|
|
|
int energy;
|
|
|
|
int flags;
|
|
|
|
int power_avg;
|
|
|
|
int health;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct bq27xxx_device_info {
|
|
|
|
struct device *dev;
|
2016-02-02 19:47:37 +07:00
|
|
|
int id;
|
2015-11-23 23:53:51 +07:00
|
|
|
enum bq27xxx_chip chip;
|
2017-06-08 01:37:56 +07:00
|
|
|
bool ram_chip;
|
2015-11-23 23:53:51 +07:00
|
|
|
const char *name;
|
2017-06-08 01:37:56 +07:00
|
|
|
struct bq27xxx_dm_reg *dm_regs;
|
2017-06-08 01:37:55 +07:00
|
|
|
u32 unseal_key;
|
2015-11-23 23:53:51 +07:00
|
|
|
struct bq27xxx_access_methods bus;
|
|
|
|
struct bq27xxx_reg_cache cache;
|
|
|
|
int charge_design_full;
|
|
|
|
unsigned long last_update;
|
|
|
|
struct delayed_work work;
|
|
|
|
struct power_supply *bat;
|
2016-09-20 10:43:02 +07:00
|
|
|
struct list_head list;
|
2015-11-23 23:53:51 +07:00
|
|
|
struct mutex lock;
|
|
|
|
u8 *regs;
|
|
|
|
};
|
|
|
|
|
|
|
|
void bq27xxx_battery_update(struct bq27xxx_device_info *di);
|
|
|
|
int bq27xxx_battery_setup(struct bq27xxx_device_info *di);
|
|
|
|
void bq27xxx_battery_teardown(struct bq27xxx_device_info *di);
|
|
|
|
|
2010-05-25 00:55:27 +07:00
|
|
|
#endif
|