summaryrefslogtreecommitdiffstats
path: root/drivers/clk/imx/clk-scu.c
diff options
context:
space:
mode:
authorDong Aisheng <aisheng.dong@nxp.com>2020-10-30 16:37:33 +0100
committerShawn Guo <shawnguo@kernel.org>2020-11-03 00:35:47 +0100
commit220175cd3979fdb860decf757cc7a5980fdd045f (patch)
tree78b44c05a97d971ece857dd562e35cc88664489f /drivers/clk/imx/clk-scu.c
parentclk: imx: remove redundant assignment to pointer np (diff)
downloadlinux-220175cd3979fdb860decf757cc7a5980fdd045f.tar.xz
linux-220175cd3979fdb860decf757cc7a5980fdd045f.zip
clk: imx: scu: fix build break when compiled as modules
After commit e0d0d4d86c76 ("clk: imx8qxp: Support building i.MX8QXP clock driver as module"), clk-scu.c and clk-imx8qxp.c are complied in one module, thus there can be only one module_init() in those two files. Commit 77d8f3068c63 ("clk: imx: scu: add two cells binding support") introduced another module_init() in clk_scu.c which caused the errors below. To fix the issue, we can remove the unnecessary builtin_platform_driver from clk_scu.c and directly register the driver in imx_clk_scu_init(). CC [M] drivers/clk/imx/clk-scu.o In file included from ../include/linux/of_device.h:6, from ../include/linux/of_platform.h:12, from ../drivers/clk/imx/clk-scu.c:11: ../drivers/clk/imx/clk-scu.c: In function ‘imx_clk_scu_init’: ../drivers/clk/imx/clk-scu.c:176:35: error: ‘imx_clk_scu_driver’ undeclared (first use in this function); did you mean ‘imx_clk_scu_init’? 176 | return platform_driver_register(&imx_clk_scu_driver); | ^~~~~~~~~~~~~~~~~~ ../include/linux/platform_device.h:218:29: note: in definition of macro ‘platform_driver_register’ 218 | __platform_driver_register(drv, THIS_MODULE) | ^~~ ../drivers/clk/imx/clk-scu.c:176:35: note: each undeclared identifier is reported only once for each function it appears in 176 | return platform_driver_register(&imx_clk_scu_driver); | ^~~~~~~~~~~~~~~~~~ ../include/linux/platform_device.h:218:29: note: in definition of macro ‘platform_driver_register’ 218 | __platform_driver_register(drv, THIS_MODULE) | ^~~ ../drivers/clk/imx/clk-scu.c:177:1: error: control reaches end of non-void function [-Werror=return-type] 177 | } | ^ At top level: ../drivers/clk/imx/clk-scu.c:470:31: warning: ‘imx_clk_scu_driver’ defined but not used [-Wunused-variable] 470 | static struct platform_driver imx_clk_scu_driver = { Reported-by: kernel test robot <lkp@intel.com> Fixes: 77d8f3068c63 ("clk: imx: scu: add two cells binding support") Signed-off-by: Dong Aisheng <aisheng.dong@nxp.com> Acked-by: Stephen Boyd <sboyd@kernel.org> Signed-off-by: Shawn Guo <shawnguo@kernel.org>
Diffstat (limited to 'drivers/clk/imx/clk-scu.c')
-rw-r--r--drivers/clk/imx/clk-scu.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/clk/imx/clk-scu.c b/drivers/clk/imx/clk-scu.c
index 229a290ca5b6..d0243c52ccbc 100644
--- a/drivers/clk/imx/clk-scu.c
+++ b/drivers/clk/imx/clk-scu.c
@@ -21,6 +21,7 @@
static struct imx_sc_ipc *ccm_ipc_handle;
struct device_node *pd_np;
+static struct platform_driver imx_clk_scu_driver;
struct imx_scu_clk_node {
const char *name;
@@ -178,7 +179,7 @@ int imx_clk_scu_init(struct device_node *np)
}
}
- return 0;
+ return platform_driver_register(&imx_clk_scu_driver);
}
/*
@@ -542,7 +543,6 @@ static struct platform_driver imx_clk_scu_driver = {
},
.probe = imx_clk_scu_probe,
};
-builtin_platform_driver(imx_clk_scu_driver);
static int imx_clk_scu_attach_pd(struct device *dev, u32 rsrc_id)
{