From b2182530468f4b4f1d110670b6edb99aeef22ae5 Mon Sep 17 00:00:00 2001 From: Elaine Zhang Date: Thu, 16 Jul 2020 17:41:43 +0800 Subject: [PATCH] clk: rockchip: rv1108: support driver build as tristate module Signed-off-by: Elaine Zhang Change-Id: Ie65251277283e3770b05107b35c5516386d88a64 --- drivers/clk/rockchip/Kconfig | 2 +- drivers/clk/rockchip/clk-rv1108.c | 30 ++++++++++++++++++++++++++++++ 2 files changed, 31 insertions(+), 1 deletion(-) diff --git a/drivers/clk/rockchip/Kconfig b/drivers/clk/rockchip/Kconfig index a8dc21228f6e..0bfc08f2d432 100644 --- a/drivers/clk/rockchip/Kconfig +++ b/drivers/clk/rockchip/Kconfig @@ -17,7 +17,7 @@ config CLK_PX30 Build the driver for PX30 Clock Driver. config CLK_RV110X - bool "Rockchip RV110x clock controller support" + tristate "Rockchip RV110x clock controller support" depends on ARM || COMPILE_TEST default y help diff --git a/drivers/clk/rockchip/clk-rv1108.c b/drivers/clk/rockchip/clk-rv1108.c index 4ceae4110f66..91ea03f0d360 100644 --- a/drivers/clk/rockchip/clk-rv1108.c +++ b/drivers/clk/rockchip/clk-rv1108.c @@ -7,8 +7,10 @@ #include #include +#include #include #include +#include #include #include #include "clk.h" @@ -840,3 +842,31 @@ static void __init rv1108_clk_init(struct device_node *np) } } CLK_OF_DECLARE(rv1108_cru, "rockchip,rv1108-cru", rv1108_clk_init); + +static int __init clk_rv1108_probe(struct platform_device *pdev) +{ + struct device_node *np = pdev->dev.of_node; + + rv1108_clk_init(np); + + return 0; +} + +static const struct of_device_id clk_rv1108_match_table[] = { + { + .compatible = "rockchip,rv1108-cru", + }, + { } +}; +MODULE_DEVICE_TABLE(of, clk_rv1108_match_table); + +static struct platform_driver clk_rv1108_driver = { + .driver = { + .name = "clk-rv1108", + .of_match_table = clk_rv1108_match_table, + }, +}; +builtin_platform_driver_probe(clk_rv1108_driver, clk_rv1108_probe); + +MODULE_DESCRIPTION("Rockchip RV1108 Clock Driver"); +MODULE_LICENSE("GPL");