Commit 5b25a71b authored by Alexandre Belloni's avatar Alexandre Belloni

rtc: mv: convert to devm_rtc_allocate_device

This allows further improvement of the driver.
Tested-by: default avatarGregory CLEMENT <gregory.clement@bootlin.com>
Signed-off-by: default avatarAlexandre Belloni <alexandre.belloni@bootlin.com>
parent b6743615
...@@ -254,15 +254,7 @@ static int __init mv_rtc_probe(struct platform_device *pdev) ...@@ -254,15 +254,7 @@ static int __init mv_rtc_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, pdata); platform_set_drvdata(pdev, pdata);
if (pdata->irq >= 0) { pdata->rtc = devm_rtc_allocate_device(&pdev->dev);
device_init_wakeup(&pdev->dev, 1);
pdata->rtc = devm_rtc_device_register(&pdev->dev, pdev->name,
&mv_rtc_alarm_ops,
THIS_MODULE);
} else {
pdata->rtc = devm_rtc_device_register(&pdev->dev, pdev->name,
&mv_rtc_ops, THIS_MODULE);
}
if (IS_ERR(pdata->rtc)) { if (IS_ERR(pdata->rtc)) {
ret = PTR_ERR(pdata->rtc); ret = PTR_ERR(pdata->rtc);
goto out; goto out;
...@@ -278,7 +270,16 @@ static int __init mv_rtc_probe(struct platform_device *pdev) ...@@ -278,7 +270,16 @@ static int __init mv_rtc_probe(struct platform_device *pdev)
} }
} }
return 0; if (pdata->irq >= 0) {
device_init_wakeup(&pdev->dev, 1);
pdata->rtc->ops = &mv_rtc_alarm_ops;
} else {
pdata->rtc->ops = &mv_rtc_ops;
}
ret = rtc_register_device(pdata->rtc);
if (!ret)
return 0;
out: out:
if (!IS_ERR(pdata->clk)) if (!IS_ERR(pdata->clk))
clk_disable_unprepare(pdata->clk); clk_disable_unprepare(pdata->clk);
......
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