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 3532507b86SJernej Skrabec ext_osc32k: ext_osc32k_clk { 3632507b86SJernej Skrabec #clock-cells = <0>; 3732507b86SJernej Skrabec compatible = "fixed-clock"; 3832507b86SJernej Skrabec clock-frequency = <32768>; 3932507b86SJernej Skrabec clock-output-names = "ext_osc32k"; 4032507b86SJernej Skrabec }; 4132507b86SJernej Skrabec 428fe62f12SOndrej Jirman leds { 438fe62f12SOndrej Jirman compatible = "gpio-leds"; 448fe62f12SOndrej Jirman 458fe62f12SOndrej Jirman power { 468fe62f12SOndrej Jirman label = "orangepi:red:power"; 478fe62f12SOndrej Jirman gpios = <&r_pio 0 4 GPIO_ACTIVE_HIGH>; /* PL4 */ 488fe62f12SOndrej Jirman default-state = "on"; 498fe62f12SOndrej Jirman }; 508fe62f12SOndrej Jirman 518fe62f12SOndrej Jirman status { 528fe62f12SOndrej Jirman label = "orangepi:green:status"; 538fe62f12SOndrej Jirman gpios = <&r_pio 0 7 GPIO_ACTIVE_HIGH>; /* PL7 */ 548fe62f12SOndrej Jirman }; 558fe62f12SOndrej Jirman }; 568fe62f12SOndrej Jirman 578fe62f12SOndrej Jirman reg_vcc5v: vcc5v { 588fe62f12SOndrej Jirman /* board wide 5V supply directly from the DC jack */ 598fe62f12SOndrej Jirman compatible = "regulator-fixed"; 608fe62f12SOndrej Jirman regulator-name = "vcc-5v"; 618fe62f12SOndrej Jirman regulator-min-microvolt = <5000000>; 628fe62f12SOndrej Jirman regulator-max-microvolt = <5000000>; 638fe62f12SOndrej Jirman regulator-always-on; 648fe62f12SOndrej Jirman }; 6515ede970SOndrej Jirman 6615ede970SOndrej Jirman reg_vcc33_wifi: vcc33-wifi { 6715ede970SOndrej Jirman /* Always on 3.3V regulator for WiFi and BT */ 6815ede970SOndrej Jirman compatible = "regulator-fixed"; 6915ede970SOndrej Jirman regulator-name = "vcc33-wifi"; 7015ede970SOndrej Jirman regulator-min-microvolt = <3300000>; 7115ede970SOndrej Jirman regulator-max-microvolt = <3300000>; 7215ede970SOndrej Jirman regulator-always-on; 7315ede970SOndrej Jirman vin-supply = <®_vcc5v>; 7415ede970SOndrej Jirman }; 7515ede970SOndrej Jirman 7615ede970SOndrej Jirman reg_vcc_wifi_io: vcc-wifi-io { 7715ede970SOndrej Jirman /* Always on 1.8V/300mA regulator for WiFi and BT IO */ 7815ede970SOndrej Jirman compatible = "regulator-fixed"; 7915ede970SOndrej Jirman regulator-name = "vcc-wifi-io"; 8015ede970SOndrej Jirman regulator-min-microvolt = <1800000>; 8115ede970SOndrej Jirman regulator-max-microvolt = <1800000>; 8215ede970SOndrej Jirman regulator-always-on; 8315ede970SOndrej Jirman vin-supply = <®_vcc33_wifi>; 8415ede970SOndrej Jirman }; 8515ede970SOndrej Jirman 8615ede970SOndrej Jirman wifi_pwrseq: wifi-pwrseq { 8715ede970SOndrej Jirman compatible = "mmc-pwrseq-simple"; 8815ede970SOndrej Jirman clocks = <&rtc 1>; 8915ede970SOndrej Jirman clock-names = "ext_clock"; 9015ede970SOndrej Jirman reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */ 9115ede970SOndrej Jirman post-power-on-delay-ms = <200>; 9215ede970SOndrej Jirman }; 938fe62f12SOndrej Jirman}; 948fe62f12SOndrej Jirman 958fe62f12SOndrej Jirman&cpu0 { 968fe62f12SOndrej Jirman cpu-supply = <®_dcdca>; 978fe62f12SOndrej Jirman}; 988fe62f12SOndrej Jirman 99802cbe1bSOndrej Jirman&de { 100802cbe1bSOndrej Jirman status = "okay"; 101802cbe1bSOndrej Jirman}; 102802cbe1bSOndrej Jirman 103b5d84ff8SOndrej Jirman&dwc3 { 104b5d84ff8SOndrej Jirman status = "okay"; 105b5d84ff8SOndrej Jirman}; 106b5d84ff8SOndrej Jirman 1078fe62f12SOndrej Jirman&ehci0 { 1088fe62f12SOndrej Jirman status = "okay"; 1098fe62f12SOndrej Jirman}; 1108fe62f12SOndrej Jirman 1118fe62f12SOndrej Jirman&ehci3 { 1128fe62f12SOndrej Jirman status = "okay"; 1138fe62f12SOndrej Jirman}; 1148fe62f12SOndrej Jirman 1158abc4c4aSClément Péron&gpu { 1168abc4c4aSClément Péron mali-supply = <®_dcdcc>; 1178abc4c4aSClément Péron status = "okay"; 1188abc4c4aSClément Péron}; 1198abc4c4aSClément Péron 120802cbe1bSOndrej Jirman&hdmi { 121802cbe1bSOndrej Jirman status = "okay"; 122802cbe1bSOndrej Jirman}; 123802cbe1bSOndrej Jirman 124802cbe1bSOndrej Jirman&hdmi_out { 125802cbe1bSOndrej Jirman hdmi_out_con: endpoint { 126802cbe1bSOndrej Jirman remote-endpoint = <&hdmi_con_in>; 127802cbe1bSOndrej Jirman }; 128802cbe1bSOndrej Jirman}; 129802cbe1bSOndrej Jirman 1308fe62f12SOndrej Jirman&mmc0 { 1318fe62f12SOndrej Jirman vmmc-supply = <®_cldo1>; 1328fe62f12SOndrej Jirman cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */ 1338fe62f12SOndrej Jirman bus-width = <4>; 1348fe62f12SOndrej Jirman status = "okay"; 1358fe62f12SOndrej Jirman}; 1368fe62f12SOndrej Jirman 13715ede970SOndrej Jirman&mmc1 { 13815ede970SOndrej Jirman vmmc-supply = <®_vcc33_wifi>; 13915ede970SOndrej Jirman vqmmc-supply = <®_vcc_wifi_io>; 14015ede970SOndrej Jirman mmc-pwrseq = <&wifi_pwrseq>; 14115ede970SOndrej Jirman bus-width = <4>; 14215ede970SOndrej Jirman non-removable; 14315ede970SOndrej Jirman status = "okay"; 14415ede970SOndrej Jirman 14515ede970SOndrej Jirman brcm: sdio-wifi@1 { 14615ede970SOndrej Jirman reg = <1>; 14715ede970SOndrej Jirman compatible = "brcm,bcm4329-fmac"; 14815ede970SOndrej Jirman interrupt-parent = <&r_pio>; 14915ede970SOndrej Jirman interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */ 15015ede970SOndrej Jirman interrupt-names = "host-wake"; 15115ede970SOndrej Jirman }; 15215ede970SOndrej Jirman}; 15315ede970SOndrej Jirman 154221a6904SJernej Skrabec&mmc2 { 155221a6904SJernej Skrabec vmmc-supply = <®_cldo1>; 156221a6904SJernej Skrabec vqmmc-supply = <®_bldo2>; 157221a6904SJernej Skrabec cap-mmc-hw-reset; 158221a6904SJernej Skrabec non-removable; 159221a6904SJernej Skrabec bus-width = <8>; 160221a6904SJernej Skrabec status = "okay"; 161221a6904SJernej Skrabec}; 162221a6904SJernej Skrabec 1638fe62f12SOndrej Jirman&ohci0 { 1648fe62f12SOndrej Jirman status = "okay"; 1658fe62f12SOndrej Jirman}; 1668fe62f12SOndrej Jirman 1678fe62f12SOndrej Jirman&ohci3 { 1688fe62f12SOndrej Jirman status = "okay"; 1698fe62f12SOndrej Jirman}; 1708fe62f12SOndrej Jirman 1718fe62f12SOndrej Jirman&pio { 1728fe62f12SOndrej Jirman vcc-pc-supply = <®_bldo2>; 1738fe62f12SOndrej Jirman vcc-pd-supply = <®_cldo1>; 17415ede970SOndrej Jirman vcc-pg-supply = <®_vcc_wifi_io>; 1758fe62f12SOndrej Jirman}; 1768fe62f12SOndrej Jirman 1778fe62f12SOndrej Jirman&r_i2c { 1788fe62f12SOndrej Jirman status = "okay"; 1798fe62f12SOndrej Jirman 1808fe62f12SOndrej Jirman axp805: pmic@36 { 1818fe62f12SOndrej Jirman compatible = "x-powers,axp805", "x-powers,axp806"; 1828fe62f12SOndrej Jirman reg = <0x36>; 1838fe62f12SOndrej Jirman interrupt-parent = <&r_intc>; 1848fe62f12SOndrej Jirman interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 1858fe62f12SOndrej Jirman interrupt-controller; 1868fe62f12SOndrej Jirman #interrupt-cells = <1>; 1878fe62f12SOndrej Jirman x-powers,self-working-mode; 1888fe62f12SOndrej Jirman vina-supply = <®_vcc5v>; 1898fe62f12SOndrej Jirman vinb-supply = <®_vcc5v>; 1908fe62f12SOndrej Jirman vinc-supply = <®_vcc5v>; 1918fe62f12SOndrej Jirman vind-supply = <®_vcc5v>; 1928fe62f12SOndrej Jirman vine-supply = <®_vcc5v>; 1938fe62f12SOndrej Jirman aldoin-supply = <®_vcc5v>; 1948fe62f12SOndrej Jirman bldoin-supply = <®_vcc5v>; 1958fe62f12SOndrej Jirman cldoin-supply = <®_vcc5v>; 1968fe62f12SOndrej Jirman 1978fe62f12SOndrej Jirman regulators { 1988fe62f12SOndrej Jirman reg_aldo1: aldo1 { 1998fe62f12SOndrej Jirman regulator-always-on; 2008fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2018fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2028fe62f12SOndrej Jirman regulator-name = "vcc-pl-led-ir"; 2038fe62f12SOndrej Jirman }; 2048fe62f12SOndrej Jirman 2058fe62f12SOndrej Jirman reg_aldo2: aldo2 { 2068fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2078fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2088fe62f12SOndrej Jirman regulator-name = "vcc33-audio-tv-ephy-mac"; 2098fe62f12SOndrej Jirman }; 2108fe62f12SOndrej Jirman 2118fe62f12SOndrej Jirman /* ALDO3 is shorted to CLDO1 */ 2128fe62f12SOndrej Jirman reg_aldo3: aldo3 { 2138fe62f12SOndrej Jirman regulator-always-on; 2148fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2158fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2168fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1"; 2178fe62f12SOndrej Jirman }; 2188fe62f12SOndrej Jirman 2198fe62f12SOndrej Jirman reg_bldo1: bldo1 { 2208fe62f12SOndrej Jirman regulator-always-on; 2218fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2228fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2238fe62f12SOndrej Jirman regulator-name = "vcc18-dram-bias-pll"; 2248fe62f12SOndrej Jirman }; 2258fe62f12SOndrej Jirman 2268fe62f12SOndrej Jirman reg_bldo2: bldo2 { 2278fe62f12SOndrej Jirman regulator-always-on; 2288fe62f12SOndrej Jirman regulator-min-microvolt = <1800000>; 2298fe62f12SOndrej Jirman regulator-max-microvolt = <1800000>; 2308fe62f12SOndrej Jirman regulator-name = "vcc-efuse-pcie-hdmi-pc"; 2318fe62f12SOndrej Jirman }; 2328fe62f12SOndrej Jirman 2338fe62f12SOndrej Jirman bldo3 { 2348fe62f12SOndrej Jirman /* unused */ 2358fe62f12SOndrej Jirman }; 2368fe62f12SOndrej Jirman 2378fe62f12SOndrej Jirman bldo4 { 2388fe62f12SOndrej Jirman /* unused */ 2398fe62f12SOndrej Jirman }; 2408fe62f12SOndrej Jirman 2418fe62f12SOndrej Jirman reg_cldo1: cldo1 { 2428fe62f12SOndrej Jirman regulator-always-on; 2438fe62f12SOndrej Jirman regulator-min-microvolt = <3300000>; 2448fe62f12SOndrej Jirman regulator-max-microvolt = <3300000>; 2458fe62f12SOndrej Jirman regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2"; 2468fe62f12SOndrej Jirman }; 2478fe62f12SOndrej Jirman 2488fe62f12SOndrej Jirman cldo2 { 2498fe62f12SOndrej Jirman /* unused */ 2508fe62f12SOndrej Jirman }; 2518fe62f12SOndrej Jirman 2528fe62f12SOndrej Jirman cldo3 { 2538fe62f12SOndrej Jirman /* unused */ 2548fe62f12SOndrej Jirman }; 2558fe62f12SOndrej Jirman 2568fe62f12SOndrej Jirman reg_dcdca: dcdca { 2578fe62f12SOndrej Jirman regulator-always-on; 2588fe62f12SOndrej Jirman regulator-min-microvolt = <800000>; 2598fe62f12SOndrej Jirman regulator-max-microvolt = <1160000>; 2608fe62f12SOndrej Jirman regulator-name = "vdd-cpu"; 2618fe62f12SOndrej Jirman }; 2628fe62f12SOndrej Jirman 2638fe62f12SOndrej Jirman reg_dcdcc: dcdcc { 2648abc4c4aSClément Péron regulator-enable-ramp-delay = <32000>; 2658fe62f12SOndrej Jirman regulator-min-microvolt = <810000>; 2668fe62f12SOndrej Jirman regulator-max-microvolt = <1080000>; 2678fe62f12SOndrej Jirman regulator-name = "vdd-gpu"; 2688fe62f12SOndrej Jirman }; 2698fe62f12SOndrej Jirman 2708fe62f12SOndrej Jirman reg_dcdcd: dcdcd { 2718fe62f12SOndrej Jirman regulator-always-on; 2728fe62f12SOndrej Jirman regulator-min-microvolt = <960000>; 2738fe62f12SOndrej Jirman regulator-max-microvolt = <960000>; 2748fe62f12SOndrej Jirman regulator-name = "vdd-sys"; 2758fe62f12SOndrej Jirman }; 2768fe62f12SOndrej Jirman 2778fe62f12SOndrej Jirman reg_dcdce: dcdce { 2788fe62f12SOndrej Jirman regulator-always-on; 2798fe62f12SOndrej Jirman regulator-min-microvolt = <1200000>; 2808fe62f12SOndrej Jirman regulator-max-microvolt = <1200000>; 2818fe62f12SOndrej Jirman regulator-name = "vcc-dram"; 2828fe62f12SOndrej Jirman }; 2838fe62f12SOndrej Jirman 2848fe62f12SOndrej Jirman sw { 2858fe62f12SOndrej Jirman /* unused */ 2868fe62f12SOndrej Jirman }; 2878fe62f12SOndrej Jirman }; 2888fe62f12SOndrej Jirman }; 2898fe62f12SOndrej Jirman}; 2908fe62f12SOndrej Jirman 2912c63afdaSAndre Heider&r_ir { 2922c63afdaSAndre Heider status = "okay"; 2932c63afdaSAndre Heider}; 2942c63afdaSAndre Heider 29532507b86SJernej Skrabec&rtc { 29632507b86SJernej Skrabec clocks = <&ext_osc32k>; 29732507b86SJernej Skrabec}; 29832507b86SJernej Skrabec 2998fe62f12SOndrej Jirman&uart0 { 3008fe62f12SOndrej Jirman pinctrl-names = "default"; 3018fe62f12SOndrej Jirman pinctrl-0 = <&uart0_ph_pins>; 3028fe62f12SOndrej Jirman status = "okay"; 3038fe62f12SOndrej Jirman}; 3048fe62f12SOndrej Jirman 30535117046SOndrej Jirman/* There's the BT part of the AP6256 connected to that UART */ 30635117046SOndrej Jirman&uart1 { 30735117046SOndrej Jirman pinctrl-names = "default"; 30835117046SOndrej Jirman pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>; 30935117046SOndrej Jirman uart-has-rtscts; 31035117046SOndrej Jirman status = "okay"; 31135117046SOndrej Jirman 31235117046SOndrej Jirman bluetooth { 31335117046SOndrej Jirman compatible = "brcm,bcm4345c5"; 31435117046SOndrej Jirman clocks = <&rtc 1>; 31535117046SOndrej Jirman clock-names = "lpo"; 31635117046SOndrej Jirman device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */ 31735117046SOndrej Jirman host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */ 31835117046SOndrej Jirman shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */ 31935117046SOndrej Jirman max-speed = <1500000>; 32035117046SOndrej Jirman }; 32135117046SOndrej Jirman}; 32235117046SOndrej Jirman 3238fe62f12SOndrej Jirman&usb2otg { 3248fe62f12SOndrej Jirman /* 3258fe62f12SOndrej Jirman * This board doesn't have a controllable VBUS even though it 3268fe62f12SOndrej Jirman * does have an ID pin. Using it as anything but a USB host is 3278fe62f12SOndrej Jirman * unsafe. 3288fe62f12SOndrej Jirman */ 3298fe62f12SOndrej Jirman dr_mode = "host"; 3308fe62f12SOndrej Jirman status = "okay"; 3318fe62f12SOndrej Jirman}; 3328fe62f12SOndrej Jirman 3338fe62f12SOndrej Jirman&usb2phy { 3348fe62f12SOndrej Jirman usb0_id_det-gpios = <&pio 2 15 GPIO_ACTIVE_HIGH>; /* PC15 */ 3358fe62f12SOndrej Jirman usb0_vbus-supply = <®_vcc5v>; 3368fe62f12SOndrej Jirman usb3_vbus-supply = <®_vcc5v>; 3378fe62f12SOndrej Jirman status = "okay"; 3388fe62f12SOndrej Jirman}; 339b5d84ff8SOndrej Jirman 340b5d84ff8SOndrej Jirman&usb3phy { 341b5d84ff8SOndrej Jirman status = "okay"; 342b5d84ff8SOndrej Jirman}; 343