clk: samsung: Allow modular build of the Audio Subsystem CLKCON driver
authorSylwester Nawrocki <s.nawrocki@samsung.com>
Fri, 8 Jul 2016 14:15:00 +0000 (16:15 +0200)
committerMichael Turquette <mturquette@baylibre.com>
Wed, 13 Jul 2016 21:59:53 +0000 (14:59 -0700)
Any clock dependencies can be properly handled with deferred probing
so we can remove core_initcall and switch to a proper loadable platform
driver module.
This change has been tested on Exynos4412 Odroid U3 based board.

Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Reviewed-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Signed-off-by: Michael Turquette <mturquette@baylibre.com>
Link: lkml.kernel.org/r/1467987300-31450-1-git-send-email-s.nawrocki@samsung.com

drivers/clk/samsung/Kconfig
drivers/clk/samsung/Makefile
drivers/clk/samsung/clk-exynos-audss.c

index 20c5fe92ab4adf9da4e655e264f2ba1d486bd8b5..addc65270e43415c5c5e57fefe3555789db2d3c6 100644 (file)
@@ -9,6 +9,15 @@ config EXYNOS_ARM64_COMMON_CLK
        bool "Samsung Exynos ARMv8-family clock controller support" if COMPILE_TEST
        depends on COMMON_CLK_SAMSUNG
 
+config EXYNOS_AUDSS_CLK_CON
+       tristate "Samsung Exynos AUDSS clock controller support"
+       depends on COMMON_CLK_SAMSUNG
+       default y if ARCH_EXYNOS
+       help
+         Support for the Audio Subsystem CLKCON clock controller present
+         on some Exynos SoC variants. Choose M or Y here if you want to
+         use audio devices such as I2S, PCM, etc.
+
 # For S3C24XX platforms, select following symbols:
 config S3C2410_COMMON_CLK
        bool "Samsung S3C2410 clock controller support" if COMPILE_TEST
index fc367d4b2902b14286ff4075f6d452612dd08f01..57f4dc6dc4474cccc23a934450d07302a5a742bc 100644 (file)
@@ -12,7 +12,7 @@ obj-$(CONFIG_SOC_EXYNOS5410)  += clk-exynos5410.o
 obj-$(CONFIG_SOC_EXYNOS5420)   += clk-exynos5420.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos5433.o
 obj-$(CONFIG_SOC_EXYNOS5440)   += clk-exynos5440.o
-obj-$(CONFIG_ARCH_EXYNOS)      += clk-exynos-audss.o
+obj-$(CONFIG_EXYNOS_AUDSS_CLK_CON) += clk-exynos-audss.o
 obj-$(CONFIG_ARCH_EXYNOS)      += clk-exynos-clkout.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos7.o
 obj-$(CONFIG_S3C2410_COMMON_CLK)+= clk-s3c2410.o
index 4e9584d79089d355fcc67b4154724f4d6cc2ed62..bdf8b971f332502bb8c19ffc399b6886bf7d42aa 100644 (file)
@@ -273,17 +273,7 @@ static struct platform_driver exynos_audss_clk_driver = {
        .remove = exynos_audss_clk_remove,
 };
 
-static int __init exynos_audss_clk_init(void)
-{
-       return platform_driver_register(&exynos_audss_clk_driver);
-}
-core_initcall(exynos_audss_clk_init);
-
-static void __exit exynos_audss_clk_exit(void)
-{
-       platform_driver_unregister(&exynos_audss_clk_driver);
-}
-module_exit(exynos_audss_clk_exit);
+module_platform_driver(exynos_audss_clk_driver);
 
 MODULE_AUTHOR("Padmavathi Venna <padma.v@samsung.com>");
 MODULE_DESCRIPTION("Exynos Audio Subsystem Clock Controller");