162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later OR MIT 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright 2022 Toradex 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci/ { 762306a36Sopenharmony_ci reg_eth2phy: regulator-eth2phy { 862306a36Sopenharmony_ci compatible = "regulator-fixed"; 962306a36Sopenharmony_ci enable-active-high; 1062306a36Sopenharmony_ci gpio = <&gpio_expander_21 4 GPIO_ACTIVE_HIGH>; /* ETH_PWR_EN */ 1162306a36Sopenharmony_ci off-on-delay-us = <500000>; 1262306a36Sopenharmony_ci regulator-max-microvolt = <3300000>; 1362306a36Sopenharmony_ci regulator-min-microvolt = <3300000>; 1462306a36Sopenharmony_ci regulator-name = "+V3.3_ETH"; 1562306a36Sopenharmony_ci startup-delay-us = <200000>; 1662306a36Sopenharmony_ci vin-supply = <®_3p3v>; 1762306a36Sopenharmony_ci }; 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci sound { 2062306a36Sopenharmony_ci compatible = "simple-audio-card"; 2162306a36Sopenharmony_ci simple-audio-card,bitclock-master = <&codec_dai>; 2262306a36Sopenharmony_ci simple-audio-card,format = "i2s"; 2362306a36Sopenharmony_ci simple-audio-card,frame-master = <&codec_dai>; 2462306a36Sopenharmony_ci simple-audio-card,mclk-fs = <256>; 2562306a36Sopenharmony_ci simple-audio-card,name = "imx8mp-nau8822"; 2662306a36Sopenharmony_ci simple-audio-card,routing = 2762306a36Sopenharmony_ci "Headphones", "LHP", 2862306a36Sopenharmony_ci "Headphones", "RHP", 2962306a36Sopenharmony_ci "Speaker", "LSPK", 3062306a36Sopenharmony_ci "Speaker", "RSPK", 3162306a36Sopenharmony_ci "Line Out", "AUXOUT1", 3262306a36Sopenharmony_ci "Line Out", "AUXOUT2", 3362306a36Sopenharmony_ci "LAUX", "Line In", 3462306a36Sopenharmony_ci "RAUX", "Line In", 3562306a36Sopenharmony_ci "LMICP", "Mic In", 3662306a36Sopenharmony_ci "RMICP", "Mic In"; 3762306a36Sopenharmony_ci simple-audio-card,widgets = 3862306a36Sopenharmony_ci "Headphones", "Headphones", 3962306a36Sopenharmony_ci "Line Out", "Line Out", 4062306a36Sopenharmony_ci "Speaker", "Speaker", 4162306a36Sopenharmony_ci "Microphone", "Mic In", 4262306a36Sopenharmony_ci "Line", "Line In"; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci codec_dai: simple-audio-card,codec { 4562306a36Sopenharmony_ci clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI1_MCLK1>; 4662306a36Sopenharmony_ci sound-dai = <&nau8822_1a>; 4762306a36Sopenharmony_ci }; 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci simple-audio-card,cpu { 5062306a36Sopenharmony_ci sound-dai = <&sai1>; 5162306a36Sopenharmony_ci }; 5262306a36Sopenharmony_ci }; 5362306a36Sopenharmony_ci}; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci&backlight { 5662306a36Sopenharmony_ci power-supply = <®_3p3v>; 5762306a36Sopenharmony_ci}; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci/* Verdin SPI_1 */ 6062306a36Sopenharmony_ci&ecspi1 { 6162306a36Sopenharmony_ci status = "okay"; 6262306a36Sopenharmony_ci}; 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci/* EEPROM on display adapter boards */ 6562306a36Sopenharmony_ci&eeprom_display_adapter { 6662306a36Sopenharmony_ci status = "okay"; 6762306a36Sopenharmony_ci}; 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci/* EEPROM on Verdin Development board */ 7062306a36Sopenharmony_ci&eeprom_carrier_board { 7162306a36Sopenharmony_ci status = "okay"; 7262306a36Sopenharmony_ci}; 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci&eqos { 7562306a36Sopenharmony_ci status = "okay"; 7662306a36Sopenharmony_ci}; 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ci&fec { 7962306a36Sopenharmony_ci phy-supply = <®_eth2phy>; 8062306a36Sopenharmony_ci status = "okay"; 8162306a36Sopenharmony_ci}; 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci&flexcan1 { 8462306a36Sopenharmony_ci status = "okay"; 8562306a36Sopenharmony_ci}; 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci&flexcan2 { 8862306a36Sopenharmony_ci status = "okay"; 8962306a36Sopenharmony_ci}; 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci/* Verdin QSPI_1 */ 9262306a36Sopenharmony_ci&flexspi { 9362306a36Sopenharmony_ci status = "okay"; 9462306a36Sopenharmony_ci}; 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci&gpio_expander_21 { 9762306a36Sopenharmony_ci status = "okay"; 9862306a36Sopenharmony_ci vcc-supply = <®_1p8v>; 9962306a36Sopenharmony_ci}; 10062306a36Sopenharmony_ci 10162306a36Sopenharmony_ci/* Current measurement into module VCC */ 10262306a36Sopenharmony_ci&hwmon { 10362306a36Sopenharmony_ci status = "okay"; 10462306a36Sopenharmony_ci}; 10562306a36Sopenharmony_ci 10662306a36Sopenharmony_ci&hwmon_temp { 10762306a36Sopenharmony_ci vs-supply = <®_1p8v>; 10862306a36Sopenharmony_ci status = "okay"; 10962306a36Sopenharmony_ci}; 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci/* Verdin I2C_2_DSI */ 11262306a36Sopenharmony_ci&i2c2 { 11362306a36Sopenharmony_ci status = "okay"; 11462306a36Sopenharmony_ci}; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_ci&i2c3 { 11762306a36Sopenharmony_ci status = "okay"; 11862306a36Sopenharmony_ci}; 11962306a36Sopenharmony_ci 12062306a36Sopenharmony_ci/* Verdin I2C_1 */ 12162306a36Sopenharmony_ci&i2c4 { 12262306a36Sopenharmony_ci status = "okay"; 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ci /* Audio Codec */ 12562306a36Sopenharmony_ci nau8822_1a: audio-codec@1a { 12662306a36Sopenharmony_ci compatible = "nuvoton,nau8822"; 12762306a36Sopenharmony_ci reg = <0x1a>; 12862306a36Sopenharmony_ci pinctrl-names = "default"; 12962306a36Sopenharmony_ci pinctrl-0 = <&pinctrl_sai1>; 13062306a36Sopenharmony_ci #sound-dai-cells = <0>; 13162306a36Sopenharmony_ci }; 13262306a36Sopenharmony_ci}; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci/* Verdin PCIE_1 */ 13562306a36Sopenharmony_ci&pcie { 13662306a36Sopenharmony_ci status = "okay"; 13762306a36Sopenharmony_ci}; 13862306a36Sopenharmony_ci 13962306a36Sopenharmony_ci&pcie_phy { 14062306a36Sopenharmony_ci status = "okay"; 14162306a36Sopenharmony_ci}; 14262306a36Sopenharmony_ci 14362306a36Sopenharmony_ci/* Verdin PWM_1 */ 14462306a36Sopenharmony_ci&pwm1 { 14562306a36Sopenharmony_ci status = "okay"; 14662306a36Sopenharmony_ci}; 14762306a36Sopenharmony_ci 14862306a36Sopenharmony_ci/* Verdin PWM_2 */ 14962306a36Sopenharmony_ci&pwm2 { 15062306a36Sopenharmony_ci status = "okay"; 15162306a36Sopenharmony_ci}; 15262306a36Sopenharmony_ci 15362306a36Sopenharmony_ci/* Verdin PWM_3_DSI */ 15462306a36Sopenharmony_ci&pwm3 { 15562306a36Sopenharmony_ci status = "okay"; 15662306a36Sopenharmony_ci}; 15762306a36Sopenharmony_ci 15862306a36Sopenharmony_ci®_usdhc2_vmmc { 15962306a36Sopenharmony_ci vin-supply = <®_3p3v>; 16062306a36Sopenharmony_ci}; 16162306a36Sopenharmony_ci 16262306a36Sopenharmony_ci/* Verdin I2S_1 */ 16362306a36Sopenharmony_ci&sai1 { 16462306a36Sopenharmony_ci assigned-clocks = <&clk IMX8MP_CLK_SAI1>; 16562306a36Sopenharmony_ci assigned-clock-parents = <&clk IMX8MP_AUDIO_PLL1_OUT>; 16662306a36Sopenharmony_ci assigned-clock-rates = <24576000>; 16762306a36Sopenharmony_ci fsl,sai-mclk-direction-output; 16862306a36Sopenharmony_ci status = "okay"; 16962306a36Sopenharmony_ci}; 17062306a36Sopenharmony_ci 17162306a36Sopenharmony_ci/* Verdin UART_1, connector X50 through RS485 transceiver */ 17262306a36Sopenharmony_ci&uart1 { 17362306a36Sopenharmony_ci linux,rs485-enabled-at-boot-time; 17462306a36Sopenharmony_ci rs485-rts-active-low; 17562306a36Sopenharmony_ci rs485-rx-during-tx; 17662306a36Sopenharmony_ci status = "okay"; 17762306a36Sopenharmony_ci}; 17862306a36Sopenharmony_ci 17962306a36Sopenharmony_ci/* Verdin UART_2 */ 18062306a36Sopenharmony_ci&uart2 { 18162306a36Sopenharmony_ci status = "okay"; 18262306a36Sopenharmony_ci}; 18362306a36Sopenharmony_ci 18462306a36Sopenharmony_ci/* Verdin UART_3, used as the Linux Console */ 18562306a36Sopenharmony_ci&uart3 { 18662306a36Sopenharmony_ci status = "okay"; 18762306a36Sopenharmony_ci}; 18862306a36Sopenharmony_ci 18962306a36Sopenharmony_ci/* Verdin USB_1 */ 19062306a36Sopenharmony_ci&usb3_0 { 19162306a36Sopenharmony_ci status = "okay"; 19262306a36Sopenharmony_ci}; 19362306a36Sopenharmony_ci 19462306a36Sopenharmony_ci&usb3_phy0 { 19562306a36Sopenharmony_ci status = "okay"; 19662306a36Sopenharmony_ci}; 19762306a36Sopenharmony_ci 19862306a36Sopenharmony_ci/* Verdin USB_2 */ 19962306a36Sopenharmony_ci&usb3_1 { 20062306a36Sopenharmony_ci fsl,permanently-attached; 20162306a36Sopenharmony_ci status = "okay"; 20262306a36Sopenharmony_ci}; 20362306a36Sopenharmony_ci 20462306a36Sopenharmony_ci&usb3_phy1 { 20562306a36Sopenharmony_ci status = "okay"; 20662306a36Sopenharmony_ci}; 20762306a36Sopenharmony_ci 20862306a36Sopenharmony_ci/* Limit frequency on dev board due to long traces and bad signal integrity */ 20962306a36Sopenharmony_ci&usdhc2 { 21062306a36Sopenharmony_ci max-frequency = <100000000>; 21162306a36Sopenharmony_ci status = "okay"; 21262306a36Sopenharmony_ci}; 213