bq27x00_battery.c 24.5 KB
Newer Older
1 2 3 4 5
/*
 * BQ27x00 battery driver
 *
 * Copyright (C) 2008 Rodolfo Giometti <giometti@linux.it>
 * Copyright (C) 2008 Eurotech S.p.A. <info@eurotech.it>
6
 * Copyright (C) 2010-2011 Lars-Peter Clausen <lars@metafoo.de>
7
 * Copyright (C) 2011 Pali Rohár <pali.rohar@gmail.com>
8 9 10 11 12 13 14 15 16 17 18 19
 *
 * Based on a previous work by Copyright (C) 2008 Texas Instruments, Inc.
 *
 * This package is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * THIS PACKAGE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
 * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 *
 */
P
Pali Rohár 已提交
20 21 22 23 24

/*
 * Datasheets:
 * http://focus.ti.com/docs/prod/folders/print/bq27000.html
 * http://focus.ti.com/docs/prod/folders/print/bq27500.html
25
 * http://www.ti.com/product/bq27425-g1
P
Pali Rohár 已提交
26 27
 */

28 29 30 31 32 33 34 35 36
#include <linux/module.h>
#include <linux/param.h>
#include <linux/jiffies.h>
#include <linux/workqueue.h>
#include <linux/delay.h>
#include <linux/platform_device.h>
#include <linux/power_supply.h>
#include <linux/idr.h>
#include <linux/i2c.h>
37
#include <linux/slab.h>
38
#include <asm/unaligned.h>
39

40 41
#include <linux/power/bq27x00_battery.h>

P
Pali Rohár 已提交
42
#define DRIVER_VERSION			"1.2.0"
43 44 45 46 47

#define BQ27x00_REG_TEMP		0x06
#define BQ27x00_REG_VOLT		0x08
#define BQ27x00_REG_AI			0x14
#define BQ27x00_REG_FLAGS		0x0A
48 49 50
#define BQ27x00_REG_TTE			0x16
#define BQ27x00_REG_TTF			0x18
#define BQ27x00_REG_TTECP		0x26
51
#define BQ27x00_REG_NAC			0x0C /* Nominal available capacity */
P
Pali Rohár 已提交
52 53
#define BQ27x00_REG_LMD			0x12 /* Last measured discharge */
#define BQ27x00_REG_CYCT		0x2A /* Cycle count total */
54
#define BQ27x00_REG_AE			0x22 /* Available energy */
55
#define BQ27x00_POWER_AVG		0x24
56

57
#define BQ27000_REG_RSOC		0x0B /* Relative State-of-Charge */
P
Pali Rohár 已提交
58
#define BQ27000_REG_ILMD		0x76 /* Initial last measured discharge */
59 60
#define BQ27000_FLAG_EDVF		BIT(0) /* Final End-of-Discharge-Voltage flag */
#define BQ27000_FLAG_EDV1		BIT(1) /* First End-of-Discharge-Voltage flag */
61
#define BQ27000_FLAG_CI			BIT(4) /* Capacity Inaccurate flag */
62
#define BQ27000_FLAG_FC			BIT(5)
63
#define BQ27000_FLAG_CHGS		BIT(7) /* Charge state flag */
64

P
Pali Rohár 已提交
65
#define BQ27500_REG_SOC			0x2C
P
Pali Rohár 已提交
66
#define BQ27500_REG_DCAP		0x3C /* Design capacity */
67
#define BQ27500_FLAG_DSC		BIT(0)
68 69
#define BQ27500_FLAG_SOCF		BIT(1) /* State-of-Charge threshold final */
#define BQ27500_FLAG_SOC1		BIT(2) /* State-of-Charge threshold 1 */
70
#define BQ27500_FLAG_FC			BIT(9)
71
#define BQ27500_FLAG_OTC		BIT(15)
72

73 74 75 76
/* bq27425 register addresses are same as bq27x00 addresses minus 4 */
#define BQ27425_REG_OFFSET		0x04
#define BQ27425_REG_SOC			0x18 /* Register address plus offset */

P
Pali Rohár 已提交
77
#define BQ27000_RS			20 /* Resistor sense */
78
#define BQ27x00_POWER_CONSTANT		(256 * 29200 / 1000)
P
Pali Rohár 已提交
79

80 81
struct bq27x00_device_info;
struct bq27x00_access_methods {
82
	int (*read)(struct bq27x00_device_info *di, u8 reg, bool single);
83 84
};

85
enum bq27x00_chip { BQ27000, BQ27500, BQ27425};
86

87 88 89 90 91
struct bq27x00_reg_cache {
	int temperature;
	int time_to_empty;
	int time_to_empty_avg;
	int time_to_full;
P
Pali Rohár 已提交
92
	int charge_full;
93
	int cycle_count;
94
	int capacity;
95
	int energy;
96
	int flags;
97 98
	int power_avg;
	int health;
99 100
};

