hc
2024-08-12 233ab1bd4c5697f5cdec94e60206e8c6ac609b4c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
 * Copyright (c) 2022 Rockchip Electronics Co., Ltd.
 *
 */
 
#include "rk3399-evb.dtsi"
#include <dt-bindings/suspend/rockchip-rk3399.h>
 
/ {
   compatible = "rockchip,rk3399-evb-rev3", "rockchip,rk3399";
 
   vcc5v0_sys: vcc5v0-sys {
       compatible = "regulator-fixed";
       regulator-name = "vcc5v0_sys";
       regulator-always-on;
       regulator-boot-on;
       regulator-min-microvolt = <5000000>;
       regulator-max-microvolt = <5000000>;
   };
 
   vdd_center: vdd-center {
       compatible = "pwm-regulator";
       rockchip,pwm_id = <2>;
       rockchip,pwm_voltage = <900000>;
       pwms = <&pwm2 0 25000 1>;
       regulator-name = "vdd_center";
       regulator-min-microvolt = <800000>;
       regulator-max-microvolt = <1400000>;
       regulator-always-on;
       regulator-boot-on;
   };
 
   xin32k: xin32k {
       compatible = "fixed-clock";
       clock-frequency = <32768>;
       clock-output-names = "xin32k";
       #clock-cells = <0>;
   };
 
   rockchip_suspend: rockchip-suspend {
       compatible = "rockchip,pm-rk3399";
       status = "okay";
       rockchip,sleep-debug-en = <1>;
       rockchip,wakeup-config = <
           (0
           | RKPM_GPIO_WKUP_EN
           )
       >;
       rockchip,pwm-regulator-config = <
           (0
           | PWM2_REGULATOR_EN
           )
       >;
       rockchip,power-ctrl =
           <&gpio1 17 GPIO_ACTIVE_HIGH>;
   };
};
 
