162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/clock/rockchip,rk3568-cru.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: ROCKCHIP rk3568 Family Clock Control Module
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Elaine Zhang <zhangqing@rock-chips.com>
1162306a36Sopenharmony_ci  - Heiko Stuebner <heiko@sntech.de>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cidescription: |
1462306a36Sopenharmony_ci  The RK3568 clock controller generates the clock and also implements a
1562306a36Sopenharmony_ci  reset controller for SoC peripherals.
1662306a36Sopenharmony_ci  (examples: provide SCLK_UART1\PCLK_UART1 and SRST_P_UART1\SRST_S_UART1 for UART module)
1762306a36Sopenharmony_ci  Each clock is assigned an identifier and client nodes can use this identifier
1862306a36Sopenharmony_ci  to specify the clock which they consume. All available clocks are defined as
1962306a36Sopenharmony_ci  preprocessor macros in the dt-bindings/clock/rk3568-cru.h headers and can be
2062306a36Sopenharmony_ci  used in device tree sources.
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ciproperties:
2362306a36Sopenharmony_ci  compatible:
2462306a36Sopenharmony_ci    enum:
2562306a36Sopenharmony_ci      - rockchip,rk3568-cru
2662306a36Sopenharmony_ci      - rockchip,rk3568-pmucru
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci  reg:
2962306a36Sopenharmony_ci    maxItems: 1
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci  "#clock-cells":
3262306a36Sopenharmony_ci    const: 1
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci  "#reset-cells":
3562306a36Sopenharmony_ci    const: 1
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci  clocks:
3862306a36Sopenharmony_ci    maxItems: 1
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci  clock-names:
4162306a36Sopenharmony_ci    const: xin24m
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci  rockchip,grf:
4462306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
4562306a36Sopenharmony_ci    description:
4662306a36Sopenharmony_ci      Phandle to the syscon managing the "general register files" (GRF),
4762306a36Sopenharmony_ci      if missing pll rates are not changeable, due to the missing pll
4862306a36Sopenharmony_ci      lock status.
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_cirequired:
5162306a36Sopenharmony_ci  - compatible
5262306a36Sopenharmony_ci  - reg
5362306a36Sopenharmony_ci  - "#clock-cells"
5462306a36Sopenharmony_ci  - "#reset-cells"
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ciadditionalProperties: false
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ciexamples:
5962306a36Sopenharmony_ci  # Clock Control Module node:
6062306a36Sopenharmony_ci  - |
6162306a36Sopenharmony_ci    pmucru: clock-controller@fdd00000 {
6262306a36Sopenharmony_ci      compatible = "rockchip,rk3568-pmucru";
6362306a36Sopenharmony_ci      reg = <0xfdd00000 0x1000>;
6462306a36Sopenharmony_ci      #clock-cells = <1>;
6562306a36Sopenharmony_ci      #reset-cells = <1>;
6662306a36Sopenharmony_ci    };
6762306a36Sopenharmony_ci  - |
6862306a36Sopenharmony_ci    cru: clock-controller@fdd20000 {
6962306a36Sopenharmony_ci      compatible = "rockchip,rk3568-cru";
7062306a36Sopenharmony_ci      reg = <0xfdd20000 0x1000>;
7162306a36Sopenharmony_ci      #clock-cells = <1>;
7262306a36Sopenharmony_ci      #reset-cells = <1>;
7362306a36Sopenharmony_ci    };
74