101 102 103
struct bq27x00_device_info {
	struct device 		*dev;
	int			id;
104
	enum bq27x00_chip	chip;
105

106
	struct bq27x00_reg_cache cache;
P
Pali Rohár 已提交
107 108
	int charge_design_full;

109
	unsigned long last_update;
L
Lars-Peter Clausen 已提交
110
	struct delayed_work work;
111

112 113 114
	struct power_supply	bat;

	struct bq27x00_access_methods bus;
L
Lars-Peter Clausen 已提交
115 116

	struct mutex lock;
117 118 119
};

static enum power_supply_property bq27x00_battery_props[] = {
120
	POWER_SUPPLY_PROP_STATUS,
121 122 123 124
	POWER_SUPPLY_PROP_PRESENT,
	POWER_SUPPLY_PROP_VOLTAGE_NOW,
	POWER_SUPPLY_PROP_CURRENT_NOW,
	POWER_SUPPLY_PROP_CAPACITY,
125
	POWER_SUPPLY_PROP_CAPACITY_LEVEL,
126
	POWER_SUPPLY_PROP_TEMP,
127 128 129
	POWER_SUPPLY_PROP_TIME_TO_EMPTY_NOW,
	POWER_SUPPLY_PROP_TIME_TO_EMPTY_AVG,
	POWER_SUPPLY_PROP_TIME_TO_FULL_NOW,
L
Lars-Peter Clausen 已提交
130
	POWER_SUPPLY_PROP_TECHNOLOGY,
P
Pali Rohár 已提交
131 132 133
	POWER_SUPPLY_PROP_CHARGE_FULL,
	POWER_SUPPLY_PROP_CHARGE_NOW,
	POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN,
134
	POWER_SUPPLY_PROP_CYCLE_COUNT,
P
Pali Rohár 已提交
135
	POWER_SUPPLY_PROP_ENERGY_NOW,
136 137
	POWER_SUPPLY_PROP_POWER_AVG,
	POWER_SUPPLY_PROP_HEALTH,
138 139
};

140 141 142 143 144 145 146 147 148 149 150 151 152 153
static enum power_supply_property bq27425_battery_props[] = {
	POWER_SUPPLY_PROP_STATUS,
	POWER_SUPPLY_PROP_PRESENT,
	POWER_SUPPLY_PROP_VOLTAGE_NOW,
	POWER_SUPPLY_PROP_CURRENT_NOW,
	POWER_SUPPLY_PROP_CAPACITY,
	POWER_SUPPLY_PROP_CAPACITY_LEVEL,
	POWER_SUPPLY_PROP_TEMP,
	POWER_SUPPLY_PROP_TECHNOLOGY,
	POWER_SUPPLY_PROP_CHARGE_FULL,
	POWER_SUPPLY_PROP_CHARGE_NOW,
	POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN,
};

L
Lars-Peter Clausen 已提交
154 155 156 157 158
static unsigned int poll_interval = 360;
module_param(poll_interval, uint, 0644);
MODULE_PARM_DESC(poll_interval, "battery poll interval in seconds - " \
				"0 disables polling");

159 160 161 162
/*
 * Common code for BQ27x00 devices
 */

163
static inline int bq27x00_read(struct bq27x00_device_info *di, u8 reg,
164
		bool single)
165
{
166 167
	if (di->chip == BQ27425)
		return di->bus.read(di, reg - BQ27425_REG_OFFSET, single);
168
	return di->bus.read(di, reg, single);
169 170
}

171 172 173 174 175 176 177 178 179 180 181 182
/*
 * Higher versions of the chip like BQ27425 and BQ27500
 * differ from BQ27000 and BQ27200 in calculation of certain
 * parameters. Hence we need to check for the chip type.
 */
static bool bq27xxx_is_chip_version_higher(struct bq27x00_device_info *di)
{
	if (di->chip == BQ27425 || di->chip == BQ27500)
		return true;
	return false;
}

183
/*
184
 * Return the battery Relative State-of-Charge
185 186
 * Or < 0 if something fails.
 */
187
static int bq27x00_battery_read_rsoc(struct bq27x00_device_info *di)
188
{
189
	int rsoc;
190

191
	if (di->chip == BQ27500)
192
		rsoc = bq27x00_read(di, BQ27500_REG_SOC, false);
193 194
	else if (di->chip == BQ27425)
		rsoc = bq27x00_read(di, BQ27425_REG_SOC, false);
195
	else
196 197 198
		rsoc = bq27x00_read(di, BQ27000_REG_RSOC, true);

	if (rsoc < 0)
199
		dev_dbg(di->dev, "error reading relative State-of-Charge\n");
200 201

	return rsoc;
202 203
}

P
Pali Rohár 已提交
204 205 206 207 208 209 210 211 212 213
/*
 * Return a battery charge value in µAh
 * Or < 0 if something fails.
 */