&i2c0 {
   fusb1: fusb30x@22 {
       compatible = "fairchild,fusb302";
       reg = <0x22>;
       pinctrl-names = "default";
       pinctrl-0 = <&fusb1_int>;
       vbus-5v-gpios = <&gpio1 4 GPIO_ACTIVE_HIGH>;
       int-n-gpios = <&gpio1 24 GPIO_ACTIVE_HIGH>;
       status = "okay";
   };
 
   vdd_cpu_b: syr827@40 {
       compatible = "silergy,syr827";
       reg = <0x40>;
       vin-supply = <&vcc5v0_sys>;
       regulator-compatible = "fan53555-reg";
       pinctrl-0 = <&vsel1_gpio>;
       vsel-gpios = <&gpio1 17 GPIO_ACTIVE_HIGH>;
       regulator-name = "vdd_cpu_b";
       regulator-min-microvolt = <712500>;
       regulator-max-microvolt = <1500000>;
       regulator-ramp-delay = <1000>;
       fcs,suspend-voltage-selector = <1>;
       regulator-always-on;
       regulator-boot-on;
       regulator-initial-state = <3>;
           regulator-state-mem {
           regulator-off-in-suspend;
       };
   };
 
   vdd_gpu: syr828@41 {
       compatible = "silergy,syr828";
       reg = <0x41>;
       vin-supply = <&vcc5v0_sys>;
       regulator-compatible = "fan53555-reg";
       pinctrl-0 = <&vsel2_gpio>;
       vsel-gpios = <&gpio1 14 GPIO_ACTIVE_HIGH>;
       regulator-name = "vdd_gpu";
       regulator-min-microvolt = <712500>;
       regulator-max-microvolt = <1500000>;
       regulator-ramp-delay = <1000>;
       fcs,suspend-voltage-selector = <1>;
       regulator-always-on;
       regulator-boot-on;
       regulator-initial-state = <3>;
           regulator-state-mem {
           regulator-off-in-suspend;
       };
   };
 
   rk808: pmic@1b {
       compatible = "rockchip,rk808";
       reg = <0x1b>;
       interrupt-parent = <&gpio1>;
       interrupts = <21 IRQ_TYPE_LEVEL_LOW>;
       pinctrl-names = "default";
       pinctrl-0 = <&pmic_int_l &pmic_dvs2>;
       rockchip,system-power-controller;
       wakeup-source;
       #clock-cells = <1>;
       clock-output-names = "rk808-clkout1", "rk808-clkout2";
 
       vcc1-supply = <&vcc3v3_sys>;
       vcc2-supply = <&vcc3v3_sys>;
       vcc3-supply = <&vcc3v3_sys>;
       vcc4-supply = <&vcc3v3_sys>;
       vcc6-supply = <&vcc3v3_sys>;
       vcc7-supply = <&vcc3v3_sys>;
       vcc8-supply = <&vcc3v3_sys>;
       vcc9-supply = <&vcc3v3_sys>;
       vcc10-supply = <&vcc3v3_sys>;
       vcc11-supply = <&vcc3v3_sys>;
       vcc12-supply = <&vcc3v3_sys>;
       vddio-supply = <&vcc1v8_pmu>;
 
       regulators {
           vdd_log: DCDC_REG1 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <750000>;
               regulator-max-microvolt = <1350000>;
               regulator-ramp-delay = <6001>;
               regulator-name = "vdd_log";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <900000>;
               };
           };
 
           vdd_cpu_l: DCDC_REG2 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <750000>;
               regulator-max-microvolt = <1350000>;
               regulator-ramp-delay = <6001>;
               regulator-name = "vdd_cpu_l";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
 
           vcc_ddr: DCDC_REG3 {
               regulator-always-on;
               regulator-boot-on;
               regulator-name = "vcc_ddr";
               regulator-state-mem {
                   regulator-on-in-suspend;
               };
           };
 
           vcc_1v8: DCDC_REG4 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <1800000>;
               regulator-name = "vcc_1v8";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <1800000>;
               };
           };
 
           vcc1v8_dvp: LDO_REG1 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <1800000>;
               regulator-name = "vcc1v8_dvp";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
 
           vcc3v0_tp: LDO_REG2 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <3000000>;
               regulator-max-microvolt = <3000000>;
               regulator-name = "vcc3v0_tp";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
 
           vcc1v8_pmu: LDO_REG3 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <1800000>;
               regulator-name = "vcc1v8_pmu";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <1800000>;
               };
           };
 
           vcc_sd: LDO_REG4 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <3000000>;
               regulator-name = "vcc_sd";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <3000000>;
               };
           };
 
           vcca3v0_codec: LDO_REG5 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <3000000>;
               regulator-max-microvolt = <3000000>;
               regulator-name = "vcca3v0_codec";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
 
           vcc_1v5: LDO_REG6 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1500000>;
               regulator-max-microvolt = <1500000>;
               regulator-name = "vcc_1v5";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <1500000>;
               };
           };
 
           vcca1v8_codec: LDO_REG7 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <1800000>;
               regulator-name = "vcca1v8_codec";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
 
           vcc_3v0: LDO_REG8 {
               regulator-always-on;
               regulator-boot-on;
               regulator-min-microvolt = <3000000>;
               regulator-max-microvolt = <3000000>;
               regulator-name = "vcc_3v0";
               regulator-state-mem {
                   regulator-on-in-suspend;
                   regulator-suspend-microvolt = <3000000>;
               };
           };
 
           vcc3v3_s3: SWITCH_REG1 {
               regulator-always-on;
               regulator-boot-on;
               regulator-name = "vcc3v3_s3";
               regulator-state-mem {
                   regulator-on-in-suspend;
               };
           };
 
           vcc3v3_s0: SWITCH_REG2 {
               regulator-always-on;
               regulator-boot-on;
               regulator-name = "vcc3v3_s0";
               regulator-state-mem {
                   regulator-off-in-suspend;
               };
           };
       };
   };
};
 
&es8316 {
   reg = <0x11>;
};
 
&i2c6 {
   status = "okay";
   fusb0: fusb30x@22 {
       compatible = "fairchild,fusb302";
       reg = <0x22>;
       pinctrl-names = "default";
       pinctrl-0 = <&fusb0_int>;
       vbus-5v-gpios = <&gpio1 3 GPIO_ACTIVE_HIGH>;
       int-n-gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
       status = "okay";
   };
};
 
&pwm2 {
   status = "okay";
   pinctrl-names = "active";
   pinctrl-0 = <&pwm2_pin_pull_down>;
};