1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
3 * Copyright (c) 2018 Collabora Ltd.
4 * Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd.
6 * Schematics available at https://dl.vamrs.com/products/ficus/docs/hw
10 #include "rk3399.dtsi"
11 #include "rk3399-opp.dtsi"
14 model = "96boards RK3399 Ficus";
15 compatible = "vamrs,ficus", "rockchip,rk3399";
18 stdout-path = "serial2:1500000n8";
21 clkin_gmac: external-gmac-clock {
22 compatible = "fixed-clock";
23 clock-frequency = <125000000>;
24 clock-output-names = "clkin_gmac";
28 vcc1v8_s0: vcc1v8-s0 {
29 compatible = "regulator-fixed";
30 regulator-name = "vcc1v8_s0";
31 regulator-min-microvolt = <1800000>;
32 regulator-max-microvolt = <1800000>;
37 compatible = "regulator-fixed";
38 regulator-name = "vcc_sys";
39 regulator-min-microvolt = <5000000>;
40 regulator-max-microvolt = <5000000>;
44 vcc3v3_sys: vcc3v3-sys {
45 compatible = "regulator-fixed";
46 regulator-name = "vcc3v3_sys";
47 regulator-min-microvolt = <3300000>;
48 regulator-max-microvolt = <3300000>;
50 vin-supply = <&vcc_sys>;
53 vcc3v3_pcie: vcc3v3-pcie-regulator {
54 compatible = "regulator-fixed";
56 gpio = <&gpio1 24 GPIO_ACTIVE_HIGH>;
57 pinctrl-names = "default";
58 pinctrl-0 = <&pcie_drv>;
60 regulator-name = "vcc3v3_pcie";
61 regulator-min-microvolt = <3300000>;
62 regulator-max-microvolt = <3300000>;
63 vin-supply = <&vcc3v3_sys>;
66 vcc5v0_host: vcc5v0-host-regulator {
67 compatible = "regulator-fixed";
69 gpio = <&gpio4 27 GPIO_ACTIVE_HIGH>;
70 pinctrl-names = "default";
71 pinctrl-0 = <&host_vbus_drv>;
72 regulator-name = "vcc5v0_host";
73 regulator-min-microvolt = <5000000>;
74 regulator-max-microvolt = <5000000>;
76 vin-supply = <&vcc_sys>;
80 compatible = "pwm-regulator";
81 pwms = <&pwm2 0 25000 0>;
82 regulator-name = "vdd_log";
83 regulator-min-microvolt = <800000>;
84 regulator-max-microvolt = <1400000>;
87 vin-supply = <&vcc_sys>;
93 cpu-supply = <&vdd_cpu_l>;
97 cpu-supply = <&vdd_cpu_l>;
101 cpu-supply = <&vdd_cpu_l>;
105 cpu-supply = <&vdd_cpu_l>;
109 cpu-supply = <&vdd_cpu_b>;
113 cpu-supply = <&vdd_cpu_b>;
121 assigned-clocks = <&cru SCLK_RMII_SRC>;
122 assigned-clock-parents = <&clkin_gmac>;
123 clock_in_out = "input";
124 phy-supply = <&vcc3v3_sys>;
126 pinctrl-names = "default";
127 pinctrl-0 = <&rgmii_pins>;
128 snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;
129 snps,reset-active-low;
130 snps,reset-delays-us = <0 10000 50000>;
137 ddc-i2c-bus = <&i2c3>;
138 pinctrl-names = "default";
139 pinctrl-0 = <&hdmi_cec>;
144 clock-frequency = <400000>;
145 i2c-scl-rising-time-ns = <168>;
146 i2c-scl-falling-time-ns = <4>;
149 vdd_cpu_b: regulator@40 {
150 compatible = "silergy,syr827";
152 fcs,suspend-voltage-selector = <1>;
153 regulator-name = "vdd_cpu_b";
154 regulator-min-microvolt = <712500>;
155 regulator-max-microvolt = <1500000>;
156 regulator-ramp-delay = <1000>;
159 vin-supply = <&vcc_sys>;
162 regulator-state-mem {
163 regulator-off-in-suspend;
167 vdd_gpu: regulator@41 {
168 compatible = "silergy,syr828";
170 fcs,suspend-voltage-selector = <1>;
171 regulator-name = "vdd_gpu";
172 regulator-min-microvolt = <712500>;
173 regulator-max-microvolt = <1500000>;
174 regulator-ramp-delay = <1000>;
177 vin-supply = <&vcc_sys>;
178 regulator-state-mem {
179 regulator-off-in-suspend;
184 compatible = "rockchip,rk808";
186 interrupt-parent = <&gpio1>;
187 interrupts = <21 IRQ_TYPE_LEVEL_LOW>;
188 pinctrl-names = "default";
189 pinctrl-0 = <&pmic_int_l>;
190 rockchip,system-power-controller;
193 clock-output-names = "xin32k", "rk808-clkout2";
195 vcc1-supply = <&vcc_sys>;
196 vcc2-supply = <&vcc_sys>;
197 vcc3-supply = <&vcc_sys>;
198 vcc4-supply = <&vcc_sys>;
199 vcc6-supply = <&vcc_sys>;
200 vcc7-supply = <&vcc_sys>;
201 vcc8-supply = <&vcc3v3_sys>;
202 vcc9-supply = <&vcc_sys>;
203 vcc10-supply = <&vcc_sys>;
204 vcc11-supply = <&vcc_sys>;
205 vcc12-supply = <&vcc3v3_sys>;
206 vddio-supply = <&vcc_1v8>;
209 vdd_center: DCDC_REG1 {
210 regulator-name = "vdd_center";
211 regulator-min-microvolt = <750000>;
212 regulator-max-microvolt = <1350000>;
215 regulator-state-mem {
216 regulator-off-in-suspend;
220 vdd_cpu_l: DCDC_REG2 {
221 regulator-name = "vdd_cpu_l";
222 regulator-min-microvolt = <750000>;
223 regulator-max-microvolt = <1350000>;
226 regulator-state-mem {
227 regulator-off-in-suspend;
232 regulator-name = "vcc_ddr";
235 regulator-state-mem {
236 regulator-on-in-suspend;
241 regulator-name = "vcc_1v8";
242 regulator-min-microvolt = <1800000>;
243 regulator-max-microvolt = <1800000>;
246 regulator-state-mem {
247 regulator-on-in-suspend;
248 regulator-suspend-microvolt = <1800000>;
252 vcc1v8_dvp: LDO_REG1 {
253 regulator-name = "vcc1v8_dvp";
254 regulator-min-microvolt = <1800000>;
255 regulator-max-microvolt = <1800000>;
258 regulator-state-mem {
259 regulator-on-in-suspend;
260 regulator-suspend-microvolt = <1800000>;
264 vcca1v8_hdmi: LDO_REG2 {
265 regulator-name = "vcca1v8_hdmi";
266 regulator-min-microvolt = <1800000>;
267 regulator-max-microvolt = <1800000>;
270 regulator-state-mem {
271 regulator-on-in-suspend;
272 regulator-suspend-microvolt = <1800000>;
277 regulator-name = "vcca_1v8";
278 regulator-min-microvolt = <1800000>;
279 regulator-max-microvolt = <1800000>;
282 regulator-state-mem {
283 regulator-on-in-suspend;
284 regulator-suspend-microvolt = <1800000>;
289 regulator-name = "vcc_sd";
290 regulator-min-microvolt = <1800000>;
291 regulator-max-microvolt = <3300000>;
294 regulator-state-mem {
295 regulator-on-in-suspend;
296 regulator-suspend-microvolt = <3300000>;
300 vcc3v0_sd: LDO_REG5 {
301 regulator-name = "vcc3v0_sd";
302 regulator-min-microvolt = <3000000>;
303 regulator-max-microvolt = <3000000>;
306 regulator-state-mem {
307 regulator-on-in-suspend;
308 regulator-suspend-microvolt = <3000000>;
313 regulator-name = "vcc_1v5";
314 regulator-min-microvolt = <1500000>;
315 regulator-max-microvolt = <1500000>;
318 regulator-state-mem {
319 regulator-on-in-suspend;
320 regulator-suspend-microvolt = <1500000>;
324 vcca0v9_hdmi: LDO_REG7 {
325 regulator-name = "vcca0v9_hdmi";
326 regulator-min-microvolt = <900000>;
327 regulator-max-microvolt = <900000>;
330 regulator-state-mem {
331 regulator-on-in-suspend;
332 regulator-suspend-microvolt = <900000>;
337 regulator-name = "vcc_3v0";
338 regulator-min-microvolt = <3000000>;
339 regulator-max-microvolt = <3000000>;
342 regulator-state-mem {
343 regulator-on-in-suspend;
344 regulator-suspend-microvolt = <3000000>;
348 vcc3v3_s3: SWITCH_REG1 {
349 regulator-name = "vcc3v3_s3";
352 regulator-state-mem {
353 regulator-on-in-suspend;
357 vcc3v3_s0: SWITCH_REG2 {
358 regulator-name = "vcc3v3_s0";
361 regulator-state-mem {
362 regulator-on-in-suspend;
386 bt656-supply = <&vcc1v8_s0>; /* bt656_gpio2ab_ms */
387 audio-supply = <&vcc1v8_s0>; /* audio_gpio3d4a_ms */
388 sdmmc-supply = <&vcc_sd>; /* sdmmc_gpio4b_ms */
389 gpio1830-supply = <&vcc_3v0>; /* gpio1833_gpio4cd_ms */
398 ep-gpios = <&gpio4 RK_PD4 GPIO_ACTIVE_HIGH>;
400 pinctrl-names = "default";
401 pinctrl-0 = <&pcie_clkreqn_cpm>;
402 vpcie3v3-supply = <&vcc3v3_pcie>;
407 pmu1830-supply = <&vcc_1v8>;
413 rgmii_sleep_pins: rgmii-sleep-pins {
415 <3 15 RK_FUNC_GPIO &pcfg_output_low>;
420 sdmmc_bus1: sdmmc-bus1 {
422 <4 8 RK_FUNC_1 &pcfg_pull_up_8ma>;
425 sdmmc_bus4: sdmmc-bus4 {
427 <4 8 RK_FUNC_1 &pcfg_pull_up_8ma>,
428 <4 9 RK_FUNC_1 &pcfg_pull_up_8ma>,
429 <4 10 RK_FUNC_1 &pcfg_pull_up_8ma>,
430 <4 11 RK_FUNC_1 &pcfg_pull_up_8ma>;
433 sdmmc_clk: sdmmc-clk {
435 <4 12 RK_FUNC_1 &pcfg_pull_none_18ma>;
438 sdmmc_cmd: sdmmc-cmd {
440 <4 13 RK_FUNC_1 &pcfg_pull_up_8ma>;
447 <1 24 RK_FUNC_GPIO &pcfg_pull_none>;
452 pmic_int_l: pmic-int-l {
454 <1 21 RK_FUNC_GPIO &pcfg_pull_up>;
457 vsel1_gpio: vsel1-gpio {
459 <1 17 RK_FUNC_GPIO &pcfg_pull_down>;
462 vsel2_gpio: vsel2-gpio {
464 <1 14 RK_FUNC_GPIO &pcfg_pull_down>;
469 host_vbus_drv: host-vbus-drv {
471 <4 27 RK_FUNC_GPIO &pcfg_pull_none>;
487 mmc-hs400-enhanced-strobe;
496 clock-frequency = <100000000>;
497 clock-freq-min-max = <100000 100000000>;
500 vqmmc-supply = <&vcc_sd>;
501 card-detect-delay = <800>;
502 pinctrl-names = "default";
503 pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_cd &sdmmc_bus4>;
524 phy-supply = <&vcc5v0_host>;
529 phy-supply = <&vcc5v0_host>;
542 pinctrl-names = "default";
543 pinctrl-0 = <&uart0_xfer &uart0_cts>;