static int bq27x00_battery_read_charge(struct bq27x00_device_info *di, u8 reg)
{
	int charge;

	charge = bq27x00_read(di, reg, false);
	if (charge < 0) {
214 215
		dev_dbg(di->dev, "error reading charge register %02x: %d\n",
			reg, charge);
P
Pali Rohár 已提交
216 217 218
		return charge;
	}

219
	if (bq27xxx_is_chip_version_higher(di))
P
Pali Rohár 已提交
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252
		charge *= 1000;
	else
		charge = charge * 3570 / BQ27000_RS;

	return charge;
}

/*
 * Return the battery Nominal available capaciy in µAh
 * Or < 0 if something fails.
 */
static inline int bq27x00_battery_read_nac(struct bq27x00_device_info *di)
{
	return bq27x00_battery_read_charge(di, BQ27x00_REG_NAC);
}

/*
 * Return the battery Last measured discharge in µAh
 * Or < 0 if something fails.
 */
static inline int bq27x00_battery_read_lmd(struct bq27x00_device_info *di)
{
	return bq27x00_battery_read_charge(di, BQ27x00_REG_LMD);
}

/*
 * Return the battery Initial last measured discharge in µAh
 * Or < 0 if something fails.
 */
static int bq27x00_battery_read_ilmd(struct bq27x00_device_info *di)
{
	int ilmd;

253
	if (bq27xxx_is_chip_version_higher(di))
P
Pali Rohár 已提交
254 255 256 257 258
		ilmd = bq27x00_read(di, BQ27500_REG_DCAP, false);
	else
		ilmd = bq27x00_read(di, BQ27000_REG_ILMD, true);

	if (ilmd < 0) {
259
		dev_dbg(di->dev, "error reading initial last measured discharge\n");
P
Pali Rohár 已提交
260 261 262
		return ilmd;
	}

263
	if (bq27xxx_is_chip_version_higher(di))
P
Pali Rohár 已提交
264 265 266 267 268 269 270
		ilmd *= 1000;
	else
		ilmd = ilmd * 256 * 3570 / BQ27000_RS;

	return ilmd;
}

271 272 273 274 275 276 277 278 279 280
/*
 * Return the battery Available energy in µWh
 * Or < 0 if something fails.
 */
static int bq27x00_battery_read_energy(struct bq27x00_device_info *di)
{
	int ae;

	ae = bq27x00_read(di, BQ27x00_REG_AE, false);
	if (ae < 0) {
281
		dev_dbg(di->dev, "error reading available energy\n");
282 283 284 285 286 287 288 289 290 291 292
		return ae;
	}

	if (di->chip == BQ27500)
		ae *= 1000;
	else
		ae = ae * 29200 / BQ27000_RS;

	return ae;
}

293 294 295 296 297 298 299 300 301 302 303 304 305 306
/*
 * Return the battery temperature in tenths of degree Celsius
 * Or < 0 if something fails.
 */
static int bq27x00_battery_read_temperature(struct bq27x00_device_info *di)
{
	int temp;

	temp = bq27x00_read(di, BQ27x00_REG_TEMP, false);
	if (temp < 0) {
		dev_err(di->dev, "error reading temperature\n");
		return temp;
	}

307
	if (bq27xxx_is_chip_version_higher(di))
308 309 310 311 312 313 314
		temp -= 2731;
	else
		temp = ((temp * 5) - 5463) / 2;

	return temp;
}

P
Pali Rohár 已提交
315 316 317 318 319 320 321 322 323 324 325 326 327 328 329
/*
 * Return the battery Cycle count total
 * Or < 0 if something fails.
 */
static int bq27x00_battery_read_cyct(struct bq27x00_device_info *di)
{
	int cyct;

	cyct = bq27x00_read(di, BQ27x00_REG_CYCT, false);
	if (cyct < 0)
		dev_err(di->dev, "error reading cycle count total\n");

	return cyct;
}

330
/*
331 332
 * Read a time register.
 * Return < 0 if something fails.
333
 */
334
static int bq27x00_battery_read_time(struct bq27x00_device_info *di, u8 reg)
335
{
336
	int tval;
337

338 339
	tval = bq27x00_read(di, reg, false);
	if (tval < 0) {
340 341
		dev_dbg(di->dev, "error reading time register %02x: %d\n",
			reg, tval);
342
		return tval;
343 344
	}

345 346 347 348 349 350
	if (tval == 65535)
		return -ENODATA;

	return tval * 60;
}

351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404
/*
 * Read a power avg register.
 * Return < 0 if something fails.
 */
static int bq27x00_battery_read_pwr_avg(struct bq27x00_device_info *di, u8 reg)
{
	int tval;

	tval = bq27x00_read(di, reg, false);
	if (tval < 0) {
		dev_err(di->dev, "error reading power avg rgister  %02x: %d\n",
			reg, tval);
		return tval;
	}

	if (di->chip == BQ27500)
		return tval;
	else
		return (tval * BQ27x00_POWER_CONSTANT) / BQ27000_RS;
}

