clk: rockchip: rv1126: support driver build as tristate module

Signed-off-by: Elaine Zhang <zhangqing@rock-chips.com>
Change-Id: Ic2607451680d7ba07999e9d18e962005bc92f31a
This commit is contained in:
Elaine Zhang
2020-07-16 17:42:10 +08:00
parent 6fbbbac945
commit 2e0cbf871b
4 changed files with 88 additions and 6 deletions

View File

@@ -23,6 +23,13 @@ config CLK_RV110X
help
Build the driver for RV110x Clock Driver.
config CLK_RV1126
tristate "Rockchip RV1126 clock controller support"
depends on ARM || COMPILE_TEST
default y
help
Build the driver for RV1126 Clock Driver.
config CLK_RK1808
tristate "Rockchip RK1808 clock controller support"
depends on ARM64 || COMPILE_TEST

View File

@@ -19,6 +19,7 @@ clk-rockchip-$(CONFIG_RESET_CONTROLLER) += softrst.o
obj-$(CONFIG_CLK_PX30) += clk-px30.o
obj-$(CONFIG_CLK_RV110X) += clk-rv1108.o
obj-$(CONFIG_CLK_RV1126) += clk-rv1126.o
obj-$(CONFIG_CLK_RK1808) += clk-rk1808.o
obj-$(CONFIG_CLK_RK3036) += clk-rk3036.o
obj-$(CONFIG_CLK_RK312X) += clk-rk3128.o

View File

@@ -5,8 +5,10 @@
*/
#include <linux/clk-provider.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/of_address.h>
#include <linux/of_device.h>
#include <linux/syscore_ops.h>
#include <dt-bindings/clock/rv1126-cru.h>
#include "clk.h"
@@ -137,9 +139,10 @@ static struct rockchip_cpuclk_rate_table rv1126_cpuclk_rates[] __initdata = {
};
static const struct rockchip_cpuclk_reg_data rv1126_cpuclk_data = {
.core_reg = RV1126_CLKSEL_CON(0),
.div_core_shift = 0,
.div_core_mask = 0x1f,
.core_reg[0] = RV1126_CLKSEL_CON(0),
.div_core_shift[0] = 0,
.div_core_mask[0] = 0x1f,
.num_cores = 1,
.mux_core_alt = 0,
.mux_core_main = 2,
.mux_core_shift = 6,
@@ -1323,9 +1326,8 @@ static struct rockchip_clk_branch rv1126_clk_branches[] __initdata = {
RV1126_CLKGATE_CON(21), 15, GFLAGS),
GATE(0, "pclk_ddr_msch", "pclk_pdddr", CLK_IGNORE_UNUSED,
RV1126_CLKGATE_CON(21), 6, GFLAGS),
COMPOSITE_DDRCLK(SCLK_DDRCLK, "sclk_ddrc", mux_dpll_gpll_p,
CLK_IGNORE_UNUSED, RV1126_CLKSEL_CON(64), 15, 1, 8, 5,
ROCKCHIP_DDRCLK_SIP_V2),
COMPOSITE_NOGATE(SCLK_DDRCLK, "sclk_ddrc", mux_dpll_gpll_p, CLK_IGNORE_UNUSED,
RV1126_CLKSEL_CON(64), 15, 1, MFLAGS, 8, 5, DFLAGS),
COMPOSITE(CLK_DDRPHY, "clk_ddrphy", mux_dpll_gpll_p, CLK_IGNORE_UNUSED,
RV1126_CLKSEL_CON(64), 15, 1, MFLAGS, 8, 5, DFLAGS,
RV1126_CLKGATE_CON(21), 8, GFLAGS),
@@ -1519,3 +1521,55 @@ static void __init rv1126_clk_init(struct device_node *np)
}
CLK_OF_DECLARE(rv1126_cru, "rockchip,rv1126-cru", rv1126_clk_init);
struct clk_rv1126_inits {
void (*inits)(struct device_node *np);
};
static const struct clk_rv1126_inits clk_rv1126_pmu_init = {
.inits = rv1126_pmu_clk_init,
};
static const struct clk_rv1126_inits clk_rv1126_init = {
.inits = rv1126_clk_init,
};
static const struct of_device_id clk_rv1126_match_table[] = {
{
.compatible = "rockchip,rv1126-cru",
.data = &clk_rv1126_init,
}, {
.compatible = "rockchip,rv1126-pmucru",
.data = &clk_rv1126_pmu_init,
},
{ }
};
MODULE_DEVICE_TABLE(of, clk_rv1126_match_table);
static int __init clk_rv1126_probe(struct platform_device *pdev)
{
struct device_node *np = pdev->dev.of_node;
const struct of_device_id *match;
const struct clk_rv1126_inits *init_data;
match = of_match_device(clk_rv1126_match_table, &pdev->dev);
if (!match || !match->data)
return -EINVAL;
init_data = match->data;
if (init_data->inits)
init_data->inits(np);
return 0;
}
static struct platform_driver clk_rv1126_driver = {
.driver = {
.name = "clk-rv1126",
.of_match_table = clk_rv1126_match_table,
},
};
builtin_platform_driver_probe(clk_rv1126_driver, clk_rv1126_probe);
MODULE_DESCRIPTION("Rockchip RV1126 Clock Driver");
MODULE_LICENSE("GPL");

View File

@@ -91,6 +91,26 @@ struct clk;
#define RV1108_SDIO_CON1 0x1e4
#define RV1108_EMMC_CON0 0x1e8
#define RV1108_EMMC_CON1 0x1ec
#define RV1126_PMU_MODE 0x0
#define RV1126_PMU_PLL_CON(x) ((x) * 0x4 + 0x10)
#define RV1126_PMU_CLKSEL_CON(x) ((x) * 0x4 + 0x100)
#define RV1126_PMU_CLKGATE_CON(x) ((x) * 0x4 + 0x180)
#define RV1126_PMU_SOFTRST_CON(x) ((x) * 0x4 + 0x200)
#define RV1126_PLL_CON(x) ((x) * 0x4)
#define RV1126_MODE_CON 0x90
#define RV1126_CLKSEL_CON(x) ((x) * 0x4 + 0x100)
#define RV1126_CLKGATE_CON(x) ((x) * 0x4 + 0x280)
#define RV1126_SOFTRST_CON(x) ((x) * 0x4 + 0x300)
#define RV1126_GLB_SRST_FST 0x408
#define RV1126_GLB_SRST_SND 0x40c
#define RV1126_SDMMC_CON0 0x440
#define RV1126_SDMMC_CON1 0x444
#define RV1126_SDIO_CON0 0x448
#define RV1126_SDIO_CON1 0x44c
#define RV1126_EMMC_CON0 0x450
#define RV1126_EMMC_CON1 0x454
/*
* register positions shared by RK1808 RK2928, RK3036,
* RK3066, RK3188 and RK3228