Commit 0529bf46 authored by Sachin Kamat's avatar Sachin Kamat Committed by Linus Torvalds

drivers/rtc/rtc-ds1305.c: use devm_* APIs

devm_* functions are device managed and make cleanup code simpler.
Signed-off-by: default avatarSachin Kamat <sachin.kamat@linaro.org>
Cc: Jingoo Han <jg1.han@samsung.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent d64132ac
...@@ -619,7 +619,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -619,7 +619,7 @@ static int ds1305_probe(struct spi_device *spi)
return -EINVAL; return -EINVAL;
/* set up driver data */ /* set up driver data */
ds1305 = kzalloc(sizeof *ds1305, GFP_KERNEL); ds1305 = devm_kzalloc(&spi->dev, sizeof(*ds1305), GFP_KERNEL);
if (!ds1305) if (!ds1305)
return -ENOMEM; return -ENOMEM;
ds1305->spi = spi; ds1305->spi = spi;
...@@ -632,7 +632,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -632,7 +632,7 @@ static int ds1305_probe(struct spi_device *spi)
if (status < 0) { if (status < 0) {
dev_dbg(&spi->dev, "can't %s, %d\n", dev_dbg(&spi->dev, "can't %s, %d\n",
"read", status); "read", status);
goto fail0; return status;
} }
dev_dbg(&spi->dev, "ctrl %s: %3ph\n", "read", ds1305->ctrl); dev_dbg(&spi->dev, "ctrl %s: %3ph\n", "read", ds1305->ctrl);
...@@ -644,8 +644,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -644,8 +644,7 @@ static int ds1305_probe(struct spi_device *spi)
*/ */
if ((ds1305->ctrl[0] & 0x38) != 0 || (ds1305->ctrl[1] & 0xfc) != 0) { if ((ds1305->ctrl[0] & 0x38) != 0 || (ds1305->ctrl[1] & 0xfc) != 0) {
dev_dbg(&spi->dev, "RTC chip is not present\n"); dev_dbg(&spi->dev, "RTC chip is not present\n");
status = -ENODEV; return -ENODEV;
goto fail0;
} }
if (ds1305->ctrl[2] == 0) if (ds1305->ctrl[2] == 0)
dev_dbg(&spi->dev, "chip may not be present\n"); dev_dbg(&spi->dev, "chip may not be present\n");
...@@ -664,7 +663,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -664,7 +663,7 @@ static int ds1305_probe(struct spi_device *spi)
dev_dbg(&spi->dev, "clear WP --> %d\n", status); dev_dbg(&spi->dev, "clear WP --> %d\n", status);
if (status < 0) if (status < 0)
goto fail0; return status;
} }
/* on DS1305, maybe start oscillator; like most low power /* on DS1305, maybe start oscillator; like most low power
...@@ -718,7 +717,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -718,7 +717,7 @@ static int ds1305_probe(struct spi_device *spi)
if (status < 0) { if (status < 0) {
dev_dbg(&spi->dev, "can't %s, %d\n", dev_dbg(&spi->dev, "can't %s, %d\n",
"write", status); "write", status);
goto fail0; return status;
} }
dev_dbg(&spi->dev, "ctrl %s: %3ph\n", "write", ds1305->ctrl); dev_dbg(&spi->dev, "ctrl %s: %3ph\n", "write", ds1305->ctrl);
...@@ -730,7 +729,7 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -730,7 +729,7 @@ static int ds1305_probe(struct spi_device *spi)
&value, sizeof value); &value, sizeof value);
if (status < 0) { if (status < 0) {
dev_dbg(&spi->dev, "read HOUR --> %d\n", status); dev_dbg(&spi->dev, "read HOUR --> %d\n", status);
goto fail0; return status;
} }
ds1305->hr12 = (DS1305_HR_12 & value) != 0; ds1305->hr12 = (DS1305_HR_12 & value) != 0;
...@@ -738,12 +737,12 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -738,12 +737,12 @@ static int ds1305_probe(struct spi_device *spi)
dev_dbg(&spi->dev, "AM/PM\n"); dev_dbg(&spi->dev, "AM/PM\n");
/* register RTC ... from here on, ds1305->ctrl needs locking */ /* register RTC ... from here on, ds1305->ctrl needs locking */
ds1305->rtc = rtc_device_register("ds1305", &spi->dev, ds1305->rtc = devm_rtc_device_register(&spi->dev, "ds1305",
&ds1305_ops, THIS_MODULE); &ds1305_ops, THIS_MODULE);
if (IS_ERR(ds1305->rtc)) { if (IS_ERR(ds1305->rtc)) {
status = PTR_ERR(ds1305->rtc); status = PTR_ERR(ds1305->rtc);
dev_dbg(&spi->dev, "register rtc --> %d\n", status); dev_dbg(&spi->dev, "register rtc --> %d\n", status);
goto fail0; return status;
} }
/* Maybe set up alarm IRQ; be ready to handle it triggering right /* Maybe set up alarm IRQ; be ready to handle it triggering right
...@@ -754,12 +753,12 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -754,12 +753,12 @@ static int ds1305_probe(struct spi_device *spi)
*/ */
if (spi->irq) { if (spi->irq) {
INIT_WORK(&ds1305->work, ds1305_work); INIT_WORK(&ds1305->work, ds1305_work);
status = request_irq(spi->irq, ds1305_irq, status = devm_request_irq(&spi->dev, spi->irq, ds1305_irq,
0, dev_name(&ds1305->rtc->dev), ds1305); 0, dev_name(&ds1305->rtc->dev), ds1305);
if (status < 0) { if (status < 0) {
dev_dbg(&spi->dev, "request_irq %d --> %d\n", dev_dbg(&spi->dev, "request_irq %d --> %d\n",
spi->irq, status); spi->irq, status);
goto fail1; return status;
} }
device_set_wakeup_capable(&spi->dev, 1); device_set_wakeup_capable(&spi->dev, 1);
...@@ -769,18 +768,10 @@ static int ds1305_probe(struct spi_device *spi) ...@@ -769,18 +768,10 @@ static int ds1305_probe(struct spi_device *spi)
status = sysfs_create_bin_file(&spi->dev.kobj, &nvram); status = sysfs_create_bin_file(&spi->dev.kobj, &nvram);
if (status < 0) { if (status < 0) {
dev_dbg(&spi->dev, "register nvram --> %d\n", status); dev_dbg(&spi->dev, "register nvram --> %d\n", status);
goto fail2; return status;
} }
return 0; return 0;
fail2:
free_irq(spi->irq, ds1305);
fail1:
rtc_device_unregister(ds1305->rtc);
fail0:
kfree(ds1305);
return status;
} }
static int ds1305_remove(struct spi_device *spi) static int ds1305_remove(struct spi_device *spi)
...@@ -792,13 +783,11 @@ static int ds1305_remove(struct spi_device *spi) ...@@ -792,13 +783,11 @@ static int ds1305_remove(struct spi_device *spi)
/* carefully shut down irq and workqueue, if present */ /* carefully shut down irq and workqueue, if present */
if (spi->irq) { if (spi->irq) {
set_bit(FLAG_EXITING, &ds1305->flags); set_bit(FLAG_EXITING, &ds1305->flags);
free_irq(spi->irq, ds1305); devm_free_irq(&spi->dev, spi->irq, ds1305);
cancel_work_sync(&ds1305->work); cancel_work_sync(&ds1305->work);
} }
rtc_device_unregister(ds1305->rtc);
spi_set_drvdata(spi, NULL); spi_set_drvdata(spi, NULL);
kfree(ds1305);
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