/*
 * Read flag register.
 * Return < 0 if something fails.
 */
static int bq27x00_battery_read_health(struct bq27x00_device_info *di)
{
	int tval;

	tval = bq27x00_read(di, BQ27x00_REG_FLAGS, false);
	if (tval < 0) {
		dev_err(di->dev, "error reading flag register:%d\n", tval);
		return tval;
	}

	if ((di->chip == BQ27500)) {
		if (tval & BQ27500_FLAG_SOCF)
			tval = POWER_SUPPLY_HEALTH_DEAD;
		else if (tval & BQ27500_FLAG_OTC)
			tval = POWER_SUPPLY_HEALTH_OVERHEAT;
		else
			tval = POWER_SUPPLY_HEALTH_GOOD;
		return tval;
	} else {
		if (tval & BQ27000_FLAG_EDV1)
			tval = POWER_SUPPLY_HEALTH_DEAD;
		else
			tval = POWER_SUPPLY_HEALTH_GOOD;
		return tval;
	}

	return -1;
}

405 406 407 408
static void bq27x00_update(struct bq27x00_device_info *di)
{
	struct bq27x00_reg_cache cache = {0, };
	bool is_bq27500 = di->chip == BQ27500;
409
	bool is_bq27425 = di->chip == BQ27425;
410

411
	cache.flags = bq27x00_read(di, BQ27x00_REG_FLAGS, !is_bq27500);
412
	if (cache.flags >= 0) {
413 414
		if (!is_bq27500 && !is_bq27425
				&& (cache.flags & BQ27000_FLAG_CI)) {
415
			dev_info(di->dev, "battery is not calibrated! ignoring capacity values\n");
416
			cache.capacity = -ENODATA;
417
			cache.energy = -ENODATA;
418 419 420 421
			cache.time_to_empty = -ENODATA;
			cache.time_to_empty_avg = -ENODATA;
			cache.time_to_full = -ENODATA;
			cache.charge_full = -ENODATA;
422
			cache.health = -ENODATA;
423 424
		} else {
			cache.capacity = bq27x00_battery_read_rsoc(di);
425 426 427 428 429 430 431 432 433 434 435 436
			if (!is_bq27425) {
				cache.energy = bq27x00_battery_read_energy(di);
				cache.time_to_empty =
					bq27x00_battery_read_time(di,
							BQ27x00_REG_TTE);
				cache.time_to_empty_avg =
					bq27x00_battery_read_time(di,
							BQ27x00_REG_TTECP);
				cache.time_to_full =
					bq27x00_battery_read_time(di,
							BQ27x00_REG_TTF);
			}
437
			cache.charge_full = bq27x00_battery_read_lmd(di);
438
			cache.health = bq27x00_battery_read_health(di);
439
		}
440
		cache.temperature = bq27x00_battery_read_temperature(di);
441 442
		if (!is_bq27425)
			cache.cycle_count = bq27x00_battery_read_cyct(di);
443
		cache.cycle_count = bq27x00_battery_read_cyct(di);
444 445
		cache.power_avg =
			bq27x00_battery_read_pwr_avg(di, BQ27x00_POWER_AVG);
446

P
Pali Rohár 已提交
447 448 449
		/* We only have to read charge design full once */
		if (di->charge_design_full <= 0)
			di->charge_design_full = bq27x00_battery_read_ilmd(di);
450 451
	}

452
	if (memcmp(&di->cache, &cache, sizeof(cache)) != 0) {
453 454 455 456 457 458 459
		di->cache = cache;
		power_supply_changed(&di->bat);
	}

	di->last_update = jiffies;
}

L
Lars-Peter Clausen 已提交
460 461 462 463 464 465 466 467 468 469 470 471 472 473
static void bq27x00_battery_poll(struct work_struct *work)
{
	struct bq27x00_device_info *di =
		container_of(work, struct bq27x00_device_info, work.work);

	bq27x00_update(di);

	if (poll_interval > 0) {
		/* The timer does not have to be accurate. */
		set_timer_slack(&di->work.timer, poll_interval * HZ / 4);
		schedule_delayed_work(&di->work, poll_interval * HZ);
	}
}

474
/*
P
Pali Rohár 已提交
475
 * Return the battery average current in µA
476 477 478
 * Note that current can be negative signed as well
 * Or 0 if something fails.
 */
479 480
static int bq27x00_battery_current(struct bq27x00_device_info *di,
	union power_supply_propval *val)
