diff options
author | Marcus Cooper <marcus.xm.cooper@stericsson.com> | 2013-01-11 08:12:54 -0500 |
---|---|---|
committer | Anton Vorontsov <anton@enomsg.org> | 2013-01-15 20:43:46 -0500 |
commit | ea4024017831d61874351defe8f8c58ae73f8009 (patch) | |
tree | 0411f756d15ee826c05a603e1218125a0410fcc0 /drivers/power/ab8500_bmdata.c | |
parent | a864c5a869dcdb40617fc15166385e0ffa609592 (diff) |
ab8500_bm: Recharge condition not optimal for battery
Today the battery recharge is determined with a voltage threshold. This
voltage threshold is only valid when the battery is relaxed. In charging
algorithm the voltage read is the loaded battery voltage and no
compensation is done to get the relaxed voltage. When maintenance
charging is not selected, this makes the recharging condition to almost
immediately activate when there is a discharge present on the battery.
Depending on which vendor the battery comes from this behavior can wear
out the battery much faster than normal.
The fuelgauge driver is responsible to monitor the actual battery
capacity and is able to estimate the remaining capacity. It is better to
use the remaining capacity as a limit to determine when battery should
be recharged.
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Marcus Cooper <marcus.xm.cooper@stericsson.com>
Reviewed-by: Hakan BERG <hakan.berg@stericsson.com>
Reviewed-by: Jonas ABERG <jonas.aberg@stericsson.com>
Signed-off-by: Anton Vorontsov <anton@enomsg.org>
Diffstat (limited to 'drivers/power/ab8500_bmdata.c')
-rw-r--r-- | drivers/power/ab8500_bmdata.c | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/drivers/power/ab8500_bmdata.c b/drivers/power/ab8500_bmdata.c index 0bf52369d6a5..20c157b4fe99 100644 --- a/drivers/power/ab8500_bmdata.c +++ b/drivers/power/ab8500_bmdata.c | |||
@@ -192,7 +192,7 @@ static struct abx500_battery_type bat_type_thermistor[] = { | |||
192 | .nominal_voltage = 3700, | 192 | .nominal_voltage = 3700, |
193 | .termination_vol = 4050, | 193 | .termination_vol = 4050, |
194 | .termination_curr = 200, | 194 | .termination_curr = 200, |
195 | .recharge_vol = 3990, | 195 | .recharge_cap = 95, |
196 | .normal_cur_lvl = 400, | 196 | .normal_cur_lvl = 400, |
197 | .normal_vol_lvl = 4100, | 197 | .normal_vol_lvl = 4100, |
198 | .maint_a_cur_lvl = 400, | 198 | .maint_a_cur_lvl = 400, |
@@ -219,7 +219,7 @@ static struct abx500_battery_type bat_type_thermistor[] = { | |||
219 | .nominal_voltage = 3600, | 219 | .nominal_voltage = 3600, |
220 | .termination_vol = 4150, | 220 | .termination_vol = 4150, |
221 | .termination_curr = 80, | 221 | .termination_curr = 80, |
222 | .recharge_vol = 4130, | 222 | .recharge_cap = 95, |
223 | .normal_cur_lvl = 700, | 223 | .normal_cur_lvl = 700, |
224 | .normal_vol_lvl = 4200, | 224 | .normal_vol_lvl = 4200, |
225 | .maint_a_cur_lvl = 600, | 225 | .maint_a_cur_lvl = 600, |
@@ -247,7 +247,7 @@ static struct abx500_battery_type bat_type_thermistor[] = { | |||
247 | .nominal_voltage = 3600, | 247 | .nominal_voltage = 3600, |
248 | .termination_vol = 4150, | 248 | .termination_vol = 4150, |
249 | .termination_curr = 80, | 249 | .termination_curr = 80, |
250 | .recharge_vol = 4130, | 250 | .recharge_cap = 95, |
251 | .normal_cur_lvl = 700, | 251 | .normal_cur_lvl = 700, |
252 | .normal_vol_lvl = 4200, | 252 | .normal_vol_lvl = 4200, |
253 | .maint_a_cur_lvl = 600, | 253 | .maint_a_cur_lvl = 600, |
@@ -278,7 +278,7 @@ static struct abx500_battery_type bat_type_ext_thermistor[] = { | |||
278 | .nominal_voltage = 3700, | 278 | .nominal_voltage = 3700, |
279 | .termination_vol = 4050, | 279 | .termination_vol = 4050, |
280 | .termination_curr = 200, | 280 | .termination_curr = 200, |
281 | .recharge_vol = 3990, | 281 | .recharge_cap = 95, |
282 | .normal_cur_lvl = 400, | 282 | .normal_cur_lvl = 400, |
283 | .normal_vol_lvl = 4100, | 283 | .normal_vol_lvl = 4100, |
284 | .maint_a_cur_lvl = 400, | 284 | .maint_a_cur_lvl = 400, |
@@ -310,7 +310,7 @@ static struct abx500_battery_type bat_type_ext_thermistor[] = { | |||
310 | .nominal_voltage = 3700, | 310 | .nominal_voltage = 3700, |
311 | .termination_vol = 4150, | 311 | .termination_vol = 4150, |
312 | .termination_curr = 100, | 312 | .termination_curr = 100, |
313 | .recharge_vol = 4130, | 313 | .recharge_cap = 95, |
314 | .normal_cur_lvl = 700, | 314 | .normal_cur_lvl = 700, |
315 | .normal_vol_lvl = 4200, | 315 | .normal_vol_lvl = 4200, |
316 | .maint_a_cur_lvl = 600, | 316 | .maint_a_cur_lvl = 600, |
@@ -337,7 +337,7 @@ static struct abx500_battery_type bat_type_ext_thermistor[] = { | |||
337 | .nominal_voltage = 3700, | 337 | .nominal_voltage = 3700, |
338 | .termination_vol = 4150, | 338 | .termination_vol = 4150, |
339 | .termination_curr = 100, | 339 | .termination_curr = 100, |
340 | .recharge_vol = 4130, | 340 | .recharge_cap = 95, |
341 | .normal_cur_lvl = 700, | 341 | .normal_cur_lvl = 700, |
342 | .normal_vol_lvl = 4200, | 342 | .normal_vol_lvl = 4200, |
343 | .maint_a_cur_lvl = 600, | 343 | .maint_a_cur_lvl = 600, |
@@ -364,7 +364,7 @@ static struct abx500_battery_type bat_type_ext_thermistor[] = { | |||
364 | .nominal_voltage = 3700, | 364 | .nominal_voltage = 3700, |
365 | .termination_vol = 4150, | 365 | .termination_vol = 4150, |
366 | .termination_curr = 100, | 366 | .termination_curr = 100, |
367 | .recharge_vol = 4130, | 367 | .recharge_cap = 95, |
368 | .normal_cur_lvl = 700, | 368 | .normal_cur_lvl = 700, |
369 | .normal_vol_lvl = 4200, | 369 | .normal_vol_lvl = 4200, |
370 | .maint_a_cur_lvl = 600, | 370 | .maint_a_cur_lvl = 600, |
@@ -405,8 +405,8 @@ static const struct abx500_fg_parameters fg = { | |||
405 | .lowbat_threshold = 3100, | 405 | .lowbat_threshold = 3100, |
406 | .battok_falling_th_sel0 = 2860, | 406 | .battok_falling_th_sel0 = 2860, |
407 | .battok_raising_th_sel1 = 2860, | 407 | .battok_raising_th_sel1 = 2860, |
408 | .maint_thres = 95, | ||
408 | .user_cap_limit = 15, | 409 | .user_cap_limit = 15, |
409 | .maint_thres = 97, | ||
410 | }; | 410 | }; |
411 | 411 | ||
412 | static const struct abx500_maxim_parameters maxi_params = { | 412 | static const struct abx500_maxim_parameters maxi_params = { |
@@ -435,6 +435,7 @@ struct abx500_bm_data ab8500_bm_data = { | |||
435 | .bkup_bat_v = BUP_VCH_SEL_2P6V, | 435 | .bkup_bat_v = BUP_VCH_SEL_2P6V, |
436 | .bkup_bat_i = BUP_ICH_SEL_150UA, | 436 | .bkup_bat_i = BUP_ICH_SEL_150UA, |
437 | .no_maintenance = false, | 437 | .no_maintenance = false, |
438 | .capacity_scaling = false, | ||
438 | .adc_therm = ABx500_ADC_THERM_BATCTRL, | 439 | .adc_therm = ABx500_ADC_THERM_BATCTRL, |
439 | .chg_unknown_bat = false, | 440 | .chg_unknown_bat = false, |
440 | .enable_overshoot = false, | 441 | .enable_overshoot = false, |
@@ -479,7 +480,7 @@ int __devinit ab8500_bm_of_probe(struct device *dev, | |||
479 | bm->chg_unknown_bat = true; | 480 | bm->chg_unknown_bat = true; |
480 | bm->bat_type[BATTERY_UNKNOWN].charge_full_design = 2600; | 481 | bm->bat_type[BATTERY_UNKNOWN].charge_full_design = 2600; |
481 | bm->bat_type[BATTERY_UNKNOWN].termination_vol = 4150; | 482 | bm->bat_type[BATTERY_UNKNOWN].termination_vol = 4150; |
482 | bm->bat_type[BATTERY_UNKNOWN].recharge_vol = 4130; | 483 | bm->bat_type[BATTERY_UNKNOWN].recharge_cap = 95; |
483 | bm->bat_type[BATTERY_UNKNOWN].normal_cur_lvl = 520; | 484 | bm->bat_type[BATTERY_UNKNOWN].normal_cur_lvl = 520; |
484 | bm->bat_type[BATTERY_UNKNOWN].normal_vol_lvl = 4200; | 485 | bm->bat_type[BATTERY_UNKNOWN].normal_vol_lvl = 4200; |
485 | } | 486 | } |