1012af553SClément Péron// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2cabbaed7SClément Péron// Copyright (C) 2019 Ondřej Jirman <megous@megous.com> 38fe62f12SOndrej Jirman 48fe62f12SOndrej Jirman/dts-v1/; 58fe62f12SOndrej Jirman 68fe62f12SOndrej Jirman#include "sun50i-h6.dtsi" 78fe62f12SOndrej Jirman 88fe62f12SOndrej Jirman#include <dt-bindings/gpio/gpio.h> 98fe62f12SOndrej Jirman 108fe62f12SOndrej Jirman/ { 118fe62f12SOndrej Jirman model = "OrangePi 3"; 128fe62f12SOndrej Jirman compatible = "xunlong,orangepi-3", "allwinner,sun50i-h6"; 138fe62f12SOndrej Jirman 148fe62f12SOndrej Jirman aliases { 158fe62f12SOndrej Jirman serial0 = &uart0; 1635117046SOndrej Jirman serial1 = &uart1; 178fe62f12SOndrej Jirman }; 188fe62f12SOndrej Jirman 198fe62f12SOndrej Jirman chosen { 208fe62f12SOndrej Jirman stdout-path = "serial0:115200n8"; 218fe62f12SOndrej Jirman }; 228fe62f12SOndrej Jirman 23802cbe1bSOndrej Jirman connector { 24802cbe1bSOndrej Jirman compatible = "hdmi-connector"; 25802cbe1bSOndrej Jirman ddc-en-gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>; /* PH2 */ 26802cbe1bSOndrej Jirman type = "a"; 27802cbe1bSOndrej Jirman 28802cbe1bSOndrej Jirman port { 29802cbe1bSOndrej Jirman hdmi_con_in: endpoint { 30802cbe1bSOndrej Jirman remote-endpoint = <&hdmi_out_con>; 31802cbe1bSOndrej Jirman }; 32802cbe1bSOndrej Jirman }; 33802cbe1bSOndrej Jirman }; 34802cbe1bSOndrej Jirman 358fe62f12SOndrej Jirman leds { 368fe62f12SOndrej Jirman compatible = "gpio-leds"; 378fe62f12SOndrej Jirman 388fe62f12SOndrej Jirman power { 398fe62f12SOndrej Jirman label = "orangepi:red:power"; 408fe62f12SOndrej Jirman gpios = <&r_pio 0 4 GPIO_ACTIVE_HIGH>; /* PL4 */ 418fe62f12SOndrej Jirman default-state = "on"; 428fe62f12SOndrej Jirman }; 438fe62f12SOndrej Jirman 448fe62f12SOndrej Jirman status { 458fe62f12SOndrej Jirman label = "orangepi:green:status"; 468fe62f12SOndrej Jirman gpios = <&r_pio 0 7 GPIO_ACTIVE_HIGH>; /* PL7 */ 478fe62f12SOndrej Jirman }; 488fe62f12SOndrej Jirman }; 498fe62f12SOndrej Jirman 508fe62f12SOndrej Jirman reg_vcc5v: vcc5v { 518fe62f12SOndrej Jirman /* board wide 5V supply directly from the DC jack */ 528fe62f12SOndrej Jirman compatible = "regulator-fixed"; 538fe62f12SOndrej Jirman regulator-name = "vcc-5v"; 548fe62f12SOndrej Jirman regulator-min-microvolt = <5000000>; 558fe62f12SOndrej Jirman regulator-max-microvolt = <5000000>; 568fe62f12SOndrej Jirman regulator-always-on; 578fe62f12SOndrej Jirman }; 5815ede970SOndrej Jirman 5915ede970SOndrej Jirman reg_vcc33_wifi: vcc33-wifi { 6015ede970SOndrej Jirman /* Always on 3.3V regulator for WiFi and BT */ 6115ede970SOndrej Jirman compatible = "regulator-fixed"; 6215ede970SOndrej Jirman regulator-name = "vcc33-wifi"; 6315ede970SOndrej Jirman regulator-min-microvolt = <3300000>; 6415ede970SOndrej Jirman regulator-max-microvolt = <3300000>; 6515ede970SOndrej Jirman regulator-always-on; 6615ede970SOndrej Jirman vin-supply = <®_vcc5v>; 6715ede970SOndrej Jirman }; 6815ede970SOndrej Jirman 6915ede970SOndrej Jirman reg_vcc_wifi_io: vcc-wifi-io { 7015ede970SOndrej Jirman /* Always on 1.8V/300mA regulator for WiFi and BT IO */ 7115ede970SOndrej Jirman compatible = "regulator-fixed"; 7215ede970SOndrej Jirman regulator-name = "vcc-wifi-io"; 7315ede970SOndrej Jirman regulator-min-microvolt = <1800000>; 7415ede970SOndrej Jirman regulator-max-microvolt = <1800000>; 7515ede970SOndrej Jirman regulator-always-on; 7615ede970SOndrej Jirman vin-supply = <®_vcc33_wifi>; 7715ede970SOndrej Jirman }; 7815ede970SOndrej Jirman 7915ede970SOndrej Jirman wifi_pwrseq: wifi-pwrseq { 8015ede970SOndrej Jirman compatible = "mmc-pwrseq-simple"; 8115ede970SOndrej Jirman clocks = <&rtc 1>; 8215ede970SOndrej Jirman clock-names = "ext_clock"; 8315ede970SOndrej Jirman reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */ 8415ede970SOndrej Jirman post-power-on-delay-ms = <200>; 8515ede970SOndrej Jirman }; 868fe62f12SOndrej Jirman}; 878fe62f12SOndrej Jirman 888fe62f12SOndrej Jirman&cpu0 { 898fe62f12SOndrej Jirman cpu-supply = <®_dcdca>; 908fe62f12SOndrej Jirman}; 918fe62f12SOndrej Jirman 92802cbe1bSOndrej Jirman&de { 93802cbe1bSOndrej Jirman status = "okay"; 94802cbe1bSOndrej Jirman}; 95802cbe1bSOndrej Jirman 96b5d84ff8SOndrej Jirman&dwc3 { 97b5d84ff8SOndrej Jirman status = "okay"; 98b5d84ff8SOndrej Jirman}; 99b5d84ff8SOndrej Jirman 1008fe62f12SOndrej Jirman&ehci0 { 1018fe62f12SOndrej Jirman status = "okay"; 1028fe62f12SOndrej Jirman}; 1038fe62f12SOndrej Jirman 1048fe62f12SOndrej Jirman&ehci3 { 1058fe62f12SOndrej Jirman status = "okay"; 1068fe62f12SOndrej Jirman}; 1078fe62f12SOndrej Jirman 1088abc4c4aSClément Péron&gpu { 1098abc4c4aSClément Péron mali-supply = <®_dcdcc>; 1108abc4c4aSClément Péron status = "okay"; 1118abc4c4aSClément Péron}; 1128abc4c4aSClément Péron 113802cbe1bSOndrej Jirman&hdmi { 114802cbe1bSOndrej Jirman status = "okay"; 115802cbe1bSOndrej Jirman}; 116802cbe1bSOndrej Jirman 117802cbe1bSOndrej Jirman&hdmi_out { 118802cbe1bSOndrej Jirman hdmi_out_con: endpoint { 119802cbe1bSOndrej Jirman remote-endpoint = <&hdmi_con_in>; 120802cbe1bSOndrej Jirman }; 121802cbe1bSOndrej Jirman}; 122802cbe1bSOndrej Jirman 1238fe62f12SOndrej Jirman&mmc0 { 1248fe62f12SOndrej Jirman vmmc-supply = <®_cldo1>; 1258fe62f12SOndrej Jirman cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */ 1268fe62f12SOndrej Jirman bus-width = <4>; 1278fe62f12SOndrej Jirman status = "okay"; 1288fe62f12SOndrej Jirman}; 1298fe62f12SOndrej Jirman 13015ede970SOndrej Jirman&mmc1 { 13115ede970SOndrej Jirman vmmc-supply = <®_vcc33_wifi>; 13215ede970SOndrej Jirman vqmmc-supply = <®_vcc_wifi_io>; 13315ede970SOndrej Jirman mmc-pwrseq = <&wifi_pwrseq>; 13415ede970SOndrej Jirman bus-width = <4>; 13515ede970SOndrej Jirman non-removable; 13615ede970SOndrej Jirman status = "okay"; 13715ede970SOndrej Jirman 13815ede970SOndrej Jirman brcm: sdio-wifi@1 { 13915ede970SOndrej Jirman reg = <1>; 14015ede970SOndrej Jirman compatible = "brcm,bcm4329-fmac"; 14115ede970SOndrej Jirman interrupt-parent = <&r_pio>; 14215ede970SOndrej Jirman interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */ 14315ede970SOndrej Jirman interrupt-names = "host-wake"; 14415ede970SOndrej Jirman }; 14515ede970SOndrej Jirman}; 14615ede970SOndrej Jirman 147221a6904SJernej Skrabec&mmc2 { 148221a6904SJernej Skrabec vmmc-supply = <®_cldo1>; 149221a6904SJernej Skrabec vqmmc-supply = <®_bldo2>; 150221a6904SJernej Skrabec cap-mmc-hw-reset; 151221a6904SJernej Skrabec non-removable; 152221a6904SJernej Skrabec bus-width = <8>; 153221a6904SJernej Skrabec status = "okay"; 154221a6904SJernej Skrabec}; 155221a6904SJernej Skrabec 1568fe62f12SOndrej Jirman&ohci0 { 1578fe62f12SOndrej Jirman status = "okay"; 1588fe62f12SOndrej Jirman}; 1598fe62f12SOndrej Jirman 1608fe62f12SOndrej Jirman&ohci3 { 1618fe62f12SOndrej Jirman status = "okay"; 1628fe62f12SOndrej Jirman}; 1638fe62f12SOndrej Jirman 1648fe62f12SOndrej Jirman&pio { 1658fe62f12SOndrej Jirman vcc-pc-supply = <®_bldo2>; 1668fe62f12SOndrej Jirman vcc-pd-supply = <®_cldo1>; 16715ede970SOndrej Jirman vcc-pg-supply = <®_vcc_wifi_io>; 1688fe62f12SOndrej Jirman}; 1698fe62f12SOndrej Jirman 1708fe62f12SOndrej Jirman&r_i2c { 1718fe62f12SOndrej Jirman status = "okay"; 1728fe62f12SOndrej Jirman 1738fe62f12SOndrej Jirman axp805: pmic@36 { 1748fe62f12SOndrej Jirman compatible = "x-powers,axp805", "x-powers,axp806"; 1758fe62f12SOndrej Jirman reg = <0x36>; 1768fe62f12SOndrej Jirman interrupt-parent = <&r_intc>; 1778fe62f12SOndrej Jirman interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 1788fe62f12SOndrej Jirman interrupt-controller; 1798fe62f12SOndrej Jirman #interrupt-cells = <1>; 1808fe62f12SOndrej Jirman x-powers,self-working-mode; 1818fe62f12SOndrej Jirman vina-supply = <®_vcc5v>; 1828fe62f12SOndrej Jirman vinb-supply = <®_vcc5v>; 1838fe62f12SOndrej Jirman vinc-supply = <®_vcc5v>; 1848fe62f12SOndrej Jirman vind-supply = <®_vcc5v>; 1858fe62f12SOndrej Jirman vine-supply = <®_vcc5v>; 1868fe62f12SOndrej Jirman aldoin-supply = <®_vcc5v>; 1878fe62f12SOndrej Jirman bldoin-supply = <®_vcc5v>; 1888fe62f12SOndrej Jirman cldoin-supply = <®_vcc5v>; 1898fe62f12SOndrej Jirman 1908fe62f12SOndrej Jirman regulators { 1918fe62f12SOndrej Jirman reg_aldo1: aldo1 { 1928fe62f12SOndrej Jirman regulator-always-on; 1938fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 1948fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 1958fe62f12SOndrej Jirman regulator-name = "vcc-pl-led-ir"; 1968fe62f12SOndrej Jirman }; 1978fe62f12SOndrej Jirman 1988fe62f12SOndrej Jirman reg_aldo2: aldo2 { 1998fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2008fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2018fe62f12SOndrej Jirman regulator-name = "vcc33-audio-tv-ephy-mac"; 2028fe62f12SOndrej Jirman }; 2038fe62f12SOndrej Jirman 2048fe62f12SOndrej Jirman /* ALDO3 is shorted to CLDO1 */ 2058fe62f12SOndrej Jirman reg_aldo3: aldo3 { 2068fe62f12SOndrej Jirman regulator-always-on; 2078fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2088fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2098fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1"; 2108fe62f12SOndrej Jirman }; 2118fe62f12SOndrej Jirman 2128fe62f12SOndrej Jirman reg_bldo1: bldo1 { 2138fe62f12SOndrej Jirman regulator-always-on; 2148fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2158fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2168fe62f12SOndrej Jirman regulator-name = "vcc18-dram-bias-pll"; 2178fe62f12SOndrej Jirman }; 2188fe62f12SOndrej Jirman 2198fe62f12SOndrej Jirman reg_bldo2: bldo2 { 2208fe62f12SOndrej Jirman regulator-always-on; 2218fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2228fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2238fe62f12SOndrej Jirman regulator-name = "vcc-efuse-pcie-hdmi-pc"; 2248fe62f12SOndrej Jirman }; 2258fe62f12SOndrej Jirman 2268fe62f12SOndrej Jirman bldo3 { 2278fe62f12SOndrej Jirman /* unused */ 2288fe62f12SOndrej Jirman }; 2298fe62f12SOndrej Jirman 2308fe62f12SOndrej Jirman bldo4 { 2318fe62f12SOndrej Jirman /* unused */ 2328fe62f12SOndrej Jirman }; 2338fe62f12SOndrej Jirman 2348fe62f12SOndrej Jirman reg_cldo1: cldo1 { 2358fe62f12SOndrej Jirman regulator-always-on; 2368fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2378fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2388fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2"; 2398fe62f12SOndrej Jirman }; 2408fe62f12SOndrej Jirman 2418fe62f12SOndrej Jirman cldo2 { 2428fe62f12SOndrej Jirman /* unused */ 2438fe62f12SOndrej Jirman }; 2448fe62f12SOndrej Jirman 2458fe62f12SOndrej Jirman cldo3 { 2468fe62f12SOndrej Jirman /* unused */ 2478fe62f12SOndrej Jirman }; 2488fe62f12SOndrej Jirman 2498fe62f12SOndrej Jirman reg_dcdca: dcdca { 2508fe62f12SOndrej Jirman regulator-always-on; 2518fe62f12SOndrej Jirman regulator-min-microvolt = <800000>; 2528fe62f12SOndrej Jirman regulator-max-microvolt = <1160000>; 2538fe62f12SOndrej Jirman regulator-name = "vdd-cpu"; 2548fe62f12SOndrej Jirman }; 2558fe62f12SOndrej Jirman 2568fe62f12SOndrej Jirman reg_dcdcc: dcdcc { 2578abc4c4aSClément Péron regulator-enable-ramp-delay = <32000>; 2588fe62f12SOndrej Jirman regulator-min-microvolt = <810000>; 2598fe62f12SOndrej Jirman regulator-max-microvolt = <1080000>; 2608fe62f12SOndrej Jirman regulator-name = "vdd-gpu"; 2618fe62f12SOndrej Jirman }; 2628fe62f12SOndrej Jirman 2638fe62f12SOndrej Jirman reg_dcdcd: dcdcd { 2648fe62f12SOndrej Jirman regulator-always-on; 2658fe62f12SOndrej Jirman regulator-min-microvolt = <960000>; 2668fe62f12SOndrej Jirman regulator-max-microvolt = <960000>; 2678fe62f12SOndrej Jirman regulator-name = "vdd-sys"; 2688fe62f12SOndrej Jirman }; 2698fe62f12SOndrej Jirman 2708fe62f12SOndrej Jirman reg_dcdce: dcdce { 2718fe62f12SOndrej Jirman regulator-always-on; 2728fe62f12SOndrej Jirman regulator-min-microvolt = <1200000>; 2738fe62f12SOndrej Jirman regulator-max-microvolt = <1200000>; 2748fe62f12SOndrej Jirman regulator-name = "vcc-dram"; 2758fe62f12SOndrej Jirman }; 2768fe62f12SOndrej Jirman 2778fe62f12SOndrej Jirman sw { 2788fe62f12SOndrej Jirman /* unused */ 2798fe62f12SOndrej Jirman }; 2808fe62f12SOndrej Jirman }; 2818fe62f12SOndrej Jirman }; 2828fe62f12SOndrej Jirman}; 2838fe62f12SOndrej Jirman 2842c63afdaSAndre Heider&r_ir { 2852c63afdaSAndre Heider status = "okay"; 2862c63afdaSAndre Heider}; 2872c63afdaSAndre Heider 2888fe62f12SOndrej Jirman&uart0 { 2898fe62f12SOndrej Jirman pinctrl-names = "default"; 2908fe62f12SOndrej Jirman pinctrl-0 = <&uart0_ph_pins>; 2918fe62f12SOndrej Jirman status = "okay"; 2928fe62f12SOndrej Jirman}; 2938fe62f12SOndrej Jirman 29435117046SOndrej Jirman/* There's the BT part of the AP6256 connected to that UART */ 29535117046SOndrej Jirman&uart1 { 29635117046SOndrej Jirman pinctrl-names = "default"; 29735117046SOndrej Jirman pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>; 29835117046SOndrej Jirman uart-has-rtscts; 29935117046SOndrej Jirman status = "okay"; 30035117046SOndrej Jirman 30135117046SOndrej Jirman bluetooth { 30235117046SOndrej Jirman compatible = "brcm,bcm4345c5"; 30335117046SOndrej Jirman clocks = <&rtc 1>; 30435117046SOndrej Jirman clock-names = "lpo"; 30535117046SOndrej Jirman device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */ 30635117046SOndrej Jirman host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */ 30735117046SOndrej Jirman shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */ 30835117046SOndrej Jirman max-speed = <1500000>; 30935117046SOndrej Jirman }; 31035117046SOndrej Jirman}; 31135117046SOndrej Jirman 3128fe62f12SOndrej Jirman&usb2otg { 3138fe62f12SOndrej Jirman /* 3148fe62f12SOndrej Jirman * This board doesn't have a controllable VBUS even though it 3158fe62f12SOndrej Jirman * does have an ID pin. Using it as anything but a USB host is 3168fe62f12SOndrej Jirman * unsafe. 3178fe62f12SOndrej Jirman */ 3188fe62f12SOndrej Jirman dr_mode = "host"; 3198fe62f12SOndrej Jirman status = "okay"; 3208fe62f12SOndrej Jirman}; 3218fe62f12SOndrej Jirman 3228fe62f12SOndrej Jirman&usb2phy { 3238fe62f12SOndrej Jirman usb0_id_det-gpios = <&pio 2 15 GPIO_ACTIVE_HIGH>; /* PC15 */ 3248fe62f12SOndrej Jirman usb0_vbus-supply = <®_vcc5v>; 3258fe62f12SOndrej Jirman usb3_vbus-supply = <®_vcc5v>; 3268fe62f12SOndrej Jirman status = "okay"; 3278fe62f12SOndrej Jirman}; 328b5d84ff8SOndrej Jirman 329b5d84ff8SOndrej Jirman&usb3phy { 330b5d84ff8SOndrej Jirman status = "okay"; 331b5d84ff8SOndrej Jirman}; 332