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 = <&reg_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 = <&reg_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 = <&reg_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 = <&reg_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 = <&reg_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&reg_usdhc2_vmmc {
15962306a36Sopenharmony_ci	vin-supply = <&reg_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