1 # SPDX-License-Identifier: GPL-2.0
4 $id: http://devicetree.org/schemas/power/rockchip,power-controller.yaml#
5 $schema: http://devicetree.org/meta-schemas/core.yaml#
7 title: Rockchip Power Domains
10 - Elaine Zhang <zhangqing@rock-chips.com>
11 - Heiko Stuebner <heiko@sntech.de>
14 Rockchip processors include support for multiple power domains
15 which can be powered up/down by software based on different
16 application scenarios to save power.
18 Power domains contained within power-controller node are
19 generic power domain providers documented in
20 Documentation/devicetree/bindings/power/power-domain.yaml.
22 IP cores belonging to a power domain should contain a
23 "power-domains" property that is a phandle for the
24 power domain node representing the domain.
28 const: power-controller
32 - rockchip,px30-power-controller
33 - rockchip,rk3036-power-controller
34 - rockchip,rk3066-power-controller
35 - rockchip,rk3128-power-controller
36 - rockchip,rk3188-power-controller
37 - rockchip,rk3228-power-controller
38 - rockchip,rk3288-power-controller
39 - rockchip,rk3328-power-controller
40 - rockchip,rk3366-power-controller
41 - rockchip,rk3368-power-controller
42 - rockchip,rk3399-power-controller
43 - rockchip,rk3568-power-controller
44 - rockchip,rk3576-power-controller
45 - rockchip,rk3588-power-controller
46 - rockchip,rv1126-power-controller
48 "#power-domain-cells":
59 - "#power-domain-cells"
61 additionalProperties: false
64 "^power-domain@[0-9a-f]+$":
66 $ref: "#/$defs/pd-node"
68 unevaluatedProperties: false
78 "^power-domain@[0-9a-f]+$":
80 $ref: "#/$defs/pd-node"
82 unevaluatedProperties: false
92 "^power-domain@[0-9a-f]+$":
94 $ref: "#/$defs/pd-node"
96 unevaluatedProperties: false
99 "#power-domain-cells":
106 Represents the power domains within the power controller node.
112 Power domain index. Valid values are defined in
113 "include/dt-bindings/power/px30-power.h"
114 "include/dt-bindings/power/rk3036-power.h"
115 "include/dt-bindings/power/rk3066-power.h"
116 "include/dt-bindings/power/rk3128-power.h"
117 "include/dt-bindings/power/rk3188-power.h"
118 "include/dt-bindings/power/rk3228-power.h"
119 "include/dt-bindings/power/rk3288-power.h"
120 "include/dt-bindings/power/rk3328-power.h"
121 "include/dt-bindings/power/rk3366-power.h"
122 "include/dt-bindings/power/rk3368-power.h"
123 "include/dt-bindings/power/rk3399-power.h"
124 "include/dt-bindings/power/rk3568-power.h"
125 "include/dt-bindings/power/rk3588-power.h"
126 "include/dt-bindings/power/rockchip,rv1126-power.h"
132 A number of phandles to clocks that need to be enabled
133 while power domain switches state.
136 $ref: /schemas/types.yaml#/definitions/phandle-array
140 A number of phandles to qos blocks which need to be saved and restored
141 while power domain switches state.
143 "#power-domain-cells":
146 Must be 0 for nodes representing a single PM domain and 1 for nodes
147 providing multiple PM domains.
151 - "#power-domain-cells"
155 #include <dt-bindings/clock/rk3399-cru.h>
156 #include <dt-bindings/power/rk3399-power.h>
159 #address-cells = <2>;
162 qos_hdcp: qos@ffa90000 {
163 compatible = "rockchip,rk3399-qos", "syscon";
164 reg = <0x0 0xffa90000 0x0 0x20>;
167 qos_iep: qos@ffa98000 {
168 compatible = "rockchip,rk3399-qos", "syscon";
169 reg = <0x0 0xffa98000 0x0 0x20>;
172 qos_rga_r: qos@ffab0000 {
173 compatible = "rockchip,rk3399-qos", "syscon";
174 reg = <0x0 0xffab0000 0x0 0x20>;
177 qos_rga_w: qos@ffab0080 {
178 compatible = "rockchip,rk3399-qos", "syscon";
179 reg = <0x0 0xffab0080 0x0 0x20>;
182 qos_video_m0: qos@ffab8000 {
183 compatible = "rockchip,rk3399-qos", "syscon";
184 reg = <0x0 0xffab8000 0x0 0x20>;
187 qos_video_m1_r: qos@ffac0000 {
188 compatible = "rockchip,rk3399-qos", "syscon";
189 reg = <0x0 0xffac0000 0x0 0x20>;
192 qos_video_m1_w: qos@ffac0080 {
193 compatible = "rockchip,rk3399-qos", "syscon";
194 reg = <0x0 0xffac0080 0x0 0x20>;
197 power-management@ff310000 {
198 compatible = "rockchip,rk3399-pmu", "syscon", "simple-mfd";
199 reg = <0x0 0xff310000 0x0 0x1000>;
202 compatible = "rockchip,rk3399-power-controller";
203 #power-domain-cells = <1>;
204 #address-cells = <1>;
207 /* These power domains are grouped by VD_CENTER */
208 power-domain@RK3399_PD_IEP {
209 reg = <RK3399_PD_IEP>;
210 clocks = <&cru ACLK_IEP>,
213 #power-domain-cells = <0>;
215 power-domain@RK3399_PD_RGA {
216 reg = <RK3399_PD_RGA>;
217 clocks = <&cru ACLK_RGA>,
219 pm_qos = <&qos_rga_r>,
221 #power-domain-cells = <0>;
223 power-domain@RK3399_PD_VCODEC {
224 reg = <RK3399_PD_VCODEC>;
225 clocks = <&cru ACLK_VCODEC>,
227 pm_qos = <&qos_video_m0>;
228 #power-domain-cells = <0>;
230 power-domain@RK3399_PD_VDU {
231 reg = <RK3399_PD_VDU>;
232 clocks = <&cru ACLK_VDU>,
234 pm_qos = <&qos_video_m1_r>,
236 #power-domain-cells = <0>;
238 power-domain@RK3399_PD_VIO {
239 reg = <RK3399_PD_VIO>;
240 #power-domain-cells = <1>;
241 #address-cells = <1>;
244 power-domain@RK3399_PD_HDCP {
245 reg = <RK3399_PD_HDCP>;
246 clocks = <&cru ACLK_HDCP>,
249 pm_qos = <&qos_hdcp>;
250 #power-domain-cells = <0>;