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 1478fe62f12SOndrej Jirman&ohci0 { 1488fe62f12SOndrej Jirman status = "okay"; 1498fe62f12SOndrej Jirman}; 1508fe62f12SOndrej Jirman 1518fe62f12SOndrej Jirman&ohci3 { 1528fe62f12SOndrej Jirman status = "okay"; 1538fe62f12SOndrej Jirman}; 1548fe62f12SOndrej Jirman 1558fe62f12SOndrej Jirman&pio { 1568fe62f12SOndrej Jirman vcc-pc-supply = <®_bldo2>; 1578fe62f12SOndrej Jirman vcc-pd-supply = <®_cldo1>; 15815ede970SOndrej Jirman vcc-pg-supply = <®_vcc_wifi_io>; 1598fe62f12SOndrej Jirman}; 1608fe62f12SOndrej Jirman 1618fe62f12SOndrej Jirman&r_i2c { 1628fe62f12SOndrej Jirman status = "okay"; 1638fe62f12SOndrej Jirman 1648fe62f12SOndrej Jirman axp805: pmic@36 { 1658fe62f12SOndrej Jirman compatible = "x-powers,axp805", "x-powers,axp806"; 1668fe62f12SOndrej Jirman reg = <0x36>; 1678fe62f12SOndrej Jirman interrupt-parent = <&r_intc>; 1688fe62f12SOndrej Jirman interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 1698fe62f12SOndrej Jirman interrupt-controller; 1708fe62f12SOndrej Jirman #interrupt-cells = <1>; 1718fe62f12SOndrej Jirman x-powers,self-working-mode; 1728fe62f12SOndrej Jirman vina-supply = <®_vcc5v>; 1738fe62f12SOndrej Jirman vinb-supply = <®_vcc5v>; 1748fe62f12SOndrej Jirman vinc-supply = <®_vcc5v>; 1758fe62f12SOndrej Jirman vind-supply = <®_vcc5v>; 1768fe62f12SOndrej Jirman vine-supply = <®_vcc5v>; 1778fe62f12SOndrej Jirman aldoin-supply = <®_vcc5v>; 1788fe62f12SOndrej Jirman bldoin-supply = <®_vcc5v>; 1798fe62f12SOndrej Jirman cldoin-supply = <®_vcc5v>; 1808fe62f12SOndrej Jirman 1818fe62f12SOndrej Jirman regulators { 1828fe62f12SOndrej Jirman reg_aldo1: aldo1 { 1838fe62f12SOndrej Jirman regulator-always-on; 1848fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 1858fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 1868fe62f12SOndrej Jirman regulator-name = "vcc-pl-led-ir"; 1878fe62f12SOndrej Jirman }; 1888fe62f12SOndrej Jirman 1898fe62f12SOndrej Jirman reg_aldo2: aldo2 { 1908fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 1918fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 1928fe62f12SOndrej Jirman regulator-name = "vcc33-audio-tv-ephy-mac"; 1938fe62f12SOndrej Jirman }; 1948fe62f12SOndrej Jirman 1958fe62f12SOndrej Jirman /* ALDO3 is shorted to CLDO1 */ 1968fe62f12SOndrej Jirman reg_aldo3: aldo3 { 1978fe62f12SOndrej Jirman regulator-always-on; 1988fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 1998fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2008fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1"; 2018fe62f12SOndrej Jirman }; 2028fe62f12SOndrej Jirman 2038fe62f12SOndrej Jirman reg_bldo1: bldo1 { 2048fe62f12SOndrej Jirman regulator-always-on; 2058fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2068fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2078fe62f12SOndrej Jirman regulator-name = "vcc18-dram-bias-pll"; 2088fe62f12SOndrej Jirman }; 2098fe62f12SOndrej Jirman 2108fe62f12SOndrej Jirman reg_bldo2: bldo2 { 2118fe62f12SOndrej Jirman regulator-always-on; 2128fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2138fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2148fe62f12SOndrej Jirman regulator-name = "vcc-efuse-pcie-hdmi-pc"; 2158fe62f12SOndrej Jirman }; 2168fe62f12SOndrej Jirman 2178fe62f12SOndrej Jirman bldo3 { 2188fe62f12SOndrej Jirman /* unused */ 2198fe62f12SOndrej Jirman }; 2208fe62f12SOndrej Jirman 2218fe62f12SOndrej Jirman bldo4 { 2228fe62f12SOndrej Jirman /* unused */ 2238fe62f12SOndrej Jirman }; 2248fe62f12SOndrej Jirman 2258fe62f12SOndrej Jirman reg_cldo1: cldo1 { 2268fe62f12SOndrej Jirman regulator-always-on; 2278fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2288fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2298fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2"; 2308fe62f12SOndrej Jirman }; 2318fe62f12SOndrej Jirman 2328fe62f12SOndrej Jirman cldo2 { 2338fe62f12SOndrej Jirman /* unused */ 2348fe62f12SOndrej Jirman }; 2358fe62f12SOndrej Jirman 2368fe62f12SOndrej Jirman cldo3 { 2378fe62f12SOndrej Jirman /* unused */ 2388fe62f12SOndrej Jirman }; 2398fe62f12SOndrej Jirman 2408fe62f12SOndrej Jirman reg_dcdca: dcdca { 2418fe62f12SOndrej Jirman regulator-always-on; 2428fe62f12SOndrej Jirman regulator-min-microvolt = <800000>; 2438fe62f12SOndrej Jirman regulator-max-microvolt = <1160000>; 2448fe62f12SOndrej Jirman regulator-name = "vdd-cpu"; 2458fe62f12SOndrej Jirman }; 2468fe62f12SOndrej Jirman 2478fe62f12SOndrej Jirman reg_dcdcc: dcdcc { 2488abc4c4aSClément Péron regulator-enable-ramp-delay = <32000>; 2498fe62f12SOndrej Jirman regulator-min-microvolt = <810000>; 2508fe62f12SOndrej Jirman regulator-max-microvolt = <1080000>; 2518fe62f12SOndrej Jirman regulator-name = "vdd-gpu"; 2528fe62f12SOndrej Jirman }; 2538fe62f12SOndrej Jirman 2548fe62f12SOndrej Jirman reg_dcdcd: dcdcd { 2558fe62f12SOndrej Jirman regulator-always-on; 2568fe62f12SOndrej Jirman regulator-min-microvolt = <960000>; 2578fe62f12SOndrej Jirman regulator-max-microvolt = <960000>; 2588fe62f12SOndrej Jirman regulator-name = "vdd-sys"; 2598fe62f12SOndrej Jirman }; 2608fe62f12SOndrej Jirman 2618fe62f12SOndrej Jirman reg_dcdce: dcdce { 2628fe62f12SOndrej Jirman regulator-always-on; 2638fe62f12SOndrej Jirman regulator-min-microvolt = <1200000>; 2648fe62f12SOndrej Jirman regulator-max-microvolt = <1200000>; 2658fe62f12SOndrej Jirman regulator-name = "vcc-dram"; 2668fe62f12SOndrej Jirman }; 2678fe62f12SOndrej Jirman 2688fe62f12SOndrej Jirman sw { 2698fe62f12SOndrej Jirman /* unused */ 2708fe62f12SOndrej Jirman }; 2718fe62f12SOndrej Jirman }; 2728fe62f12SOndrej Jirman }; 2738fe62f12SOndrej Jirman}; 2748fe62f12SOndrej Jirman 2752c63afdaSAndre Heider&r_ir { 2762c63afdaSAndre Heider status = "okay"; 2772c63afdaSAndre Heider}; 2782c63afdaSAndre Heider 2798fe62f12SOndrej Jirman&uart0 { 2808fe62f12SOndrej Jirman pinctrl-names = "default"; 2818fe62f12SOndrej Jirman pinctrl-0 = <&uart0_ph_pins>; 2828fe62f12SOndrej Jirman status = "okay"; 2838fe62f12SOndrej Jirman}; 2848fe62f12SOndrej Jirman 28535117046SOndrej Jirman/* There's the BT part of the AP6256 connected to that UART */ 28635117046SOndrej Jirman&uart1 { 28735117046SOndrej Jirman pinctrl-names = "default"; 28835117046SOndrej Jirman pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>; 28935117046SOndrej Jirman uart-has-rtscts; 29035117046SOndrej Jirman status = "okay"; 29135117046SOndrej Jirman 29235117046SOndrej Jirman bluetooth { 29335117046SOndrej Jirman compatible = "brcm,bcm4345c5"; 29435117046SOndrej Jirman clocks = <&rtc 1>; 29535117046SOndrej Jirman clock-names = "lpo"; 29635117046SOndrej Jirman device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */ 29735117046SOndrej Jirman host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */ 29835117046SOndrej Jirman shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */ 29935117046SOndrej Jirman max-speed = <1500000>; 30035117046SOndrej Jirman }; 30135117046SOndrej Jirman}; 30235117046SOndrej Jirman 3038fe62f12SOndrej Jirman&usb2otg { 3048fe62f12SOndrej Jirman /* 3058fe62f12SOndrej Jirman * This board doesn't have a controllable VBUS even though it 3068fe62f12SOndrej Jirman * does have an ID pin. Using it as anything but a USB host is 3078fe62f12SOndrej Jirman * unsafe. 3088fe62f12SOndrej Jirman */ 3098fe62f12SOndrej Jirman dr_mode = "host"; 3108fe62f12SOndrej Jirman status = "okay"; 3118fe62f12SOndrej Jirman}; 3128fe62f12SOndrej Jirman 3138fe62f12SOndrej Jirman&usb2phy { 3148fe62f12SOndrej Jirman usb0_id_det-gpios = <&pio 2 15 GPIO_ACTIVE_HIGH>; /* PC15 */ 3158fe62f12SOndrej Jirman usb0_vbus-supply = <®_vcc5v>; 3168fe62f12SOndrej Jirman usb3_vbus-supply = <®_vcc5v>; 3178fe62f12SOndrej Jirman status = "okay"; 3188fe62f12SOndrej Jirman}; 319b5d84ff8SOndrej Jirman 320b5d84ff8SOndrej Jirman&usb3phy { 321b5d84ff8SOndrej Jirman status = "okay"; 322b5d84ff8SOndrej Jirman}; 323