]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/commitdiff
rtc-parisc: use platform_driver_probe
authordann frazier <dannf@hp.com>
Tue, 31 Mar 2009 22:24:52 +0000 (15:24 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Wed, 1 Apr 2009 15:59:25 +0000 (08:59 -0700)
This isn't a hotpluggable device, so call platform_driver_probe
directly in parisc_rtc_init

Signed-off-by: dann frazier <dannf@hp.com>
Cc: Alessandro Zummo <a.zummo@towertech.it>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Grant Grundler <grundler@parisc-linux.org>
Cc: Matthew Wilcox <matthew@wil.cx>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
drivers/rtc/rtc-parisc.c

index 0477cc129c6de26247fc96a649c733e5fe2e2221..a2ca07ad42cba311ddf66163841c3a3d176a8146 100644 (file)
@@ -40,19 +40,14 @@ static const struct rtc_class_ops parisc_rtc_ops = {
        .set_time = parisc_set_time,
 };
 
-static int __devinit parisc_rtc_probe(struct platform_device *dev)
+static int __init parisc_rtc_probe(struct platform_device *dev)
 {
        struct rtc_device *p;
 
-       p = kzalloc(sizeof (*p), GFP_KERNEL);
-       if (!p)
-               return -ENOMEM;
-
        p = rtc_device_register("rtc-parisc", &dev->dev, &parisc_rtc_ops,
                                THIS_MODULE);
        if (IS_ERR(p)) {
                int err = PTR_ERR(p);
-               kfree(p);
                return err;
        }
 
@@ -61,12 +56,11 @@ static int __devinit parisc_rtc_probe(struct platform_device *dev)
        return 0;
 }
 
-static int __devexit parisc_rtc_remove(struct platform_device *dev)
+static int __exit parisc_rtc_remove(struct platform_device *dev)
 {
        struct rtc_device *p = platform_get_drvdata(dev);
 
        rtc_device_unregister(p);
-       kfree(p);
 
        return 0;
 }
@@ -82,7 +76,7 @@ static struct platform_driver parisc_rtc_driver = {
 
 static int __init parisc_rtc_init(void)
 {
-       return platform_driver_register(&parisc_rtc_driver);
+       return platform_driver_probe(&parisc_rtc_driver, parisc_rtc_probe);
 }
 
 static void __exit parisc_rtc_fini(void)