浏览代码

rtc: asm9260: remove incorrect __init/__exit annotations

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>
Arnd Bergmann 9 年之前
父节点
当前提交
15c6ea6f81
共有 1 个文件被更改,包括 2 次插入2 次删除
  1. 2 2
      drivers/rtc/rtc-asm9260.c

+ 2 - 2
drivers/rtc/rtc-asm9260.c

@@ -255,7 +255,7 @@ static const struct rtc_class_ops asm9260_rtc_ops = {
 	.alarm_irq_enable	= asm9260_alarm_irq_enable,
 	.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 asm9260_rtc_priv *priv;
 	struct device *dev = &pdev->dev;
 	struct device *dev = &pdev->dev;
@@ -323,7 +323,7 @@ err_return:
 	return ret;
 	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);
 	struct asm9260_rtc_priv *priv = platform_get_drvdata(pdev);