Commit 6192fa87 authored by Axel Lin's avatar Axel Lin Committed by Thierry Reding

pwm: Convert pwm-samsung to use devm_* APIs

Signed-off-by: default avatarAxel Lin <axel.lin@gmail.com>
Signed-off-by: default avatarThierry Reding <thierry.reding@avionic-design.de>
parent 0c8f527d
/* arch/arm/plat-s3c/pwm.c /* drivers/pwm/pwm-samsung.c
* *
* Copyright (c) 2007 Ben Dooks * Copyright (c) 2007 Ben Dooks
* Copyright (c) 2008 Simtec Electronics * Copyright (c) 2008 Simtec Electronics
...@@ -215,7 +215,7 @@ static int s3c_pwm_probe(struct platform_device *pdev) ...@@ -215,7 +215,7 @@ static int s3c_pwm_probe(struct platform_device *pdev)
return -ENXIO; return -ENXIO;
} }
s3c = kzalloc(sizeof(*s3c), GFP_KERNEL); s3c = devm_kzalloc(&pdev->dev, sizeof(*s3c), GFP_KERNEL);
if (s3c == NULL) { if (s3c == NULL) {
dev_err(dev, "failed to allocate pwm_device\n"); dev_err(dev, "failed to allocate pwm_device\n");
return -ENOMEM; return -ENOMEM;
...@@ -227,18 +227,16 @@ static int s3c_pwm_probe(struct platform_device *pdev) ...@@ -227,18 +227,16 @@ static int s3c_pwm_probe(struct platform_device *pdev)
s3c->chip.base = -1; s3c->chip.base = -1;
s3c->chip.npwm = 1; s3c->chip.npwm = 1;
s3c->clk = clk_get(dev, "pwm-tin"); s3c->clk = devm_clk_get(dev, "pwm-tin");
if (IS_ERR(s3c->clk)) { if (IS_ERR(s3c->clk)) {
dev_err(dev, "failed to get pwm tin clk\n"); dev_err(dev, "failed to get pwm tin clk\n");
ret = PTR_ERR(s3c->clk); return PTR_ERR(s3c->clk);
goto err_alloc;
} }
s3c->clk_div = clk_get(dev, "pwm-tdiv"); s3c->clk_div = devm_clk_get(dev, "pwm-tdiv");
if (IS_ERR(s3c->clk_div)) { if (IS_ERR(s3c->clk_div)) {
dev_err(dev, "failed to get pwm tdiv clk\n"); dev_err(dev, "failed to get pwm tdiv clk\n");
ret = PTR_ERR(s3c->clk_div); return PTR_ERR(s3c->clk_div);
goto err_clk_tin;
} }
clk_enable(s3c->clk); clk_enable(s3c->clk);
...@@ -272,13 +270,6 @@ static int s3c_pwm_probe(struct platform_device *pdev) ...@@ -272,13 +270,6 @@ static int s3c_pwm_probe(struct platform_device *pdev)
err_clk_tdiv: err_clk_tdiv:
clk_disable(s3c->clk_div); clk_disable(s3c->clk_div);
clk_disable(s3c->clk); clk_disable(s3c->clk);
clk_put(s3c->clk_div);
err_clk_tin:
clk_put(s3c->clk);
err_alloc:
kfree(s3c);
return ret; return ret;
} }
...@@ -293,9 +284,6 @@ static int __devexit s3c_pwm_remove(struct platform_device *pdev) ...@@ -293,9 +284,6 @@ static int __devexit s3c_pwm_remove(struct platform_device *pdev)
clk_disable(s3c->clk_div); clk_disable(s3c->clk_div);
clk_disable(s3c->clk); clk_disable(s3c->clk);
clk_put(s3c->clk_div);
clk_put(s3c->clk);
kfree(s3c);
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