Commit 9e1343ed authored by Stephen Boyd's avatar Stephen Boyd

Merge tag 'v6.1-rockchip-clock1' of...

Merge tag 'v6.1-rockchip-clock1' of git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip into clk-rockchip

Pull Rockchip clk driver updates from Heiko Stuebner:

 - mux-variant clock using the table variant to select parents
 - clock controller for the rv1126 soc
 - conversion of rk3128 to yaml and relicensing of the yaml bindings
   to gpl2+MIT (following dt-binding guildelines)

* tag 'v6.1-rockchip-clock1' of git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip:
  dt-bindings: clock: rockchip: change SPDX-License-Identifier
  dt-bindings: clock: convert rockchip,rk3128-cru.txt to YAML
  clk: rockchip: Add clock controller support for RV1126 SoC
  dt-bindings: clock: rockchip: Document RV1126 CRU
  clk: rockchip: Add dt-binding header for RV1126
  clk: rockchip: Add MUXTBL variant
parents 1c23f9e6 fffa0fa4
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,px30-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,px30-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3036-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3036-cru.yaml#
......
* Rockchip RK3126/RK3128 Clock and Reset Unit
The RK3126/RK3128 clock controller generates and supplies clock to various
controllers within the SoC and also implements a reset controller for SoC
peripherals.
Required Properties:
- compatible: should be "rockchip,rk3126-cru" or "rockchip,rk3128-cru"
"rockchip,rk3126-cru" - controller compatible with RK3126 SoC.
"rockchip,rk3128-cru" - controller compatible with RK3128 SoC.
- reg: physical base address of the controller and length of memory mapped
region.
- #clock-cells: should be 1.
- #reset-cells: should be 1.
Optional Properties:
- rockchip,grf: phandle to the syscon managing the "general register files"
If missing pll rates are not changeable, due to the missing pll lock status.
Each clock is assigned an identifier and client nodes can use this identifier
to specify the clock which they consume. All available clocks are defined as
preprocessor macros in the dt-bindings/clock/rk3128-cru.h headers and can be
used in device tree sources. Similar macros exist for the reset sources in
these files.
External clocks:
There are several clocks that are generated outside the SoC. It is expected
that they are defined using standard clock bindings with following
clock-output-names:
- "xin24m" - crystal input - required,
- "ext_i2s" - external I2S clock - optional,
- "gmac_clkin" - external GMAC clock - optional
Example: Clock controller node:
cru: cru@20000000 {
compatible = "rockchip,rk3128-cru";
reg = <0x20000000 0x1000>;
rockchip,grf = <&grf>;
#clock-cells = <1>;
#reset-cells = <1>;
};
Example: UART controller node that consumes the clock generated by the clock
controller:
uart2: serial@20068000 {
compatible = "rockchip,serial";
reg = <0x20068000 0x100>;
interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
clock-frequency = <24000000>;
clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>;
clock-names = "sclk_uart", "pclk_uart";
};
# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2
---
$id: http://devicetree.org/schemas/clock/rockchip,rk3128-cru.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Rockchip RK3126/RK3128 Clock and Reset Unit (CRU)
maintainers:
- Elaine Zhang <zhangqing@rock-chips.com>
- Heiko Stuebner <heiko@sntech.de>
description: |
The RK3126/RK3128 clock controller generates and supplies clock to various
controllers within the SoC and also implements a reset controller for SoC
peripherals.
Each clock is assigned an identifier and client nodes can use this identifier
to specify the clock which they consume. All available clocks are defined as
preprocessor macros in the dt-bindings/clock/rk3128-cru.h headers and can be
used in device tree sources. Similar macros exist for the reset sources in
these files.
properties:
compatible:
enum:
- rockchip,rk3126-cru
- rockchip,rk3128-cru
reg:
maxItems: 1
"#clock-cells":
const: 1
"#reset-cells":
const: 1
clocks:
minItems: 1
maxItems: 3
clock-names:
minItems: 1
items:
- const: xin24m
- enum:
- ext_i2s
- gmac_clkin
- enum:
- ext_i2s
- gmac_clkin
rockchip,grf:
$ref: /schemas/types.yaml#/definitions/phandle
description:
Phandle to the syscon managing the "general register files" (GRF),
if missing pll rates are not changeable, due to the missing pll
lock status.
required:
- compatible
- reg
- "#clock-cells"
- "#reset-cells"
additionalProperties: false
examples:
- |
cru: clock-controller@20000000 {
compatible = "rockchip,rk3128-cru";
reg = <0x20000000 0x1000>;
rockchip,grf = <&grf>;
#clock-cells = <1>;
#reset-cells = <1>;
};
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3228-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3228-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3288-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3288-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3308-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3308-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3368-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3368-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0-only # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rk3399-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rk3399-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: (GPL-2.0+ OR MIT)
%YAML 1.2 %YAML 1.2
--- ---
$id: http://devicetree.org/schemas/clock/rockchip,rv1108-cru.yaml# $id: http://devicetree.org/schemas/clock/rockchip,rv1108-cru.yaml#
......
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
%YAML 1.2
---
$id: http://devicetree.org/schemas/clock/rockchip,rv1126-cru.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Rockchip RV1126 Clock and Reset Unit
maintainers:
- Jagan Teki <jagan@edgeble.ai>
- Finley Xiao <finley.xiao@rock-chips.com>
- Heiko Stuebner <heiko@sntech.de>
description:
The RV1126 clock controller generates the clock and also implements a
reset controller for SoC peripherals.
properties:
compatible:
enum:
- rockchip,rv1126-cru
- rockchip,rv1126-pmucru
reg:
maxItems: 1
"#clock-cells":
const: 1
"#reset-cells":
const: 1
clocks:
maxItems: 1
clock-names:
const: xin24m
rockchip,grf:
$ref: /schemas/types.yaml#/definitions/phandle
description:
Phandle to the syscon managing the "general register files" (GRF),
if missing pll rates are not changeable, due to the missing pll
lock status.
required:
- compatible
- reg
- "#clock-cells"
- "#reset-cells"
additionalProperties: false
examples:
- |
cru: clock-controller@ff490000 {
compatible = "rockchip,rv1126-cru";
reg = <0xff490000 0x1000>;
rockchip,grf = <&grf>;
#clock-cells = <1>;
#reset-cells = <1>;
};
...@@ -23,6 +23,13 @@ config CLK_RV110X ...@@ -23,6 +23,13 @@ config CLK_RV110X
help help
Build the driver for RV110x Clock Driver. Build the driver for RV110x Clock Driver.
config CLK_RV1126
bool "Rockchip RV1126 clock controller support"
depends on ARM || COMPILE_TEST
default y
help
Build the driver for RV1126 Clock Driver.
config CLK_RK3036 config CLK_RK3036
bool "Rockchip RK3036 clock controller support" bool "Rockchip RK3036 clock controller support"
depends on ARM || COMPILE_TEST depends on ARM || COMPILE_TEST
......
...@@ -17,6 +17,7 @@ clk-rockchip-$(CONFIG_RESET_CONTROLLER) += softrst.o ...@@ -17,6 +17,7 @@ clk-rockchip-$(CONFIG_RESET_CONTROLLER) += softrst.o
obj-$(CONFIG_CLK_PX30) += clk-px30.o obj-$(CONFIG_CLK_PX30) += clk-px30.o
obj-$(CONFIG_CLK_RV110X) += clk-rv1108.o obj-$(CONFIG_CLK_RV110X) += clk-rv1108.o
obj-$(CONFIG_CLK_RV1126) += clk-rv1126.o
obj-$(CONFIG_CLK_RK3036) += clk-rk3036.o obj-$(CONFIG_CLK_RK3036) += clk-rk3036.o
obj-$(CONFIG_CLK_RK312X) += clk-rk3128.o obj-$(CONFIG_CLK_RK312X) += clk-rk3128.o
obj-$(CONFIG_CLK_RK3188) += clk-rk3188.o obj-$(CONFIG_CLK_RK3188) += clk-rk3188.o
......
This diff is collapsed.
...@@ -40,6 +40,7 @@ static struct clk *rockchip_clk_register_branch(const char *name, ...@@ -40,6 +40,7 @@ static struct clk *rockchip_clk_register_branch(const char *name,
const char *const *parent_names, u8 num_parents, const char *const *parent_names, u8 num_parents,
void __iomem *base, void __iomem *base,
int muxdiv_offset, u8 mux_shift, u8 mux_width, u8 mux_flags, int muxdiv_offset, u8 mux_shift, u8 mux_width, u8 mux_flags,
u32 *mux_table,
int div_offset, u8 div_shift, u8 div_width, u8 div_flags, int div_offset, u8 div_shift, u8 div_width, u8 div_flags,
struct clk_div_table *div_table, int gate_offset, struct clk_div_table *div_table, int gate_offset,
u8 gate_shift, u8 gate_flags, unsigned long flags, u8 gate_shift, u8 gate_flags, unsigned long flags,
...@@ -62,6 +63,7 @@ static struct clk *rockchip_clk_register_branch(const char *name, ...@@ -62,6 +63,7 @@ static struct clk *rockchip_clk_register_branch(const char *name,
mux->shift = mux_shift; mux->shift = mux_shift;
mux->mask = BIT(mux_width) - 1; mux->mask = BIT(mux_width) - 1;
mux->flags = mux_flags; mux->flags = mux_flags;
mux->table = mux_table;
mux->lock = lock; mux->lock = lock;
mux_ops = (mux_flags & CLK_MUX_READ_ONLY) ? &clk_mux_ro_ops mux_ops = (mux_flags & CLK_MUX_READ_ONLY) ? &clk_mux_ro_ops
: &clk_mux_ops; : &clk_mux_ops;
...@@ -270,6 +272,8 @@ static struct clk *rockchip_clk_register_frac_branch( ...@@ -270,6 +272,8 @@ static struct clk *rockchip_clk_register_frac_branch(
frac_mux->shift = child->mux_shift; frac_mux->shift = child->mux_shift;
frac_mux->mask = BIT(child->mux_width) - 1; frac_mux->mask = BIT(child->mux_width) - 1;
frac_mux->flags = child->mux_flags; frac_mux->flags = child->mux_flags;
if (child->mux_table)
frac_mux->table = child->mux_table;
frac_mux->lock = lock; frac_mux->lock = lock;
frac_mux->hw.init = &init; frac_mux->hw.init = &init;
...@@ -444,11 +448,21 @@ void rockchip_clk_register_branches(struct rockchip_clk_provider *ctx, ...@@ -444,11 +448,21 @@ void rockchip_clk_register_branches(struct rockchip_clk_provider *ctx,
/* catch simple muxes */ /* catch simple muxes */
switch (list->branch_type) { switch (list->branch_type) {
case branch_mux: case branch_mux:
clk = clk_register_mux(NULL, list->name, if (list->mux_table)
list->parent_names, list->num_parents, clk = clk_register_mux_table(NULL, list->name,
flags, ctx->reg_base + list->muxdiv_offset, list->parent_names, list->num_parents,
list->mux_shift, list->mux_width, flags,
list->mux_flags, &ctx->lock); ctx->reg_base + list->muxdiv_offset,
list->mux_shift, list->mux_width,
list->mux_flags, list->mux_table,
&ctx->lock);
else
clk = clk_register_mux(NULL, list->name,
list->parent_names, list->num_parents,
flags,
ctx->reg_base + list->muxdiv_offset,
list->mux_shift, list->mux_width,
list->mux_flags, &ctx->lock);
break; break;
case branch_muxgrf: case branch_muxgrf:
clk = rockchip_clk_register_muxgrf(list->name, clk = rockchip_clk_register_muxgrf(list->name,
...@@ -506,7 +520,8 @@ void rockchip_clk_register_branches(struct rockchip_clk_provider *ctx, ...@@ -506,7 +520,8 @@ void rockchip_clk_register_branches(struct rockchip_clk_provider *ctx,
ctx->reg_base, list->muxdiv_offset, ctx->reg_base, list->muxdiv_offset,
list->mux_shift, list->mux_shift,
list->mux_width, list->mux_flags, list->mux_width, list->mux_flags,
list->div_offset, list->div_shift, list->div_width, list->mux_table, list->div_offset,
list->div_shift, list->div_width,
list->div_flags, list->div_table, list->div_flags, list->div_table,
list->gate_offset, list->gate_shift, list->gate_offset, list->gate_shift,
list->gate_flags, flags, &ctx->lock); list->gate_flags, flags, &ctx->lock);
......
...@@ -79,6 +79,25 @@ struct clk; ...@@ -79,6 +79,25 @@ struct clk;
#define RV1108_EMMC_CON0 0x1e8 #define RV1108_EMMC_CON0 0x1e8
#define RV1108_EMMC_CON1 0x1ec #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
#define RK2928_PLL_CON(x) ((x) * 0x4) #define RK2928_PLL_CON(x) ((x) * 0x4)
#define RK2928_MODE_CON 0x40 #define RK2928_MODE_CON 0x40
#define RK2928_CLKSEL_CON(x) ((x) * 0x4 + 0x44) #define RK2928_CLKSEL_CON(x) ((x) * 0x4 + 0x44)
...@@ -448,6 +467,7 @@ struct rockchip_clk_branch { ...@@ -448,6 +467,7 @@ struct rockchip_clk_branch {
u8 mux_shift; u8 mux_shift;
u8 mux_width; u8 mux_width;
u8 mux_flags; u8 mux_flags;
u32 *mux_table;
int div_offset; int div_offset;
u8 div_shift; u8 div_shift;
u8 div_width; u8 div_width;
...@@ -680,6 +700,22 @@ struct rockchip_clk_branch { ...@@ -680,6 +700,22 @@ struct rockchip_clk_branch {
.gate_offset = -1, \ .gate_offset = -1, \
} }
#define MUXTBL(_id, cname, pnames, f, o, s, w, mf, mt) \
{ \
.id = _id, \
.branch_type = branch_mux, \
.name = cname, \
.parent_names = pnames, \
.num_parents = ARRAY_SIZE(pnames), \
.flags = f, \
.muxdiv_offset = o, \
.mux_shift = s, \
.mux_width = w, \
.mux_flags = mf, \
.gate_offset = -1, \
.mux_table = mt, \
}
#define MUXGRF(_id, cname, pnames, f, o, s, w, mf) \ #define MUXGRF(_id, cname, pnames, f, o, s, w, mf) \
{ \ { \
.id = _id, \ .id = _id, \
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment