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/renesas,rzg2l-cpg.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Renesas RZ/{G2L,V2L,V2M} Clock Pulse Generator / Module Standby Mode
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Geert Uytterhoeven <geert+renesas@glider.be>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |
1362306a36Sopenharmony_ci  On Renesas RZ/{G2L,V2L}-alike SoC's, the CPG (Clock Pulse Generator) and Module
1462306a36Sopenharmony_ci  Standby Mode share the same register block. On RZ/V2M, the functionality is
1562306a36Sopenharmony_ci  similar, but does not have Clock Monitor Registers.
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci  They provide the following functionalities:
1862306a36Sopenharmony_ci    - The CPG block generates various core clocks,
1962306a36Sopenharmony_ci    - The Module Standby Mode block provides two functions:
2062306a36Sopenharmony_ci        1. Module Standby, providing a Clock Domain to control the clock supply
2162306a36Sopenharmony_ci           to individual SoC devices,
2262306a36Sopenharmony_ci        2. Reset Control, to perform a software reset of individual SoC devices.
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ciproperties:
2562306a36Sopenharmony_ci  compatible:
2662306a36Sopenharmony_ci    enum:
2762306a36Sopenharmony_ci      - renesas,r9a07g043-cpg # RZ/G2UL{Type-1,Type-2} and RZ/Five
2862306a36Sopenharmony_ci      - renesas,r9a07g044-cpg # RZ/G2{L,LC}
2962306a36Sopenharmony_ci      - renesas,r9a07g054-cpg # RZ/V2L
3062306a36Sopenharmony_ci      - renesas,r9a09g011-cpg # RZ/V2M
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci  reg:
3362306a36Sopenharmony_ci    maxItems: 1
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci  clocks:
3662306a36Sopenharmony_ci    maxItems: 1
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci  clock-names:
3962306a36Sopenharmony_ci    description:
4062306a36Sopenharmony_ci      Clock source to CPG can be either from external clock input (EXCLK) or
4162306a36Sopenharmony_ci      crystal oscillator (XIN/XOUT).
4262306a36Sopenharmony_ci    const: extal
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci  '#clock-cells':
4562306a36Sopenharmony_ci    description: |
4662306a36Sopenharmony_ci      - For CPG core clocks, the two clock specifier cells must be "CPG_CORE"
4762306a36Sopenharmony_ci        and a core clock reference, as defined in
4862306a36Sopenharmony_ci        <dt-bindings/clock/r9a0*-cpg.h>,
4962306a36Sopenharmony_ci      - For module clocks, the two clock specifier cells must be "CPG_MOD" and
5062306a36Sopenharmony_ci        a module number, as defined in <dt-bindings/clock/r9a0*-cpg.h>.
5162306a36Sopenharmony_ci    const: 2
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci  '#power-domain-cells':
5462306a36Sopenharmony_ci    description:
5562306a36Sopenharmony_ci      SoC devices that are part of the CPG/Module Standby Mode Clock Domain and
5662306a36Sopenharmony_ci      can be power-managed through Module Standby should refer to the CPG device
5762306a36Sopenharmony_ci      node in their "power-domains" property, as documented by the generic PM
5862306a36Sopenharmony_ci      Domain bindings in Documentation/devicetree/bindings/power/power-domain.yaml.
5962306a36Sopenharmony_ci    const: 0
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci  '#reset-cells':
6262306a36Sopenharmony_ci    description:
6362306a36Sopenharmony_ci      The single reset specifier cell must be the module number, as defined in
6462306a36Sopenharmony_ci      <dt-bindings/clock/r9a0*-cpg.h>.
6562306a36Sopenharmony_ci    const: 1
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_cirequired:
6862306a36Sopenharmony_ci  - compatible
6962306a36Sopenharmony_ci  - reg
7062306a36Sopenharmony_ci  - clocks
7162306a36Sopenharmony_ci  - clock-names
7262306a36Sopenharmony_ci  - '#clock-cells'
7362306a36Sopenharmony_ci  - '#power-domain-cells'
7462306a36Sopenharmony_ci  - '#reset-cells'
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ciadditionalProperties: false
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_ciexamples:
7962306a36Sopenharmony_ci  - |
8062306a36Sopenharmony_ci    cpg: clock-controller@11010000 {
8162306a36Sopenharmony_ci            compatible = "renesas,r9a07g044-cpg";
8262306a36Sopenharmony_ci            reg = <0x11010000 0x10000>;
8362306a36Sopenharmony_ci            clocks = <&extal_clk>;
8462306a36Sopenharmony_ci            clock-names = "extal";
8562306a36Sopenharmony_ci            #clock-cells = <2>;
8662306a36Sopenharmony_ci            #power-domain-cells = <0>;
8762306a36Sopenharmony_ci            #reset-cells = <1>;
8862306a36Sopenharmony_ci    };
89