481
{
482
	int curr;
483
	int flags;
484

485
	curr = bq27x00_read(di, BQ27x00_REG_AI, false);
486 487
	if (curr < 0) {
		dev_err(di->dev, "error reading current\n");
488
		return curr;
489
	}
490

491
	if (bq27xxx_is_chip_version_higher(di)) {
492
		/* bq27500 returns signed value */
493
		val->intval = (int)((s16)curr) * 1000;
494
	} else {
495 496
		flags = bq27x00_read(di, BQ27x00_REG_FLAGS, false);
		if (flags & BQ27000_FLAG_CHGS) {
497
			dev_dbg(di->dev, "negative current!\n");
498
			curr = -curr;
499
		}
500

501
		val->intval = curr * 3570 / BQ27000_RS;
502 503
	}

504
	return 0;
505 506
}

507
static int bq27x00_battery_status(struct bq27x00_device_info *di,
508
	union power_supply_propval *val)
509 510 511
{
	int status;

512
	if (bq27xxx_is_chip_version_higher(di)) {
513
		if (di->cache.flags & BQ27500_FLAG_FC)
514
			status = POWER_SUPPLY_STATUS_FULL;
515
		else if (di->cache.flags & BQ27500_FLAG_DSC)
516
			status = POWER_SUPPLY_STATUS_DISCHARGING;
517
		else
518
			status = POWER_SUPPLY_STATUS_CHARGING;
519
	} else {
520 521 522
		if (di->cache.flags & BQ27000_FLAG_FC)
			status = POWER_SUPPLY_STATUS_FULL;
		else if (di->cache.flags & BQ27000_FLAG_CHGS)
523
			status = POWER_SUPPLY_STATUS_CHARGING;
524 525
		else if (power_supply_am_i_supplied(&di->bat))
			status = POWER_SUPPLY_STATUS_NOT_CHARGING;
526 527 528 529 530
		else
			status = POWER_SUPPLY_STATUS_DISCHARGING;
	}

	val->intval = status;
531

532 533 534
	return 0;
}

535 536 537 538 539
static int bq27x00_battery_capacity_level(struct bq27x00_device_info *di,
	union power_supply_propval *val)
{
	int level;

540
	if (bq27xxx_is_chip_version_higher(di)) {
541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564
		if (di->cache.flags & BQ27500_FLAG_FC)
			level = POWER_SUPPLY_CAPACITY_LEVEL_FULL;
		else if (di->cache.flags & BQ27500_FLAG_SOC1)
			level = POWER_SUPPLY_CAPACITY_LEVEL_LOW;
		else if (di->cache.flags & BQ27500_FLAG_SOCF)
			level = POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL;
		else
			level = POWER_SUPPLY_CAPACITY_LEVEL_NORMAL;
	} else {
		if (di->cache.flags & BQ27000_FLAG_FC)
			level = POWER_SUPPLY_CAPACITY_LEVEL_FULL;
		else if (di->cache.flags & BQ27000_FLAG_EDV1)
			level = POWER_SUPPLY_CAPACITY_LEVEL_LOW;
		else if (di->cache.flags & BQ27000_FLAG_EDVF)
			level = POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL;
		else
			level = POWER_SUPPLY_CAPACITY_LEVEL_NORMAL;
	}

	val->intval = level;

	return 0;
}

565
/*
T
Thomas Weber 已提交
566
 * Return the battery Voltage in millivolts
567
 * Or < 0 if something fails.
568
 */
569 570
static int bq27x00_battery_voltage(struct bq27x00_device_info *di,
	union power_supply_propval *val)
571
{
572
	int volt;
573

574
	volt = bq27x00_read(di, BQ27x00_REG_VOLT, false);
575 576
	if (volt < 0) {
		dev_err(di->dev, "error reading voltage\n");
577
		return volt;
578
	}
579

580 581 582 583 584 585 586 587 588 589 590 591
	val->intval = volt * 1000;

	return 0;
}

static int bq27x00_simple_value(int value,
	union power_supply_propval *val)
{
	if (value < 0)
		return value;

	val->intval = value;
592 593 594 595

	return 0;
}

596 597 598 599 600 601 602
#define to_bq27x00_device_info(x) container_of((x), \
				struct bq27x00_device_info, bat);

static int bq27x00_battery_get_property(struct power_supply *psy,
					enum power_supply_property psp,
					union power_supply_propval *val)
{
603
	int ret = 0;
604
	struct bq27x00_device_info *di = to_bq27x00_device_info(psy);
605

L
Lars-Peter Clausen 已提交
606 607 608 609 610 611
	mutex_lock(&di->lock);
	if (time_is_before_jiffies(di->last_update + 5 * HZ)) {
		cancel_delayed_work_sync(&di->work);
		bq27x00_battery_poll(&di->work.work);
	}
	mutex_unlock(&di->lock);
612 613

	if (psp != POWER_SUPPLY_PROP_PRESENT && di->cache.flags < 0)
614
		return -ENODEV;
615 616

