162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/dts-v1/; 362306a36Sopenharmony_ci#include "bcm2711.dtsi" 462306a36Sopenharmony_ci#include "bcm2711-rpi.dtsi" 562306a36Sopenharmony_ci#include "bcm283x-rpi-wifi-bt.dtsi" 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci/ { 862306a36Sopenharmony_ci compatible = "raspberrypi,4-compute-module", "brcm,bcm2711"; 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci chosen { 1162306a36Sopenharmony_ci /* 8250 auxiliary UART instead of pl011 */ 1262306a36Sopenharmony_ci stdout-path = "serial1:115200n8"; 1362306a36Sopenharmony_ci }; 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci sd_io_1v8_reg: regulator-sd-io-1v8 { 1662306a36Sopenharmony_ci compatible = "regulator-gpio"; 1762306a36Sopenharmony_ci regulator-name = "vdd-sd-io"; 1862306a36Sopenharmony_ci regulator-min-microvolt = <1800000>; 1962306a36Sopenharmony_ci regulator-max-microvolt = <3300000>; 2062306a36Sopenharmony_ci regulator-boot-on; 2162306a36Sopenharmony_ci regulator-always-on; 2262306a36Sopenharmony_ci regulator-settling-time-us = <5000>; 2362306a36Sopenharmony_ci gpios = <&expgpio 4 GPIO_ACTIVE_HIGH>; 2462306a36Sopenharmony_ci states = <1800000 0x1>, 2562306a36Sopenharmony_ci <3300000 0x0>; 2662306a36Sopenharmony_ci status = "okay"; 2762306a36Sopenharmony_ci }; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci sd_vcc_reg: regulator-sd-vcc { 3062306a36Sopenharmony_ci compatible = "regulator-fixed"; 3162306a36Sopenharmony_ci regulator-name = "vcc-sd"; 3262306a36Sopenharmony_ci regulator-min-microvolt = <3300000>; 3362306a36Sopenharmony_ci regulator-max-microvolt = <3300000>; 3462306a36Sopenharmony_ci regulator-boot-on; 3562306a36Sopenharmony_ci enable-active-high; 3662306a36Sopenharmony_ci gpio = <&expgpio 6 GPIO_ACTIVE_HIGH>; 3762306a36Sopenharmony_ci }; 3862306a36Sopenharmony_ci}; 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci&bt { 4162306a36Sopenharmony_ci shutdown-gpios = <&expgpio 0 GPIO_ACTIVE_HIGH>; 4262306a36Sopenharmony_ci}; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci/* EMMC2 is used to drive the eMMC */ 4562306a36Sopenharmony_ci&emmc2 { 4662306a36Sopenharmony_ci bus-width = <8>; 4762306a36Sopenharmony_ci vqmmc-supply = <&sd_io_1v8_reg>; 4862306a36Sopenharmony_ci vmmc-supply = <&sd_vcc_reg>; 4962306a36Sopenharmony_ci broken-cd; 5062306a36Sopenharmony_ci /* Even the IP block is limited to 100 MHz 5162306a36Sopenharmony_ci * this provides a throughput gain 5262306a36Sopenharmony_ci */ 5362306a36Sopenharmony_ci mmc-hs200-1_8v; 5462306a36Sopenharmony_ci status = "okay"; 5562306a36Sopenharmony_ci}; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci&expgpio { 5862306a36Sopenharmony_ci gpio-line-names = "BT_ON", 5962306a36Sopenharmony_ci "WL_ON", 6062306a36Sopenharmony_ci "PWR_LED_OFF", 6162306a36Sopenharmony_ci "ANT1", 6262306a36Sopenharmony_ci "VDD_SD_IO_SEL", 6362306a36Sopenharmony_ci "CAM_GPIO", 6462306a36Sopenharmony_ci "SD_PWR_ON", 6562306a36Sopenharmony_ci "ANT2"; 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_ci ant1: ant1-hog { 6862306a36Sopenharmony_ci gpio-hog; 6962306a36Sopenharmony_ci gpios = <3 GPIO_ACTIVE_HIGH>; 7062306a36Sopenharmony_ci /* internal antenna enabled */ 7162306a36Sopenharmony_ci output-high; 7262306a36Sopenharmony_ci line-name = "ant1"; 7362306a36Sopenharmony_ci }; 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ci ant2: ant2-hog { 7662306a36Sopenharmony_ci gpio-hog; 7762306a36Sopenharmony_ci gpios = <7 GPIO_ACTIVE_HIGH>; 7862306a36Sopenharmony_ci /* external antenna disabled */ 7962306a36Sopenharmony_ci output-low; 8062306a36Sopenharmony_ci line-name = "ant2"; 8162306a36Sopenharmony_ci }; 8262306a36Sopenharmony_ci}; 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci&genet { 8562306a36Sopenharmony_ci phy-handle = <&phy1>; 8662306a36Sopenharmony_ci phy-mode = "rgmii-rxid"; 8762306a36Sopenharmony_ci status = "okay"; 8862306a36Sopenharmony_ci}; 8962306a36Sopenharmony_ci 9062306a36Sopenharmony_ci&genet_mdio { 9162306a36Sopenharmony_ci phy1: ethernet-phy@0 { 9262306a36Sopenharmony_ci /* No PHY interrupt */ 9362306a36Sopenharmony_ci reg = <0x0>; 9462306a36Sopenharmony_ci }; 9562306a36Sopenharmony_ci}; 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci/* uart0 communicates with the BT module */ 9862306a36Sopenharmony_ci&uart0 { 9962306a36Sopenharmony_ci pinctrl-names = "default"; 10062306a36Sopenharmony_ci pinctrl-0 = <&uart0_ctsrts_gpio30 &uart0_gpio32>; 10162306a36Sopenharmony_ci uart-has-rtscts; 10262306a36Sopenharmony_ci}; 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci/* uart1 is mapped to the pin header */ 10562306a36Sopenharmony_ci&uart1 { 10662306a36Sopenharmony_ci pinctrl-names = "default"; 10762306a36Sopenharmony_ci pinctrl-0 = <&uart1_gpio14>; 10862306a36Sopenharmony_ci status = "okay"; 10962306a36Sopenharmony_ci}; 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci&wifi_pwrseq { 11262306a36Sopenharmony_ci reset-gpios = <&expgpio 1 GPIO_ACTIVE_LOW>; 11362306a36Sopenharmony_ci}; 114