xref: /freebsd-src/sys/contrib/device-tree/Bindings/clock/renesas,emev2-smu.yaml (revision 5956d97f4b3204318ceb6aa9c77bd0bc6ea87a41)
1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/clock/renesas,emev2-smu.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Renesas EMMA Mobile EV2 System Management Unit
8
9maintainers:
10  - Geert Uytterhoeven <geert+renesas@glider.be>
11  - Magnus Damm <magnus.damm@gmail.com>
12
13description: |
14  The System Management Unit is described in user's manual R19UH0037EJ1000_SMU.
15  This is not a clock provider, but clocks under SMU depend on it.
16
17properties:
18  compatible:
19    const: renesas,emev2-smu
20
21  reg:
22    maxItems: 1
23
24  '#address-cells':
25    const: 2
26
27  '#size-cells':
28    const: 0
29
30required:
31  - compatible
32  - reg
33  - '#address-cells'
34  - '#size-cells'
35
36patternProperties:
37  ".*sclkdiv@.*":
38    type: object
39
40    description: |
41      Function block with an input mux and a divider, which corresponds to
42      "Serial clock generator" in fig. "Clock System Overview" of the manual,
43      and "xxx frequency division setting register" (XXXCLKDIV) registers.
44      This makes internal (neither input nor output) clock that is provided
45      to input of xxxGCLK block.
46
47    properties:
48      compatible:
49        const: renesas,emev2-smu-clkdiv
50
51      reg:
52        maxItems: 1
53        description:
54          Byte offset from SMU base and Bit position in the register.
55
56      clocks:
57        minItems: 1
58        maxItems: 4
59
60      '#clock-cells':
61        const: 0
62
63    required:
64      - compatible
65      - reg
66      - clocks
67      - '#clock-cells'
68
69    additionalProperties: false
70
71  ".*sclk@.*":
72    type: object
73
74    description: |
75      Clock gating node shown as "Clock stop processing block" in the
76      fig. "Clock System Overview" of the manual.
77      Registers are "xxx clock gate control register" (XXXGCLKCTRL).
78
79    properties:
80      compatible:
81        const: renesas,emev2-smu-gclk
82
83      reg:
84        maxItems: 1
85        description:
86          Byte offset from SMU base and Bit position in the register.
87
88      clocks:
89        maxItems: 1
90
91      '#clock-cells':
92        const: 0
93
94    required:
95      - compatible
96      - reg
97      - clocks
98      - '#clock-cells'
99
100    additionalProperties: false
101
102additionalProperties: true
103
104examples:
105  - |
106    // Example of clock-tree description:
107    //
108    //  This describes a clock path in the clock tree
109    //   c32ki -> pll3_fo -> usia_u0_sclkdiv -> usia_u0_sclk
110    clocks@e0110000 {
111            compatible = "renesas,emev2-smu";
112            reg = <0xe0110000 0x10000>;
113            #address-cells = <2>;
114            #size-cells = <0>;
115
116            c32ki: c32ki {
117                    compatible = "fixed-clock";
118                    clock-frequency = <32768>;
119                    #clock-cells = <0>;
120            };
121            pll3_fo: pll3_fo {
122                    compatible = "fixed-factor-clock";
123                    clocks = <&c32ki>;
124                    clock-div = <1>;
125                    clock-mult = <7000>;
126                    #clock-cells = <0>;
127            };
128            usia_u0_sclkdiv: usia_u0_sclkdiv@610,0 {
129                    compatible = "renesas,emev2-smu-clkdiv";
130                    reg = <0x610 0>;
131                    clocks = <&pll3_fo>;
132                    #clock-cells = <0>;
133            };
134            usia_u0_sclk: usia_u0_sclk@4a0,1 {
135                    compatible = "renesas,emev2-smu-gclk";
136                    reg = <0x4a0 1>;
137                    clocks = <&usia_u0_sclkdiv>;
138                    #clock-cells = <0>;
139            };
140    };
141