	switch (psp) {
617 618 619
	case POWER_SUPPLY_PROP_STATUS:
		ret = bq27x00_battery_status(di, val);
		break;
620
	case POWER_SUPPLY_PROP_VOLTAGE_NOW:
621
		ret = bq27x00_battery_voltage(di, val);
622
		break;
623
	case POWER_SUPPLY_PROP_PRESENT:
624
		val->intval = di->cache.flags < 0 ? 0 : 1;
625 626
		break;
	case POWER_SUPPLY_PROP_CURRENT_NOW:
627
		ret = bq27x00_battery_current(di, val);
628 629
		break;
	case POWER_SUPPLY_PROP_CAPACITY:
630
		ret = bq27x00_simple_value(di->cache.capacity, val);
631
		break;
632 633 634
	case POWER_SUPPLY_PROP_CAPACITY_LEVEL:
		ret = bq27x00_battery_capacity_level(di, val);
		break;
635
	case POWER_SUPPLY_PROP_TEMP:
636
		ret = bq27x00_simple_value(di->cache.temperature, val);
637
		break;
638
	case POWER_SUPPLY_PROP_TIME_TO_EMPTY_NOW:
639
		ret = bq27x00_simple_value(di->cache.time_to_empty, val);
640 641
		break;
	case POWER_SUPPLY_PROP_TIME_TO_EMPTY_AVG:
642
		ret = bq27x00_simple_value(di->cache.time_to_empty_avg, val);
643 644
		break;
	case POWER_SUPPLY_PROP_TIME_TO_FULL_NOW:
645
		ret = bq27x00_simple_value(di->cache.time_to_full, val);
646
		break;
L
Lars-Peter Clausen 已提交
647 648 649
	case POWER_SUPPLY_PROP_TECHNOLOGY:
		val->intval = POWER_SUPPLY_TECHNOLOGY_LION;
		break;
P
Pali Rohár 已提交
650 651 652 653 654 655 656 657 658
	case POWER_SUPPLY_PROP_CHARGE_NOW:
		ret = bq27x00_simple_value(bq27x00_battery_read_nac(di), val);
		break;
	case POWER_SUPPLY_PROP_CHARGE_FULL:
		ret = bq27x00_simple_value(di->cache.charge_full, val);
		break;
	case POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN:
		ret = bq27x00_simple_value(di->charge_design_full, val);
		break;
659 660
	case POWER_SUPPLY_PROP_CYCLE_COUNT:
		ret = bq27x00_simple_value(di->cache.cycle_count, val);
P
Pali Rohár 已提交
661 662
		break;
	case POWER_SUPPLY_PROP_ENERGY_NOW:
663
		ret = bq27x00_simple_value(di->cache.energy, val);
P
Pali Rohár 已提交
664
		break;
665 666 667 668 669 670
	case POWER_SUPPLY_PROP_POWER_AVG:
		ret = bq27x00_simple_value(di->cache.power_avg, val);
		break;
	case POWER_SUPPLY_PROP_HEALTH:
		ret = bq27x00_simple_value(di->cache.health, val);
		break;
671 672 673 674
	default:
		return -EINVAL;
	}

675
	return ret;
676 677
}

L
Lars-Peter Clausen 已提交
678 679 680 681 682 683 684 685
static void bq27x00_external_power_changed(struct power_supply *psy)
{
	struct bq27x00_device_info *di = to_bq27x00_device_info(psy);

	cancel_delayed_work_sync(&di->work);
	schedule_delayed_work(&di->work, 0);
}

686
static int bq27x00_powersupply_init(struct bq27x00_device_info *di)
687
{
688 689
	int ret;

690
	di->bat.type = POWER_SUPPLY_TYPE_BATTERY;
691 692 693 694 695 696 697 698
	di->chip = BQ27425;
	if (di->chip == BQ27425) {
		di->bat.properties = bq27425_battery_props;
		di->bat.num_properties = ARRAY_SIZE(bq27425_battery_props);
	} else {
		di->bat.properties = bq27x00_battery_props;
		di->bat.num_properties = ARRAY_SIZE(bq27x00_battery_props);
	}
699
	di->bat.get_property = bq27x00_battery_get_property;
L
Lars-Peter Clausen 已提交
700 701 702 703
	di->bat.external_power_changed = bq27x00_external_power_changed;

	INIT_DELAYED_WORK(&di->work, bq27x00_battery_poll);
	mutex_init(&di->lock);
704 705 706 707 708 709 710 711 712

	ret = power_supply_register(di->dev, &di->bat);
	if (ret) {
		dev_err(di->dev, "failed to register battery: %d\n", ret);
		return ret;
	}

	dev_info(di->dev, "support ver. %s enabled\n", DRIVER_VERSION);

713 714
	bq27x00_update(di);

715
	return 0;
716 717
}

