power: supply: twl4030-charger: add writable INPUT_CURRENT_LIMIT property
Currently, the twl4030 charger defines its own max_current by directly creating sysfs nodes. It should use the input_current_limit property which is e.g. used by the bq24257 driver. This patch adds the input_current_property with the same semantics as the max_current property. The code to manage the max_current property is removed by a separate patch. Signed-off-by: H. Nikolaus Schaller <hns@goldelico.com> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.co.uk>
This commit is contained in:
parent
6cf62a3b97
commit
3fb319c2cd
|
@ -922,6 +922,28 @@ static int twl4030_bci_get_property(struct power_supply *psy,
|
||||||
twl4030_bci_state_to_status(state) !=
|
twl4030_bci_state_to_status(state) !=
|
||||||
POWER_SUPPLY_STATUS_NOT_CHARGING;
|
POWER_SUPPLY_STATUS_NOT_CHARGING;
|
||||||
break;
|
break;
|
||||||
|
case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
|
||||||
|
val->intval = -1;
|
||||||
|
if (psy->desc->type != POWER_SUPPLY_TYPE_USB) {
|
||||||
|
if (!bci->ac_is_active)
|
||||||
|
val->intval = bci->ac_cur;
|
||||||
|
} else {
|
||||||
|
if (bci->ac_is_active)
|
||||||
|
val->intval = bci->usb_cur_target;
|
||||||
|
}
|
||||||
|
if (val->intval < 0) {
|
||||||
|
u8 bcictl1;
|
||||||
|
|
||||||
|
val->intval = twl4030bci_read_adc_val(TWL4030_BCIIREF1);
|
||||||
|
if (val->intval < 0)
|
||||||
|
return val->intval;
|
||||||
|
ret = twl4030_bci_read(TWL4030_BCICTL1, &bcictl1);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
val->intval = regval2ua(val->intval, bcictl1 &
|
||||||
|
TWL4030_CGAIN);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -929,11 +951,44 @@ static int twl4030_bci_get_property(struct power_supply *psy,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int twl4030_bci_set_property(struct power_supply *psy,
|
||||||
|
enum power_supply_property psp,
|
||||||
|
const union power_supply_propval *val)
|
||||||
|
{
|
||||||
|
struct twl4030_bci *bci = dev_get_drvdata(psy->dev.parent);
|
||||||
|
|
||||||
|
switch (psp) {
|
||||||
|
case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
|
||||||
|
if (psy->desc->type == POWER_SUPPLY_TYPE_USB)
|
||||||
|
bci->usb_cur_target = val->intval;
|
||||||
|
else
|
||||||
|
bci->ac_cur = val->intval;
|
||||||
|
twl4030_charger_update_current(bci);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int twl4030_bci_property_is_writeable(struct power_supply *psy,
|
||||||
|
enum power_supply_property psp)
|
||||||
|
{
|
||||||
|
switch (psp) {
|
||||||
|
case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static enum power_supply_property twl4030_charger_props[] = {
|
static enum power_supply_property twl4030_charger_props[] = {
|
||||||
POWER_SUPPLY_PROP_STATUS,
|
POWER_SUPPLY_PROP_STATUS,
|
||||||
POWER_SUPPLY_PROP_ONLINE,
|
POWER_SUPPLY_PROP_ONLINE,
|
||||||
POWER_SUPPLY_PROP_VOLTAGE_NOW,
|
POWER_SUPPLY_PROP_VOLTAGE_NOW,
|
||||||
POWER_SUPPLY_PROP_CURRENT_NOW,
|
POWER_SUPPLY_PROP_CURRENT_NOW,
|
||||||
|
POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT,
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_OF
|
#ifdef CONFIG_OF
|
||||||
|
@ -970,6 +1025,8 @@ static const struct power_supply_desc twl4030_bci_ac_desc = {
|
||||||
.properties = twl4030_charger_props,
|
.properties = twl4030_charger_props,
|
||||||
.num_properties = ARRAY_SIZE(twl4030_charger_props),
|
.num_properties = ARRAY_SIZE(twl4030_charger_props),
|
||||||
.get_property = twl4030_bci_get_property,
|
.get_property = twl4030_bci_get_property,
|
||||||
|
.set_property = twl4030_bci_set_property,
|
||||||
|
.property_is_writeable = twl4030_bci_property_is_writeable,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct power_supply_desc twl4030_bci_usb_desc = {
|
static const struct power_supply_desc twl4030_bci_usb_desc = {
|
||||||
|
@ -978,6 +1035,8 @@ static const struct power_supply_desc twl4030_bci_usb_desc = {
|
||||||
.properties = twl4030_charger_props,
|
.properties = twl4030_charger_props,
|
||||||
.num_properties = ARRAY_SIZE(twl4030_charger_props),
|
.num_properties = ARRAY_SIZE(twl4030_charger_props),
|
||||||
.get_property = twl4030_bci_get_property,
|
.get_property = twl4030_bci_get_property,
|
||||||
|
.set_property = twl4030_bci_set_property,
|
||||||
|
.property_is_writeable = twl4030_bci_property_is_writeable,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int twl4030_bci_probe(struct platform_device *pdev)
|
static int twl4030_bci_probe(struct platform_device *pdev)
|
||||||
|
|
Loading…
Reference in New Issue