mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-21 21:53:06 +07:00
power: supply: smb347-charger: Use resource-managed API
Simplify code, more convenient to use with Device Tree. Reviewed-by: Dmitry Osipenko <digetx@gmail.com> Signed-off-by: David Heidelberg <david@ixit.cz> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
This commit is contained in:
parent
ef805f2177
commit
2d52f7102b
@ -836,21 +836,31 @@ static int smb347_irq_init(struct smb347_charger *smb,
|
|||||||
struct i2c_client *client)
|
struct i2c_client *client)
|
||||||
{
|
{
|
||||||
const struct smb347_charger_platform_data *pdata = smb->pdata;
|
const struct smb347_charger_platform_data *pdata = smb->pdata;
|
||||||
int ret, irq = gpio_to_irq(pdata->irq_gpio);
|
unsigned long irqflags = IRQF_ONESHOT;
|
||||||
|
int ret;
|
||||||
|
|
||||||
ret = gpio_request_one(pdata->irq_gpio, GPIOF_IN, client->name);
|
/* Requesting GPIO for IRQ is only needed in non-DT way */
|
||||||
if (ret < 0)
|
if (!client->irq) {
|
||||||
goto fail;
|
int irq = gpio_to_irq(pdata->irq_gpio);
|
||||||
|
|
||||||
ret = request_threaded_irq(irq, NULL, smb347_interrupt,
|
ret = devm_gpio_request_one(smb->dev, pdata->irq_gpio,
|
||||||
IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
|
GPIOF_IN, client->name);
|
||||||
client->name, smb);
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
irqflags |= IRQF_TRIGGER_FALLING;
|
||||||
|
client->irq = irq;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = devm_request_threaded_irq(smb->dev, client->irq, NULL,
|
||||||
|
smb347_interrupt, irqflags,
|
||||||
|
client->name, smb);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto fail_gpio;
|
return ret;
|
||||||
|
|
||||||
ret = smb347_set_writable(smb, true);
|
ret = smb347_set_writable(smb, true);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto fail_irq;
|
return ret;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Configure the STAT output to be suitable for interrupts: disable
|
* Configure the STAT output to be suitable for interrupts: disable
|
||||||
@ -860,20 +870,10 @@ static int smb347_irq_init(struct smb347_charger *smb,
|
|||||||
CFG_STAT_ACTIVE_HIGH | CFG_STAT_DISABLED,
|
CFG_STAT_ACTIVE_HIGH | CFG_STAT_DISABLED,
|
||||||
CFG_STAT_DISABLED);
|
CFG_STAT_DISABLED);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto fail_readonly;
|
client->irq = 0;
|
||||||
|
|
||||||
smb347_set_writable(smb, false);
|
smb347_set_writable(smb, false);
|
||||||
client->irq = irq;
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
fail_readonly:
|
|
||||||
smb347_set_writable(smb, false);
|
|
||||||
fail_irq:
|
|
||||||
free_irq(irq, smb);
|
|
||||||
fail_gpio:
|
|
||||||
gpio_free(pdata->irq_gpio);
|
|
||||||
fail:
|
|
||||||
client->irq = 0;
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1251,32 +1251,24 @@ static int smb347_probe(struct i2c_client *client,
|
|||||||
mains_usb_cfg.num_supplicants = ARRAY_SIZE(battery);
|
mains_usb_cfg.num_supplicants = ARRAY_SIZE(battery);
|
||||||
mains_usb_cfg.drv_data = smb;
|
mains_usb_cfg.drv_data = smb;
|
||||||
if (smb->pdata->use_mains) {
|
if (smb->pdata->use_mains) {
|
||||||
smb->mains = power_supply_register(dev, &smb347_mains_desc,
|
smb->mains = devm_power_supply_register(dev, &smb347_mains_desc,
|
||||||
&mains_usb_cfg);
|
&mains_usb_cfg);
|
||||||
if (IS_ERR(smb->mains))
|
if (IS_ERR(smb->mains))
|
||||||
return PTR_ERR(smb->mains);
|
return PTR_ERR(smb->mains);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (smb->pdata->use_usb) {
|
if (smb->pdata->use_usb) {
|
||||||
smb->usb = power_supply_register(dev, &smb347_usb_desc,
|
smb->usb = devm_power_supply_register(dev, &smb347_usb_desc,
|
||||||
&mains_usb_cfg);
|
&mains_usb_cfg);
|
||||||
if (IS_ERR(smb->usb)) {
|
if (IS_ERR(smb->usb))
|
||||||
if (smb->pdata->use_mains)
|
|
||||||
power_supply_unregister(smb->mains);
|
|
||||||
return PTR_ERR(smb->usb);
|
return PTR_ERR(smb->usb);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
battery_cfg.drv_data = smb;
|
battery_cfg.drv_data = smb;
|
||||||
smb->battery = power_supply_register(dev, &smb347_battery_desc,
|
smb->battery = devm_power_supply_register(dev, &smb347_battery_desc,
|
||||||
&battery_cfg);
|
&battery_cfg);
|
||||||
if (IS_ERR(smb->battery)) {
|
if (IS_ERR(smb->battery))
|
||||||
if (smb->pdata->use_usb)
|
|
||||||
power_supply_unregister(smb->usb);
|
|
||||||
if (smb->pdata->use_mains)
|
|
||||||
power_supply_unregister(smb->mains);
|
|
||||||
return PTR_ERR(smb->battery);
|
return PTR_ERR(smb->battery);
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Interrupt pin is optional. If it is connected, we setup the
|
* Interrupt pin is optional. If it is connected, we setup the
|
||||||
@ -1299,17 +1291,8 @@ static int smb347_remove(struct i2c_client *client)
|
|||||||
{
|
{
|
||||||
struct smb347_charger *smb = i2c_get_clientdata(client);
|
struct smb347_charger *smb = i2c_get_clientdata(client);
|
||||||
|
|
||||||
if (client->irq) {
|
if (client->irq)
|
||||||
smb347_irq_disable(smb);
|
smb347_irq_disable(smb);
|
||||||
free_irq(client->irq, smb);
|
|
||||||
gpio_free(smb->pdata->irq_gpio);
|
|
||||||
}
|
|
||||||
|
|
||||||
power_supply_unregister(smb->battery);
|
|
||||||
if (smb->pdata->use_usb)
|
|
||||||
power_supply_unregister(smb->usb);
|
|
||||||
if (smb->pdata->use_mains)
|
|
||||||
power_supply_unregister(smb->mains);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user