Commit a75bc6b7 authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Thierry Reding

pwm: twl: Simplify using devm_pwmchip_add()

This allows to drop the platform_driver's remove function. This is the
only user of driver data so this can go away, too.
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent c9bb1c9e
...@@ -298,7 +298,6 @@ static const struct pwm_ops twl6030_pwm_ops = { ...@@ -298,7 +298,6 @@ static const struct pwm_ops twl6030_pwm_ops = {
static int twl_pwm_probe(struct platform_device *pdev) static int twl_pwm_probe(struct platform_device *pdev)
{ {
struct twl_pwm_chip *twl; struct twl_pwm_chip *twl;
int ret;
twl = devm_kzalloc(&pdev->dev, sizeof(*twl), GFP_KERNEL); twl = devm_kzalloc(&pdev->dev, sizeof(*twl), GFP_KERNEL);
if (!twl) if (!twl)
...@@ -314,20 +313,7 @@ static int twl_pwm_probe(struct platform_device *pdev) ...@@ -314,20 +313,7 @@ static int twl_pwm_probe(struct platform_device *pdev)
mutex_init(&twl->mutex); mutex_init(&twl->mutex);
ret = pwmchip_add(&twl->chip); return devm_pwmchip_add(&pdev->dev, &twl->chip);
if (ret < 0)
return ret;
platform_set_drvdata(pdev, twl);
return 0;
}
static int twl_pwm_remove(struct platform_device *pdev)
{
struct twl_pwm_chip *twl = platform_get_drvdata(pdev);
return pwmchip_remove(&twl->chip);
} }
#ifdef CONFIG_OF #ifdef CONFIG_OF
...@@ -345,7 +331,6 @@ static struct platform_driver twl_pwm_driver = { ...@@ -345,7 +331,6 @@ static struct platform_driver twl_pwm_driver = {
.of_match_table = of_match_ptr(twl_pwm_of_match), .of_match_table = of_match_ptr(twl_pwm_of_match),
}, },
.probe = twl_pwm_probe, .probe = twl_pwm_probe,
.remove = twl_pwm_remove,
}; };
module_platform_driver(twl_pwm_driver); module_platform_driver(twl_pwm_driver);
......
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