L
Lars-Peter Clausen 已提交
718 719
static void bq27x00_powersupply_unregister(struct bq27x00_device_info *di)
{
720 721 722 723 724 725 726 727
	/*
	 * power_supply_unregister call bq27x00_battery_get_property which
	 * call bq27x00_battery_poll.
	 * Make sure that bq27x00_battery_poll will not call
	 * schedule_delayed_work again after unregister (which cause OOPS).
	 */
	poll_interval = 0;

L
Lars-Peter Clausen 已提交
728 729 730 731 732 733 734
	cancel_delayed_work_sync(&di->work);

	power_supply_unregister(&di->bat);

	mutex_destroy(&di->lock);
}

735 736 737 738 739 740

/* i2c specific code */
#ifdef CONFIG_BATTERY_BQ27X00_I2C

/* If the system has several batteries we need a different name for each
 * of them...
741
 */
742 743
static DEFINE_IDR(battery_id);
static DEFINE_MUTEX(battery_mutex);
744

745
static int bq27x00_read_i2c(struct bq27x00_device_info *di, u8 reg, bool single)
746
{
747
	struct i2c_client *client = to_i2c_client(di->dev);
748
	struct i2c_msg msg[2];
749
	unsigned char data[2];
750
	int ret;
751 752 753 754

	if (!client->adapter)
		return -ENODEV;

755 756 757 758 759 760 761
	msg[0].addr = client->addr;
	msg[0].flags = 0;
	msg[0].buf = &reg;
	msg[0].len = sizeof(reg);
	msg[1].addr = client->addr;
	msg[1].flags = I2C_M_RD;
	msg[1].buf = data;
762
	if (single)
763
		msg[1].len = 1;
764
	else
765
		msg[1].len = 2;
766

767
	ret = i2c_transfer(client->adapter, msg, ARRAY_SIZE(msg));
768 769 770 771 772 773 774
	if (ret < 0)
		return ret;

	if (!single)
		ret = get_unaligned_le16(data);
	else
		ret = data[0];
775

776
	return ret;
777 778
}

779
static int bq27x00_battery_probe(struct i2c_client *client,
780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796
				 const struct i2c_device_id *id)
{
	char *name;
	struct bq27x00_device_info *di;
	int num;
	int retval = 0;

	/* Get new ID for the new battery device */
	retval = idr_pre_get(&battery_id, GFP_KERNEL);
	if (retval == 0)
		return -ENOMEM;
	mutex_lock(&battery_mutex);
	retval = idr_get_new(&battery_id, client, &num);
	mutex_unlock(&battery_mutex);
	if (retval < 0)
		return retval;

797
	name = kasprintf(GFP_KERNEL, "%s-%d", id->name, num);
798 799 800 801 802 803 804 805 806 807 808 809
	if (!name) {
		dev_err(&client->dev, "failed to allocate device name\n");
		retval = -ENOMEM;
		goto batt_failed_1;
	}

	di = kzalloc(sizeof(*di), GFP_KERNEL);
	if (!di) {
		dev_err(&client->dev, "failed to allocate device info data\n");
		retval = -ENOMEM;
		goto batt_failed_2;
	}
810

811
	di->id = num;
812
	di->dev = &client->dev;
813
	di->chip = id->driver_data;
814 815
	di->bat.name = name;
	di->bus.read = &bq27x00_read_i2c;
816

817 818
	retval = bq27x00_powersupply_init(di);
	if (retval)
819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836
		goto batt_failed_3;

	i2c_set_clientdata(client, di);

	return 0;

batt_failed_3:
	kfree(di);
batt_failed_2:
	kfree(name);
batt_failed_1:
	mutex_lock(&battery_mutex);
	idr_remove(&battery_id, num);
	mutex_unlock(&battery_mutex);

	return retval;
}

837
static int bq27x00_battery_remove(struct i2c_client *client)
838 839 840
{
	struct bq27x00_device_info *di = i2c_get_clientdata(client);

L
Lars-Peter Clausen 已提交
841
	bq27x00_powersupply_unregister(di);
842 843 844 845 846 847 848 849 850 851 852 853

	kfree(di->bat.name);

	mutex_lock(&battery_mutex);
	idr_remove(&battery_id, di->id);
	mutex_unlock(&battery_mutex);

	kfree(di);

	return 0;
}

854 855 856
static const struct i2c_device_id bq27x00_id[] = {
	{ "bq27200", BQ27000 },	/* bq27200 is same as bq27000, but with i2c */
	{ "bq27500", BQ27500 },
857
	{ "bq27425", BQ27425 },
858 859
	{},
};
P
Pali Rohár 已提交
860
MODULE_DEVICE_TABLE(i2c, bq27x00_id);
861

862
static struct i2c_driver bq27x00_battery_driver = {
863
	.driver = {
864
		.name = "bq27x00-battery",
865
	},
866 867 868
	.probe = bq27x00_battery_probe,
	.remove = bq27x00_battery_remove,
	.id_table = bq27x00_id,
869 870
};

