rtc: asm9260: remove incorrect __init/__exit annotations
authorArnd Bergmann <arnd@arndb.de>
Tue, 15 Mar 2016 21:44:31 +0000 (22:44 +0100)
committerAlexandre Belloni <alexandre.belloni@free-electrons.com>
Fri, 18 Mar 2016 23:02:55 +0000 (00:02 +0100)
The probe and remove callbacks of the platform driver are marked __init
and __exit, respectively. However, this is not a correct way to annotate
them, as it will result in those sections to be discarded at link time
or after boot, while we can actually call them again based on manual
unbinding, or deferred probing.

Kbuild warns about the problem:

WARNING: drivers/rtc/rtc-asm9260.o(.data+0x0): Section mismatch in reference from the variable asm9260_rtc_driver to the function .init.text:asm9260_rtc_probe()

This removes the annotations, so we no longer branch into missing
code and avoid the warning.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Fixes: 125e550fd257 ("rtc: add Alphascale asm9260 driver")
Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
drivers/rtc/rtc-asm9260.c

index 14e08c4c1a016148b514aa370f094aed1f1d5e38..355fdb97a00638e29cafb1209f267083b1ece573 100644 (file)
@@ -255,7 +255,7 @@ static const struct rtc_class_ops asm9260_rtc_ops = {
        .alarm_irq_enable       = asm9260_alarm_irq_enable,
 };
 
-static int __init asm9260_rtc_probe(struct platform_device *pdev)
+static int asm9260_rtc_probe(struct platform_device *pdev)
 {
        struct asm9260_rtc_priv *priv;
        struct device *dev = &pdev->dev;
@@ -323,7 +323,7 @@ err_return:
        return ret;
 }
 
-static int __exit asm9260_rtc_remove(struct platform_device *pdev)
+static int asm9260_rtc_remove(struct platform_device *pdev)
 {
        struct asm9260_rtc_priv *priv = platform_get_drvdata(pdev);