• Home
  • Raw
  • Download

Lines Matching refs:power

77 static bool axp20x_usb_vbus_needs_polling(struct axp20x_usb_power *power)  in axp20x_usb_vbus_needs_polling()  argument
84 if (power->axp20x_id >= AXP221_ID && !power->online) in axp20x_usb_vbus_needs_polling()
92 struct axp20x_usb_power *power = devid; in axp20x_usb_power_irq() local
94 power_supply_changed(power->supply); in axp20x_usb_power_irq()
96 mod_delayed_work(system_power_efficient_wq, &power->vbus_detect, DEBOUNCE_TIME); in axp20x_usb_power_irq()
103 struct axp20x_usb_power *power = in axp20x_usb_power_poll_vbus() local
108 ret = regmap_read(power->regmap, AXP20X_PWR_INPUT_STATUS, &val); in axp20x_usb_power_poll_vbus()
113 if (val != power->old_status) in axp20x_usb_power_poll_vbus()
114 power_supply_changed(power->supply); in axp20x_usb_power_poll_vbus()
116 power->old_status = val; in axp20x_usb_power_poll_vbus()
117 power->online = val & AXP20X_PWR_STATUS_VBUS_USED; in axp20x_usb_power_poll_vbus()
120 if (axp20x_usb_vbus_needs_polling(power)) in axp20x_usb_power_poll_vbus()
121 mod_delayed_work(system_power_efficient_wq, &power->vbus_detect, DEBOUNCE_TIME); in axp20x_usb_power_poll_vbus()
124 static int axp20x_get_current_max(struct axp20x_usb_power *power, int *val) in axp20x_get_current_max() argument
127 int ret = regmap_read(power->regmap, AXP20X_VBUS_IPSOUT_MGMT, &v); in axp20x_get_current_max()
134 if (power->axp20x_id == AXP221_ID) in axp20x_get_current_max()
153 static int axp813_get_current_max(struct axp20x_usb_power *power, int *val) in axp813_get_current_max() argument
156 int ret = regmap_read(power->regmap, AXP20X_VBUS_IPSOUT_MGMT, &v); in axp813_get_current_max()
181 struct axp20x_usb_power *power = power_supply_get_drvdata(psy); in axp20x_usb_power_get_property() local
187 ret = regmap_read(power->regmap, AXP20X_VBUS_IPSOUT_MGMT, &v); in axp20x_usb_power_get_property()
195 ret = iio_read_channel_processed(power->vbus_v, in axp20x_usb_power_get_property()
208 ret = axp20x_read_variable_width(power->regmap, in axp20x_usb_power_get_property()
216 if (power->axp20x_id == AXP813_ID) in axp20x_usb_power_get_property()
217 return axp813_get_current_max(power, &val->intval); in axp20x_usb_power_get_property()
218 return axp20x_get_current_max(power, &val->intval); in axp20x_usb_power_get_property()
221 ret = iio_read_channel_processed(power->vbus_i, in axp20x_usb_power_get_property()
234 ret = axp20x_read_variable_width(power->regmap, in axp20x_usb_power_get_property()
246 ret = regmap_read(power->regmap, AXP20X_PWR_INPUT_STATUS, &input); in axp20x_usb_power_get_property()
259 if (power->axp20x_id == AXP202_ID) { in axp20x_usb_power_get_property()
260 ret = regmap_read(power->regmap, in axp20x_usb_power_get_property()
283 static int axp813_usb_power_set_online(struct axp20x_usb_power *power, in axp813_usb_power_set_online() argument
288 return regmap_update_bits(power->regmap, in axp813_usb_power_set_online()
293 static int axp20x_usb_power_set_voltage_min(struct axp20x_usb_power *power, in axp20x_usb_power_set_voltage_min() argument
308 return regmap_update_bits(power->regmap, in axp20x_usb_power_set_voltage_min()
319 static int axp813_usb_power_set_current_max(struct axp20x_usb_power *power, in axp813_usb_power_set_current_max() argument
326 return regmap_update_bits(power->regmap, in axp813_usb_power_set_current_max()
334 return regmap_update_bits(power->regmap, in axp813_usb_power_set_current_max()
344 static int axp20x_usb_power_set_current_max(struct axp20x_usb_power *power, in axp20x_usb_power_set_current_max() argument
351 if (power->axp20x_id == AXP221_ID) in axp20x_usb_power_set_current_max()
357 return regmap_update_bits(power->regmap, in axp20x_usb_power_set_current_max()
371 struct axp20x_usb_power *power = power_supply_get_drvdata(psy); in axp20x_usb_power_set_property() local
375 if (power->axp20x_id != AXP813_ID) in axp20x_usb_power_set_property()
377 return axp813_usb_power_set_online(power, val->intval); in axp20x_usb_power_set_property()
380 return axp20x_usb_power_set_voltage_min(power, val->intval); in axp20x_usb_power_set_property()
383 if (power->axp20x_id == AXP813_ID) in axp20x_usb_power_set_property()
384 return axp813_usb_power_set_current_max(power, in axp20x_usb_power_set_property()
386 return axp20x_usb_power_set_current_max(power, val->intval); in axp20x_usb_power_set_property()
398 struct axp20x_usb_power *power = power_supply_get_drvdata(psy); in axp20x_usb_power_prop_writeable() local
408 return power->axp20x_id == AXP813_ID; in axp20x_usb_power_prop_writeable()
502 struct axp20x_usb_power *power = dev_get_drvdata(dev); in axp20x_usb_power_suspend() local
511 if (device_may_wakeup(&power->supply->dev)) in axp20x_usb_power_suspend()
512 enable_irq_wake(power->irqs[i++]); in axp20x_usb_power_suspend()
513 while (i < power->num_irqs) in axp20x_usb_power_suspend()
514 disable_irq(power->irqs[i++]); in axp20x_usb_power_suspend()
521 struct axp20x_usb_power *power = dev_get_drvdata(dev); in axp20x_usb_power_resume() local
524 if (device_may_wakeup(&power->supply->dev)) in axp20x_usb_power_resume()
525 disable_irq_wake(power->irqs[i++]); in axp20x_usb_power_resume()
526 while (i < power->num_irqs) in axp20x_usb_power_resume()
527 enable_irq(power->irqs[i++]); in axp20x_usb_power_resume()
529 mod_delayed_work(system_power_efficient_wq, &power->vbus_detect, DEBOUNCE_TIME); in axp20x_usb_power_resume()
539 struct axp20x_usb_power *power) in configure_iio_channels() argument
541 power->vbus_v = devm_iio_channel_get(&pdev->dev, "vbus_v"); in configure_iio_channels()
542 if (IS_ERR(power->vbus_v)) { in configure_iio_channels()
543 if (PTR_ERR(power->vbus_v) == -ENODEV) in configure_iio_channels()
545 return PTR_ERR(power->vbus_v); in configure_iio_channels()
548 power->vbus_i = devm_iio_channel_get(&pdev->dev, "vbus_i"); in configure_iio_channels()
549 if (IS_ERR(power->vbus_i)) { in configure_iio_channels()
550 if (PTR_ERR(power->vbus_i) == -ENODEV) in configure_iio_channels()
552 return PTR_ERR(power->vbus_i); in configure_iio_channels()
558 static int configure_adc_registers(struct axp20x_usb_power *power) in configure_adc_registers() argument
561 return regmap_update_bits(power->regmap, AXP20X_ADC_EN1, in configure_adc_registers()
572 struct axp20x_usb_power *power; in axp20x_usb_power_probe() local
586 power = devm_kzalloc(&pdev->dev, in axp20x_usb_power_probe()
587 struct_size(power, irqs, axp_data->num_irq_names), in axp20x_usb_power_probe()
589 if (!power) in axp20x_usb_power_probe()
592 platform_set_drvdata(pdev, power); in axp20x_usb_power_probe()
594 power->axp20x_id = axp_data->axp20x_id; in axp20x_usb_power_probe()
595 power->regmap = axp20x->regmap; in axp20x_usb_power_probe()
596 power->num_irqs = axp_data->num_irq_names; in axp20x_usb_power_probe()
598 ret = devm_delayed_work_autocancel(&pdev->dev, &power->vbus_detect, in axp20x_usb_power_probe()
603 if (power->axp20x_id == AXP202_ID) { in axp20x_usb_power_probe()
605 ret = regmap_update_bits(power->regmap, AXP20X_VBUS_MON, in axp20x_usb_power_probe()
612 ret = configure_iio_channels(pdev, power); in axp20x_usb_power_probe()
614 ret = configure_adc_registers(power); in axp20x_usb_power_probe()
620 if (power->axp20x_id == AXP813_ID) { in axp20x_usb_power_probe()
629 psy_cfg.drv_data = power; in axp20x_usb_power_probe()
631 power->supply = devm_power_supply_register(&pdev->dev, in axp20x_usb_power_probe()
634 if (IS_ERR(power->supply)) in axp20x_usb_power_probe()
635 return PTR_ERR(power->supply); in axp20x_usb_power_probe()
645 power->irqs[i] = regmap_irq_get_virq(axp20x->regmap_irqc, irq); in axp20x_usb_power_probe()
646 ret = devm_request_any_context_irq(&pdev->dev, power->irqs[i], in axp20x_usb_power_probe()
648 DRVNAME, power); in axp20x_usb_power_probe()
656 if (axp20x_usb_vbus_needs_polling(power)) in axp20x_usb_power_probe()
657 queue_delayed_work(system_power_efficient_wq, &power->vbus_detect, 0); in axp20x_usb_power_probe()