diff options
Diffstat (limited to 'drivers/rtc')
-rw-r--r-- | drivers/rtc/rtc-isl1208.c | 36 |
1 files changed, 11 insertions, 25 deletions
diff --git a/drivers/rtc/rtc-isl1208.c b/drivers/rtc/rtc-isl1208.c index 5a0bf7ce1033..c3c549d511b9 100644 --- a/drivers/rtc/rtc-isl1208.c +++ b/drivers/rtc/rtc-isl1208.c | |||
@@ -643,10 +643,11 @@ isl1208_probe(struct i2c_client *client, const struct i2c_device_id *id) | |||
643 | "chip found, driver version " DRV_VERSION "\n"); | 643 | "chip found, driver version " DRV_VERSION "\n"); |
644 | 644 | ||
645 | if (client->irq > 0) { | 645 | if (client->irq > 0) { |
646 | rc = request_threaded_irq(client->irq, NULL, | 646 | rc = devm_request_threaded_irq(&client->dev, client->irq, NULL, |
647 | isl1208_rtc_interrupt, | 647 | isl1208_rtc_interrupt, |
648 | IRQF_SHARED, | 648 | IRQF_SHARED, |
649 | isl1208_driver.driver.name, client); | 649 | isl1208_driver.driver.name, |
650 | client); | ||
650 | if (!rc) { | 651 | if (!rc) { |
651 | device_init_wakeup(&client->dev, 1); | 652 | device_init_wakeup(&client->dev, 1); |
652 | enable_irq_wake(client->irq); | 653 | enable_irq_wake(client->irq); |
@@ -658,20 +659,18 @@ isl1208_probe(struct i2c_client *client, const struct i2c_device_id *id) | |||
658 | } | 659 | } |
659 | } | 660 | } |
660 | 661 | ||
661 | rtc = rtc_device_register(isl1208_driver.driver.name, | 662 | rtc = devm_rtc_device_register(&client->dev, isl1208_driver.driver.name, |
662 | &client->dev, &isl1208_rtc_ops, | 663 | &isl1208_rtc_ops, |
663 | THIS_MODULE); | 664 | THIS_MODULE); |
664 | if (IS_ERR(rtc)) { | 665 | if (IS_ERR(rtc)) |
665 | rc = PTR_ERR(rtc); | 666 | return PTR_ERR(rtc); |
666 | goto exit_free_irq; | ||
667 | } | ||
668 | 667 | ||
669 | i2c_set_clientdata(client, rtc); | 668 | i2c_set_clientdata(client, rtc); |
670 | 669 | ||
671 | rc = isl1208_i2c_get_sr(client); | 670 | rc = isl1208_i2c_get_sr(client); |
672 | if (rc < 0) { | 671 | if (rc < 0) { |
673 | dev_err(&client->dev, "reading status failed\n"); | 672 | dev_err(&client->dev, "reading status failed\n"); |
674 | goto exit_unregister; | 673 | return rc; |
675 | } | 674 | } |
676 | 675 | ||
677 | if (rc & ISL1208_REG_SR_RTCF) | 676 | if (rc & ISL1208_REG_SR_RTCF) |
@@ -680,28 +679,15 @@ isl1208_probe(struct i2c_client *client, const struct i2c_device_id *id) | |||
680 | 679 | ||
681 | rc = sysfs_create_group(&client->dev.kobj, &isl1208_rtc_sysfs_files); | 680 | rc = sysfs_create_group(&client->dev.kobj, &isl1208_rtc_sysfs_files); |
682 | if (rc) | 681 | if (rc) |
683 | goto exit_unregister; | 682 | return rc; |
684 | 683 | ||
685 | return 0; | 684 | return 0; |
686 | |||
687 | exit_unregister: | ||
688 | rtc_device_unregister(rtc); | ||
689 | exit_free_irq: | ||
690 | if (client->irq) | ||
691 | free_irq(client->irq, client); | ||
692 | |||
693 | return rc; | ||
694 | } | 685 | } |
695 | 686 | ||
696 | static int | 687 | static int |
697 | isl1208_remove(struct i2c_client *client) | 688 | isl1208_remove(struct i2c_client *client) |
698 | { | 689 | { |
699 | struct rtc_device *rtc = i2c_get_clientdata(client); | ||
700 | |||
701 | sysfs_remove_group(&client->dev.kobj, &isl1208_rtc_sysfs_files); | 690 | sysfs_remove_group(&client->dev.kobj, &isl1208_rtc_sysfs_files); |
702 | rtc_device_unregister(rtc); | ||
703 | if (client->irq) | ||
704 | free_irq(client->irq, client); | ||
705 | 691 | ||
706 | return 0; | 692 | return 0; |
707 | } | 693 | } |