Lines Matching +full:semi +full:- +full:static

1 // SPDX-License-Identifier: GPL-2.0-only
3 * Power supply driver for the Active-semi ACT8945A PMIC
18 static const char *act8945a_charger_model = "ACT8945A";
19 static const char *act8945a_charger_manufacturer = "Active-semi";
86 static int act8945a_get_charger_state(struct regmap *regmap, int *val) in act8945a_get_charger_state()
125 static int act8945a_get_charge_type(struct regmap *regmap, int *val) in act8945a_get_charge_type()
163 static int act8945a_get_battery_health(struct regmap *regmap, int *val) in act8945a_get_battery_health()
209 static int act8945a_get_capacity_level(struct act8945a_charger *charger, in act8945a_get_capacity_level()
214 int lbo_level = gpiod_get_value(charger->lbo_gpio); in act8945a_get_capacity_level()
268 * Riset(K) = 2336 * (1V/Ichg(mA)) - 0.205
276 static int act8945a_get_current_max(struct act8945a_charger *charger, in act8945a_get_current_max()
282 int chgin_level = gpiod_get_value(charger->chglev_gpio); in act8945a_get_current_max()
331 static enum power_supply_property act8945a_charger_props[] = {
342 static int act8945a_charger_get_property(struct power_supply *psy, in act8945a_charger_get_property()
347 struct regmap *regmap = charger->regmap; in act8945a_charger_get_property()
352 ret = act8945a_get_charger_state(regmap, &val->intval); in act8945a_charger_get_property()
355 ret = act8945a_get_charge_type(regmap, &val->intval); in act8945a_charger_get_property()
358 val->intval = POWER_SUPPLY_TECHNOLOGY_LION; in act8945a_charger_get_property()
361 ret = act8945a_get_battery_health(regmap, &val->intval); in act8945a_charger_get_property()
365 regmap, &val->intval); in act8945a_charger_get_property()
369 regmap, &val->intval); in act8945a_charger_get_property()
372 val->strval = act8945a_charger_model; in act8945a_charger_get_property()
375 val->strval = act8945a_charger_manufacturer; in act8945a_charger_get_property()
378 return -EINVAL; in act8945a_charger_get_property()
384 static int act8945a_enable_interrupt(struct act8945a_charger *charger) in act8945a_enable_interrupt()
386 struct regmap *regmap = charger->regmap; in act8945a_enable_interrupt()
407 static unsigned int act8945a_set_supply_type(struct act8945a_charger *charger, in act8945a_set_supply_type()
413 ret = regmap_read(charger->regmap, ACT8945A_APCH_STATUS, &status); in act8945a_set_supply_type()
417 ret = regmap_read(charger->regmap, ACT8945A_APCH_STATE, &state); in act8945a_set_supply_type()
433 static void act8945a_work(struct work_struct *work) in act8945a_work()
438 act8945a_set_supply_type(charger, &charger->desc.type); in act8945a_work()
440 power_supply_changed(charger->psy); in act8945a_work()
443 static irqreturn_t act8945a_status_changed(int irq, void *dev_id) in act8945a_status_changed()
447 if (charger->init_done) in act8945a_status_changed()
448 schedule_work(&charger->work); in act8945a_status_changed()
457 static int act8945a_charger_config(struct device *dev, in act8945a_charger_config()
460 struct device_node *np = dev->of_node; in act8945a_charger_config()
461 struct regmap *regmap = charger->regmap; in act8945a_charger_config()
473 return -EINVAL; in act8945a_charger_config()
485 charger->lbo_gpio = devm_gpiod_get_optional(dev, "active-semi,lbo", in act8945a_charger_config()
487 if (IS_ERR(charger->lbo_gpio)) { in act8945a_charger_config()
488 err = PTR_ERR(charger->lbo_gpio); in act8945a_charger_config()
493 ret = devm_request_irq(dev, gpiod_to_irq(charger->lbo_gpio), in act8945a_charger_config()
500 charger->chglev_gpio = devm_gpiod_get_optional(dev, in act8945a_charger_config()
501 "active-semi,chglev", in act8945a_charger_config()
503 if (IS_ERR(charger->chglev_gpio)) { in act8945a_charger_config()
504 err = PTR_ERR(charger->chglev_gpio); in act8945a_charger_config()
510 "active-semi,input-voltage-threshold-microvolt", in act8945a_charger_config()
515 "active-semi,precondition-timeout", in act8945a_charger_config()
519 if (of_property_read_u32(np, "active-semi,total-timeout", in act8945a_charger_config()
574 static int act8945a_charger_probe(struct platform_device *pdev) in act8945a_charger_probe()
580 charger = devm_kzalloc(&pdev->dev, sizeof(*charger), GFP_KERNEL); in act8945a_charger_probe()
582 return -ENOMEM; in act8945a_charger_probe()
584 charger->regmap = dev_get_regmap(pdev->dev.parent, NULL); in act8945a_charger_probe()
585 if (!charger->regmap) { in act8945a_charger_probe()
586 dev_err(&pdev->dev, "Parent did not provide regmap\n"); in act8945a_charger_probe()
587 return -EINVAL; in act8945a_charger_probe()
590 ret = act8945a_charger_config(&pdev->dev, charger); in act8945a_charger_probe()
594 irq = of_irq_get(pdev->dev.of_node, 0); in act8945a_charger_probe()
596 dev_err(&pdev->dev, "failed to find IRQ number\n"); in act8945a_charger_probe()
597 return irq ?: -ENXIO; in act8945a_charger_probe()
600 ret = devm_request_irq(&pdev->dev, irq, act8945a_status_changed, in act8945a_charger_probe()
604 dev_err(&pdev->dev, "failed to request nIRQ pin IRQ\n"); in act8945a_charger_probe()
608 charger->desc.name = "act8945a-charger"; in act8945a_charger_probe()
609 charger->desc.get_property = act8945a_charger_get_property; in act8945a_charger_probe()
610 charger->desc.properties = act8945a_charger_props; in act8945a_charger_probe()
611 charger->desc.num_properties = ARRAY_SIZE(act8945a_charger_props); in act8945a_charger_probe()
613 ret = act8945a_set_supply_type(charger, &charger->desc.type); in act8945a_charger_probe()
615 return -EINVAL; in act8945a_charger_probe()
617 psy_cfg.of_node = pdev->dev.of_node; in act8945a_charger_probe()
620 charger->psy = devm_power_supply_register(&pdev->dev, in act8945a_charger_probe()
621 &charger->desc, in act8945a_charger_probe()
623 if (IS_ERR(charger->psy)) { in act8945a_charger_probe()
624 dev_err(&pdev->dev, "failed to register power supply\n"); in act8945a_charger_probe()
625 return PTR_ERR(charger->psy); in act8945a_charger_probe()
630 INIT_WORK(&charger->work, act8945a_work); in act8945a_charger_probe()
634 return -EIO; in act8945a_charger_probe()
636 charger->init_done = true; in act8945a_charger_probe()
641 static void act8945a_charger_remove(struct platform_device *pdev) in act8945a_charger_remove()
645 charger->init_done = false; in act8945a_charger_remove()
646 cancel_work_sync(&charger->work); in act8945a_charger_remove()
649 static struct platform_driver act8945a_charger_driver = {
651 .name = "act8945a-charger",
658 MODULE_DESCRIPTION("Active-semi ACT8945A ActivePath charger driver");