xref: /linux/Documentation/devicetree/bindings/soc/samsung/exynos-pmu.yaml (revision 705672285530cd513b5549f96f92b2a9fcd63017)
196c8bddbSKrzysztof Kozlowski# SPDX-License-Identifier: GPL-2.0
296c8bddbSKrzysztof Kozlowski%YAML 1.2
396c8bddbSKrzysztof Kozlowski---
496c8bddbSKrzysztof Kozlowski$id: http://devicetree.org/schemas/soc/samsung/exynos-pmu.yaml#
596c8bddbSKrzysztof Kozlowski$schema: http://devicetree.org/meta-schemas/core.yaml#
696c8bddbSKrzysztof Kozlowski
796c8bddbSKrzysztof Kozlowskititle: Samsung Exynos SoC series Power Management Unit (PMU)
896c8bddbSKrzysztof Kozlowski
996c8bddbSKrzysztof Kozlowskimaintainers:
1096c8bddbSKrzysztof Kozlowski  - Krzysztof Kozlowski <krzk@kernel.org>
1196c8bddbSKrzysztof Kozlowski
1296c8bddbSKrzysztof Kozlowski# Custom select to avoid matching all nodes with 'syscon'
1396c8bddbSKrzysztof Kozlowskiselect:
1496c8bddbSKrzysztof Kozlowski  properties:
1596c8bddbSKrzysztof Kozlowski    compatible:
1696c8bddbSKrzysztof Kozlowski      contains:
1796c8bddbSKrzysztof Kozlowski        enum:
1896c8bddbSKrzysztof Kozlowski          - samsung,exynos3250-pmu
1996c8bddbSKrzysztof Kozlowski          - samsung,exynos4210-pmu
208a19d4a1SArtur Weber          - samsung,exynos4212-pmu
2196c8bddbSKrzysztof Kozlowski          - samsung,exynos4412-pmu
2296c8bddbSKrzysztof Kozlowski          - samsung,exynos5250-pmu
2396c8bddbSKrzysztof Kozlowski          - samsung,exynos5260-pmu
2496c8bddbSKrzysztof Kozlowski          - samsung,exynos5410-pmu
2596c8bddbSKrzysztof Kozlowski          - samsung,exynos5420-pmu
2696c8bddbSKrzysztof Kozlowski          - samsung,exynos5433-pmu
2796c8bddbSKrzysztof Kozlowski          - samsung,exynos7-pmu
2896c8bddbSKrzysztof Kozlowski          - samsung,exynos850-pmu
2996c8bddbSKrzysztof Kozlowski          - samsung-s5pv210-pmu
3096c8bddbSKrzysztof Kozlowski  required:
3196c8bddbSKrzysztof Kozlowski    - compatible
3296c8bddbSKrzysztof Kozlowski
3396c8bddbSKrzysztof Kozlowskiproperties:
3496c8bddbSKrzysztof Kozlowski  compatible:
35fe6a952bSKrzysztof Kozlowski    oneOf:
36fe6a952bSKrzysztof Kozlowski      - items:
3796c8bddbSKrzysztof Kozlowski          - enum:
3896c8bddbSKrzysztof Kozlowski              - samsung,exynos3250-pmu
3996c8bddbSKrzysztof Kozlowski              - samsung,exynos4210-pmu
408a19d4a1SArtur Weber              - samsung,exynos4212-pmu
4196c8bddbSKrzysztof Kozlowski              - samsung,exynos4412-pmu
4296c8bddbSKrzysztof Kozlowski              - samsung,exynos5250-pmu
4396c8bddbSKrzysztof Kozlowski              - samsung,exynos5260-pmu
4496c8bddbSKrzysztof Kozlowski              - samsung,exynos5410-pmu
4596c8bddbSKrzysztof Kozlowski              - samsung,exynos5420-pmu
4696c8bddbSKrzysztof Kozlowski              - samsung,exynos5433-pmu
4796c8bddbSKrzysztof Kozlowski              - samsung,exynos7-pmu
4896c8bddbSKrzysztof Kozlowski              - samsung,exynos850-pmu
4996c8bddbSKrzysztof Kozlowski              - samsung-s5pv210-pmu
5096c8bddbSKrzysztof Kozlowski          - const: syscon
51fe6a952bSKrzysztof Kozlowski      - items:
52fe6a952bSKrzysztof Kozlowski          - enum:
5325737c24SKrzysztof Kozlowski              - samsung,exynos7885-pmu
5425737c24SKrzysztof Kozlowski              - samsung,exynosautov9-pmu
55*70567228SJaewon Kim              - samsung,exynosautov920-pmu
5625737c24SKrzysztof Kozlowski          - const: samsung,exynos7-pmu
5725737c24SKrzysztof Kozlowski          - const: syscon
5825737c24SKrzysztof Kozlowski      - items:
5925737c24SKrzysztof Kozlowski          - enum:
60e154a338SKrzysztof Kozlowski              - samsung,exynos3250-pmu
61e154a338SKrzysztof Kozlowski              - samsung,exynos4210-pmu
628a19d4a1SArtur Weber              - samsung,exynos4212-pmu
63e154a338SKrzysztof Kozlowski              - samsung,exynos4412-pmu
64fe6a952bSKrzysztof Kozlowski              - samsung,exynos5250-pmu
65fe6a952bSKrzysztof Kozlowski              - samsung,exynos5420-pmu
66fe6a952bSKrzysztof Kozlowski              - samsung,exynos5433-pmu
67fe6a952bSKrzysztof Kozlowski          - const: simple-mfd
68fe6a952bSKrzysztof Kozlowski          - const: syscon
6996c8bddbSKrzysztof Kozlowski
7096c8bddbSKrzysztof Kozlowski  reg:
7196c8bddbSKrzysztof Kozlowski    maxItems: 1
7296c8bddbSKrzysztof Kozlowski
7396c8bddbSKrzysztof Kozlowski  '#clock-cells':
7496c8bddbSKrzysztof Kozlowski    const: 1
7596c8bddbSKrzysztof Kozlowski
7696c8bddbSKrzysztof Kozlowski  clock-names:
7796c8bddbSKrzysztof Kozlowski    description:
7896c8bddbSKrzysztof Kozlowski      List of clock names for particular CLKOUT mux inputs
7996c8bddbSKrzysztof Kozlowski    minItems: 1
8096c8bddbSKrzysztof Kozlowski    maxItems: 32
8196c8bddbSKrzysztof Kozlowski    items:
8296c8bddbSKrzysztof Kozlowski      pattern: '^clkout([0-9]|[12][0-9]|3[0-1])$'
8396c8bddbSKrzysztof Kozlowski
8496c8bddbSKrzysztof Kozlowski  clocks:
8596c8bddbSKrzysztof Kozlowski    minItems: 1
8696c8bddbSKrzysztof Kozlowski    maxItems: 32
8796c8bddbSKrzysztof Kozlowski
88fe6a952bSKrzysztof Kozlowski  dp-phy:
89fe6a952bSKrzysztof Kozlowski    $ref: /schemas/phy/samsung,dp-video-phy.yaml
90fe6a952bSKrzysztof Kozlowski    unevaluatedProperties: false
91fe6a952bSKrzysztof Kozlowski
9296c8bddbSKrzysztof Kozlowski  interrupt-controller:
9396c8bddbSKrzysztof Kozlowski    description:
9496c8bddbSKrzysztof Kozlowski      Some PMUs are capable of behaving as an interrupt controller (mostly
9596c8bddbSKrzysztof Kozlowski      to wake up a suspended PMU).
9696c8bddbSKrzysztof Kozlowski
9796c8bddbSKrzysztof Kozlowski  '#interrupt-cells':
9896c8bddbSKrzysztof Kozlowski    description:
9996c8bddbSKrzysztof Kozlowski      Must be identical to the that of the parent interrupt controller.
10096c8bddbSKrzysztof Kozlowski    const: 3
10196c8bddbSKrzysztof Kozlowski
102fe6a952bSKrzysztof Kozlowski  mipi-phy:
103fe6a952bSKrzysztof Kozlowski    $ref: /schemas/phy/samsung,mipi-video-phy.yaml
104fe6a952bSKrzysztof Kozlowski    unevaluatedProperties: false
105fe6a952bSKrzysztof Kozlowski
1063e27bf71SKrzysztof Kozlowski  reboot-mode:
1073e27bf71SKrzysztof Kozlowski    $ref: /schemas/power/reset/syscon-reboot-mode.yaml
1083e27bf71SKrzysztof Kozlowski    type: object
1093e27bf71SKrzysztof Kozlowski    description:
1103e27bf71SKrzysztof Kozlowski      Reboot mode to alter bootloader behavior for the next boot
1113e27bf71SKrzysztof Kozlowski
11296c8bddbSKrzysztof Kozlowski  syscon-poweroff:
11361bebc29SKrzysztof Kozlowski    $ref: /schemas/power/reset/syscon-poweroff.yaml#
11496c8bddbSKrzysztof Kozlowski    type: object
11596c8bddbSKrzysztof Kozlowski    description:
11696c8bddbSKrzysztof Kozlowski      Node for power off method
11796c8bddbSKrzysztof Kozlowski
11896c8bddbSKrzysztof Kozlowski  syscon-reboot:
11961bebc29SKrzysztof Kozlowski    $ref: /schemas/power/reset/syscon-reboot.yaml#
12096c8bddbSKrzysztof Kozlowski    type: object
12196c8bddbSKrzysztof Kozlowski    description:
12296c8bddbSKrzysztof Kozlowski      Node for reboot method
12396c8bddbSKrzysztof Kozlowski
12496c8bddbSKrzysztof Kozlowskirequired:
12596c8bddbSKrzysztof Kozlowski  - compatible
12696c8bddbSKrzysztof Kozlowski  - reg
12796c8bddbSKrzysztof Kozlowski
12896c8bddbSKrzysztof KozlowskiadditionalProperties: false
12996c8bddbSKrzysztof Kozlowski
13096c8bddbSKrzysztof KozlowskiallOf:
13196c8bddbSKrzysztof Kozlowski  - if:
13296c8bddbSKrzysztof Kozlowski      properties:
13396c8bddbSKrzysztof Kozlowski        compatible:
13496c8bddbSKrzysztof Kozlowski          contains:
13596c8bddbSKrzysztof Kozlowski            enum:
13696c8bddbSKrzysztof Kozlowski              - samsung,exynos3250-pmu
13796c8bddbSKrzysztof Kozlowski              - samsung,exynos4210-pmu
1388a19d4a1SArtur Weber              - samsung,exynos4212-pmu
13996c8bddbSKrzysztof Kozlowski              - samsung,exynos4412-pmu
14096c8bddbSKrzysztof Kozlowski              - samsung,exynos5250-pmu
14196c8bddbSKrzysztof Kozlowski              - samsung,exynos5410-pmu
14296c8bddbSKrzysztof Kozlowski              - samsung,exynos5420-pmu
14396c8bddbSKrzysztof Kozlowski              - samsung,exynos5433-pmu
14496c8bddbSKrzysztof Kozlowski    then:
14596c8bddbSKrzysztof Kozlowski      required:
14696c8bddbSKrzysztof Kozlowski        - '#clock-cells'
14796c8bddbSKrzysztof Kozlowski        - clock-names
14896c8bddbSKrzysztof Kozlowski        - clocks
14996c8bddbSKrzysztof Kozlowski
150fe6a952bSKrzysztof Kozlowski  - if:
151fe6a952bSKrzysztof Kozlowski      properties:
152fe6a952bSKrzysztof Kozlowski        compatible:
153fe6a952bSKrzysztof Kozlowski          contains:
154fe6a952bSKrzysztof Kozlowski            enum:
155e154a338SKrzysztof Kozlowski              - samsung,exynos3250-pmu
156e154a338SKrzysztof Kozlowski              - samsung,exynos4210-pmu
1578a19d4a1SArtur Weber              - samsung,exynos4212-pmu
158e154a338SKrzysztof Kozlowski              - samsung,exynos4412-pmu
159e154a338SKrzysztof Kozlowski              - samsung,exynos5250-pmu
160e154a338SKrzysztof Kozlowski              - samsung,exynos5420-pmu
161e154a338SKrzysztof Kozlowski              - samsung,exynos5433-pmu
162e154a338SKrzysztof Kozlowski    then:
163e154a338SKrzysztof Kozlowski      properties:
164e154a338SKrzysztof Kozlowski        mipi-phy: true
165e154a338SKrzysztof Kozlowski    else:
166e154a338SKrzysztof Kozlowski      properties:
167e154a338SKrzysztof Kozlowski        mipi-phy: false
168e154a338SKrzysztof Kozlowski
169e154a338SKrzysztof Kozlowski  - if:
170e154a338SKrzysztof Kozlowski      properties:
171e154a338SKrzysztof Kozlowski        compatible:
172e154a338SKrzysztof Kozlowski          contains:
173e154a338SKrzysztof Kozlowski            enum:
174fe6a952bSKrzysztof Kozlowski              - samsung,exynos5250-pmu
175fe6a952bSKrzysztof Kozlowski              - samsung,exynos5420-pmu
176fe6a952bSKrzysztof Kozlowski              - samsung,exynos5433-pmu
177fe6a952bSKrzysztof Kozlowski    then:
178fe6a952bSKrzysztof Kozlowski      properties:
179fe6a952bSKrzysztof Kozlowski        dp-phy: true
180fe6a952bSKrzysztof Kozlowski    else:
181fe6a952bSKrzysztof Kozlowski      properties:
182fe6a952bSKrzysztof Kozlowski        dp-phy: false
183fe6a952bSKrzysztof Kozlowski
18496c8bddbSKrzysztof Kozlowskiexamples:
18596c8bddbSKrzysztof Kozlowski  - |
18696c8bddbSKrzysztof Kozlowski    #include <dt-bindings/clock/exynos5250.h>
18796c8bddbSKrzysztof Kozlowski
18896c8bddbSKrzysztof Kozlowski    pmu_system_controller: system-controller@10040000 {
18996c8bddbSKrzysztof Kozlowski        compatible = "samsung,exynos5250-pmu", "syscon";
19096c8bddbSKrzysztof Kozlowski        reg = <0x10040000 0x5000>;
19196c8bddbSKrzysztof Kozlowski        interrupt-controller;
19296c8bddbSKrzysztof Kozlowski        #interrupt-cells = <3>;
19396c8bddbSKrzysztof Kozlowski        interrupt-parent = <&gic>;
19496c8bddbSKrzysztof Kozlowski        #clock-cells = <1>;
19596c8bddbSKrzysztof Kozlowski        clock-names = "clkout16";
19696c8bddbSKrzysztof Kozlowski        clocks = <&clock CLK_FIN_PLL>;
197fe6a952bSKrzysztof Kozlowski
198fe6a952bSKrzysztof Kozlowski        dp-phy {
199fe6a952bSKrzysztof Kozlowski            compatible = "samsung,exynos5250-dp-video-phy";
200fe6a952bSKrzysztof Kozlowski            #phy-cells = <0>;
201fe6a952bSKrzysztof Kozlowski        };
202fe6a952bSKrzysztof Kozlowski
203fe6a952bSKrzysztof Kozlowski        mipi-phy {
204fe6a952bSKrzysztof Kozlowski            compatible = "samsung,s5pv210-mipi-video-phy";
205fe6a952bSKrzysztof Kozlowski            #phy-cells = <1>;
206fe6a952bSKrzysztof Kozlowski        };
20796c8bddbSKrzysztof Kozlowski    };
208