Commit 7f0f07ce authored by Linus Walleij's avatar Linus Walleij Committed by Samuel Ortiz

mfd: Use devm allocation for ab3100-core

Allocate memory and irq for device state using devm_*
helpers to simplify memory accounting.
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
parent 78a27cd3
...@@ -867,7 +867,7 @@ static int __devinit ab3100_probe(struct i2c_client *client, ...@@ -867,7 +867,7 @@ static int __devinit ab3100_probe(struct i2c_client *client,
int err; int err;
int i; int i;
ab3100 = kzalloc(sizeof(struct ab3100), GFP_KERNEL); ab3100 = devm_kzalloc(&client->dev, sizeof(struct ab3100), GFP_KERNEL);
if (!ab3100) { if (!ab3100) {
dev_err(&client->dev, "could not allocate AB3100 device\n"); dev_err(&client->dev, "could not allocate AB3100 device\n");
return -ENOMEM; return -ENOMEM;
...@@ -931,13 +931,13 @@ static int __devinit ab3100_probe(struct i2c_client *client, ...@@ -931,13 +931,13 @@ static int __devinit ab3100_probe(struct i2c_client *client,
if (err) if (err)
goto exit_no_setup; goto exit_no_setup;
err = request_threaded_irq(client->irq, NULL, ab3100_irq_handler, err = devm_request_threaded_irq(&client->dev,
client->irq, NULL, ab3100_irq_handler,
IRQF_ONESHOT, "ab3100-core", ab3100); IRQF_ONESHOT, "ab3100-core", ab3100);
/* This real unpredictable IRQ is of course sampled for entropy */
rand_initialize_irq(client->irq);
if (err) if (err)
goto exit_no_irq; goto exit_no_irq;
/* This real unpredictable IRQ is of course sampled for entropy */
rand_initialize_irq(client->irq);
err = abx500_register_ops(&client->dev, &ab3100_ops); err = abx500_register_ops(&client->dev, &ab3100_ops);
if (err) if (err)
...@@ -962,7 +962,6 @@ static int __devinit ab3100_probe(struct i2c_client *client, ...@@ -962,7 +962,6 @@ static int __devinit ab3100_probe(struct i2c_client *client,
i2c_unregister_device(ab3100->testreg_client); i2c_unregister_device(ab3100->testreg_client);
exit_no_testreg_client: exit_no_testreg_client:
exit_no_detect: exit_no_detect:
kfree(ab3100);
return err; return err;
} }
...@@ -972,16 +971,8 @@ static int __devexit ab3100_remove(struct i2c_client *client) ...@@ -972,16 +971,8 @@ static int __devexit ab3100_remove(struct i2c_client *client)
/* Unregister subdevices */ /* Unregister subdevices */
mfd_remove_devices(&client->dev); mfd_remove_devices(&client->dev);
ab3100_remove_debugfs(); ab3100_remove_debugfs();
i2c_unregister_device(ab3100->testreg_client); i2c_unregister_device(ab3100->testreg_client);
/*
* At this point, all subscribers should have unregistered
* their notifiers so deactivate IRQ
*/
free_irq(client->irq, ab3100);
kfree(ab3100);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment