mirror of
https://github.com/torvalds/linux.git
synced 2024-11-23 12:42:02 +00:00
power: bq25890: use proper CURRENT_NOW property for I_BAT
Charge Current is more apropriately reflected by CURRENT_NOW property (measured current) than CONSTANT_CURRENT_VOLTAGE (configured CC-phase current limit). Fix the reference and make the sign reflect direction of the current. Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
This commit is contained in:
parent
0383024f81
commit
1e4724d0b7
@ -427,15 +427,6 @@ static int bq25890_power_supply_get_property(struct power_supply *psy,
|
|||||||
val->intval = POWER_SUPPLY_HEALTH_UNSPEC_FAILURE;
|
val->intval = POWER_SUPPLY_HEALTH_UNSPEC_FAILURE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT:
|
|
||||||
ret = bq25890_field_read(bq, F_ICHGR); /* read measured value */
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
/* converted_val = ADC_val * 50mA (table 10.3.19) */
|
|
||||||
val->intval = ret * 50000;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX:
|
case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX:
|
||||||
val->intval = bq25890_find_val(bq->init_data.ichg, TBL_ICHG);
|
val->intval = bq25890_find_val(bq->init_data.ichg, TBL_ICHG);
|
||||||
break;
|
break;
|
||||||
@ -471,6 +462,15 @@ static int bq25890_power_supply_get_property(struct power_supply *psy,
|
|||||||
val->intval = 2304000 + ret * 20000;
|
val->intval = 2304000 + ret * 20000;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case POWER_SUPPLY_PROP_CURRENT_NOW:
|
||||||
|
ret = bq25890_field_read(bq, F_ICHGR); /* read measured value */
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
/* converted_val = ADC_val * 50mA (table 10.3.19) */
|
||||||
|
val->intval = ret * -50000;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
@ -645,12 +645,12 @@ static const enum power_supply_property bq25890_power_supply_props[] = {
|
|||||||
POWER_SUPPLY_PROP_STATUS,
|
POWER_SUPPLY_PROP_STATUS,
|
||||||
POWER_SUPPLY_PROP_ONLINE,
|
POWER_SUPPLY_PROP_ONLINE,
|
||||||
POWER_SUPPLY_PROP_HEALTH,
|
POWER_SUPPLY_PROP_HEALTH,
|
||||||
POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT,
|
|
||||||
POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX,
|
POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX,
|
||||||
POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE,
|
POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE,
|
||||||
POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX,
|
POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX,
|
||||||
POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT,
|
POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT,
|
||||||
POWER_SUPPLY_PROP_VOLTAGE_NOW,
|
POWER_SUPPLY_PROP_VOLTAGE_NOW,
|
||||||
|
POWER_SUPPLY_PROP_CURRENT_NOW,
|
||||||
};
|
};
|
||||||
|
|
||||||
static char *bq25890_charger_supplied_to[] = {
|
static char *bq25890_charger_supplied_to[] = {
|
||||||
|
Loading…
Reference in New Issue
Block a user