871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895
static inline int bq27x00_battery_i2c_init(void)
{
	int ret = i2c_add_driver(&bq27x00_battery_driver);
	if (ret)
		printk(KERN_ERR "Unable to register BQ27x00 i2c driver\n");

	return ret;
}

static inline void bq27x00_battery_i2c_exit(void)
{
	i2c_del_driver(&bq27x00_battery_driver);
}

#else

static inline int bq27x00_battery_i2c_init(void) { return 0; }
static inline void bq27x00_battery_i2c_exit(void) {};

#endif

/* platform specific code */
#ifdef CONFIG_BATTERY_BQ27X00_PLATFORM

static int bq27000_read_platform(struct bq27x00_device_info *di, u8 reg,
896
			bool single)
897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922
{
	struct device *dev = di->dev;
	struct bq27000_platform_data *pdata = dev->platform_data;
	unsigned int timeout = 3;
	int upper, lower;
	int temp;

	if (!single) {
		/* Make sure the value has not changed in between reading the
		 * lower and the upper part */
		upper = pdata->read(dev, reg + 1);
		do {
			temp = upper;
			if (upper < 0)
				return upper;

			lower = pdata->read(dev, reg);
			if (lower < 0)
				return lower;

			upper = pdata->read(dev, reg + 1);
		} while (temp != upper && --timeout);

		if (timeout == 0)
			return -EIO;

923
		return (upper << 8) | lower;
924
	}
925 926

	return pdata->read(dev, reg);
927 928
}

B
Bill Pemberton 已提交
929
static int bq27000_battery_probe(struct platform_device *pdev)
930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971
{
	struct bq27x00_device_info *di;
	struct bq27000_platform_data *pdata = pdev->dev.platform_data;
	int ret;

	if (!pdata) {
		dev_err(&pdev->dev, "no platform_data supplied\n");
		return -EINVAL;
	}

	if (!pdata->read) {
		dev_err(&pdev->dev, "no hdq read callback supplied\n");
		return -EINVAL;
	}

	di = kzalloc(sizeof(*di), GFP_KERNEL);
	if (!di) {
		dev_err(&pdev->dev, "failed to allocate device info data\n");
		return -ENOMEM;
	}

	platform_set_drvdata(pdev, di);

	di->dev = &pdev->dev;
	di->chip = BQ27000;

	di->bat.name = pdata->name ?: dev_name(&pdev->dev);
	di->bus.read = &bq27000_read_platform;

	ret = bq27x00_powersupply_init(di);
	if (ret)
		goto err_free;

	return 0;

err_free:
	platform_set_drvdata(pdev, NULL);
	kfree(di);

	return ret;
}

B
Bill Pemberton 已提交
972
static int bq27000_battery_remove(struct platform_device *pdev)
973 974 975
{
	struct bq27x00_device_info *di = platform_get_drvdata(pdev);

L
Lars-Peter Clausen 已提交
976 977
	bq27x00_powersupply_unregister(di);

978 979 980 981 982 983 984 985
	platform_set_drvdata(pdev, NULL);
	kfree(di);

	return 0;
}

static struct platform_driver bq27000_battery_driver = {
	.probe	= bq27000_battery_probe,
B
Bill Pemberton 已提交
986
	.remove = bq27000_battery_remove,
987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017
	.driver = {
		.name = "bq27000-battery",
		.owner = THIS_MODULE,
	},
};

static inline int bq27x00_battery_platform_init(void)
{
	int ret = platform_driver_register(&bq27000_battery_driver);
	if (ret)
		printk(KERN_ERR "Unable to register BQ27000 platform driver\n");

	return ret;
}

static inline void bq27x00_battery_platform_exit(void)
{
	platform_driver_unregister(&bq27000_battery_driver);
}

#else

static inline int bq27x00_battery_platform_init(void) { return 0; }
static inline void bq27x00_battery_platform_exit(void) {};

#endif

/*
 * Module stuff
 */

1018 1019 1020 1021
static int __init bq27x00_battery_init(void)
{
	int ret;

1022 1023 1024 1025 1026
	ret = bq27x00_battery_i2c_init();
	if (ret)
		return ret;

	ret = bq27x00_battery_platform_init();
1027
	if (ret)
1028
		bq27x00_battery_i2c_exit();
1029 1030 1031 1032 1033 1034 1035

	return ret;
}
module_init(bq27x00_battery_init);

static void __exit bq27x00_battery_exit(void)
{
1036 1037
	bq27x00_battery_platform_exit();
	bq27x00_battery_i2c_exit();
1038 1039 1040 1041 1042 1043
}
module_exit(bq27x00_battery_exit);

MODULE_AUTHOR("Rodolfo Giometti <giometti@linux.it>");
MODULE_DESCRIPTION("BQ27x00 battery monitor driver");
MODULE_LICENSE("GPL");