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,rk3588-power-controller
45 - rockchip,rv1126-power-controller
47 "#power-domain-cells":
58 - "#power-domain-cells"
60 additionalProperties: false
63 "^power-domain@[0-9a-f]+$":
65 $ref: "#/$defs/pd-node"
67 unevaluatedProperties: false
77 "^power-domain@[0-9a-f]+$":
79 $ref: "#/$defs/pd-node"
81 unevaluatedProperties: false
91 "^power-domain@[0-9a-f]+$":
93 $ref: "#/$defs/pd-node"
95 unevaluatedProperties: false
98 "#power-domain-cells":
105 Represents the power domains within the power controller node.
111 Power domain index. Valid values are defined in
112 "include/dt-bindings/power/px30-power.h"
113 "include/dt-bindings/power/rk3036-power.h"
114 "include/dt-bindings/power/rk3066-power.h"
115 "include/dt-bindings/power/rk3128-power.h"
116 "include/dt-bindings/power/rk3188-power.h"
117 "include/dt-bindings/power/rk3228-power.h"
118 "include/dt-bindings/power/rk3288-power.h"
119 "include/dt-bindings/power/rk3328-power.h"
120 "include/dt-bindings/power/rk3366-power.h"
121 "include/dt-bindings/power/rk3368-power.h"
122 "include/dt-bindings/power/rk3399-power.h"
123 "include/dt-bindings/power/rk3568-power.h"
124 "include/dt-bindings/power/rk3588-power.h"
125 "include/dt-bindings/power/rockchip,rv1126-power.h"
131 A number of phandles to clocks that need to be enabled
132 while power domain switches state.
135 $ref: /schemas/types.yaml#/definitions/phandle-array
139 A number of phandles to qos blocks which need to be saved and restored
140 while power domain switches state.
142 "#power-domain-cells":
145 Must be 0 for nodes representing a single PM domain and 1 for nodes
146 providing multiple PM domains.
150 - "#power-domain-cells"
154 #include <dt-bindings/clock/rk3399-cru.h>
155 #include <dt-bindings/power/rk3399-power.h>
158 #address-cells = <2>;
161 qos_hdcp: qos@ffa90000 {
162 compatible = "rockchip,rk3399-qos", "syscon";
163 reg = <0x0 0xffa90000 0x0 0x20>;
166 qos_iep: qos@ffa98000 {
167 compatible = "rockchip,rk3399-qos", "syscon";
168 reg = <0x0 0xffa98000 0x0 0x20>;
171 qos_rga_r: qos@ffab0000 {
172 compatible = "rockchip,rk3399-qos", "syscon";
173 reg = <0x0 0xffab0000 0x0 0x20>;
176 qos_rga_w: qos@ffab0080 {
177 compatible = "rockchip,rk3399-qos", "syscon";
178 reg = <0x0 0xffab0080 0x0 0x20>;
181 qos_video_m0: qos@ffab8000 {
182 compatible = "rockchip,rk3399-qos", "syscon";
183 reg = <0x0 0xffab8000 0x0 0x20>;
186 qos_video_m1_r: qos@ffac0000 {
187 compatible = "rockchip,rk3399-qos", "syscon";
188 reg = <0x0 0xffac0000 0x0 0x20>;
191 qos_video_m1_w: qos@ffac0080 {
192 compatible = "rockchip,rk3399-qos", "syscon";
193 reg = <0x0 0xffac0080 0x0 0x20>;
196 power-management@ff310000 {
197 compatible = "rockchip,rk3399-pmu", "syscon", "simple-mfd";
198 reg = <0x0 0xff310000 0x0 0x1000>;
201 compatible = "rockchip,rk3399-power-controller";
202 #power-domain-cells = <1>;
203 #address-cells = <1>;
206 /* These power domains are grouped by VD_CENTER */
207 power-domain@RK3399_PD_IEP {
208 reg = <RK3399_PD_IEP>;
209 clocks = <&cru ACLK_IEP>,
212 #power-domain-cells = <0>;
214 power-domain@RK3399_PD_RGA {
215 reg = <RK3399_PD_RGA>;
216 clocks = <&cru ACLK_RGA>,
218 pm_qos = <&qos_rga_r>,
220 #power-domain-cells = <0>;
222 power-domain@RK3399_PD_VCODEC {
223 reg = <RK3399_PD_VCODEC>;
224 clocks = <&cru ACLK_VCODEC>,
226 pm_qos = <&qos_video_m0>;
227 #power-domain-cells = <0>;
229 power-domain@RK3399_PD_VDU {
230 reg = <RK3399_PD_VDU>;
231 clocks = <&cru ACLK_VDU>,
233 pm_qos = <&qos_video_m1_r>,
235 #power-domain-cells = <0>;
237 power-domain@RK3399_PD_VIO {
238 reg = <RK3399_PD_VIO>;
239 #power-domain-cells = <1>;
240 #address-cells = <1>;
243 power-domain@RK3399_PD_HDCP {
244 reg = <RK3399_PD_HDCP>;
245 clocks = <&cru ACLK_HDCP>,
248 pm_qos = <&qos_hdcp>;
249 #power-domain-cells = <0>;