1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
4 *
5 * EVM Board Schematics: https://www.ti.com/lit/zip/sprr458
6 */
7
8/dts-v1/;
9
10#include <dt-bindings/net/ti-dp83867.h>
11#include <dt-bindings/gpio/gpio.h>
12#include "k3-j784s4.dtsi"
13
14/ {
15	compatible = "ti,j784s4-evm", "ti,j784s4";
16	model = "Texas Instruments J784S4 EVM";
17
18	chosen {
19		stdout-path = "serial2:115200n8";
20	};
21
22	aliases {
23		serial2 = &main_uart8;
24		mmc1 = &main_sdhci1;
25		i2c0 = &main_i2c0;
26	};
27
28	memory@80000000 {
29		device_type = "memory";
30		/* 32G RAM */
31		reg = <0x00 0x80000000 0x00 0x80000000>,
32		      <0x08 0x80000000 0x07 0x80000000>;
33	};
34
35	reserved_memory: reserved-memory {
36		#address-cells = <2>;
37		#size-cells = <2>;
38		ranges;
39
40		secure_ddr: optee@9e800000 {
41			reg = <0x00 0x9e800000 0x00 0x01800000>;
42			no-map;
43		};
44	};
45
46	evm_12v0: regulator-evm12v0 {
47		/* main supply */
48		compatible = "regulator-fixed";
49		regulator-name = "evm_12v0";
50		regulator-min-microvolt = <12000000>;
51		regulator-max-microvolt = <12000000>;
52		regulator-always-on;
53		regulator-boot-on;
54	};
55
56	vsys_3v3: regulator-vsys3v3 {
57		/* Output of LM5140 */
58		compatible = "regulator-fixed";
59		regulator-name = "vsys_3v3";
60		regulator-min-microvolt = <3300000>;
61		regulator-max-microvolt = <3300000>;
62		vin-supply = <&evm_12v0>;
63		regulator-always-on;
64		regulator-boot-on;
65	};
66
67	vsys_5v0: regulator-vsys5v0 {
68		/* Output of LM5140 */
69		compatible = "regulator-fixed";
70		regulator-name = "vsys_5v0";
71		regulator-min-microvolt = <5000000>;
72		regulator-max-microvolt = <5000000>;
73		vin-supply = <&evm_12v0>;
74		regulator-always-on;
75		regulator-boot-on;
76	};
77
78	vdd_mmc1: regulator-sd {
79		/* Output of TPS22918 */
80		compatible = "regulator-fixed";
81		regulator-name = "vdd_mmc1";
82		regulator-min-microvolt = <3300000>;
83		regulator-max-microvolt = <3300000>;
84		regulator-boot-on;
85		enable-active-high;
86		vin-supply = <&vsys_3v3>;
87		gpio = <&exp2 2 GPIO_ACTIVE_HIGH>;
88	};
89
90	vdd_sd_dv: regulator-TLV71033 {
91		/* Output of TLV71033 */
92		compatible = "regulator-gpio";
93		regulator-name = "tlv71033";
94		pinctrl-names = "default";
95		pinctrl-0 = <&vdd_sd_dv_pins_default>;
96		regulator-min-microvolt = <1800000>;
97		regulator-max-microvolt = <3300000>;
98		regulator-boot-on;
99		vin-supply = <&vsys_5v0>;
100		gpios = <&main_gpio0 8 GPIO_ACTIVE_HIGH>;
101		states = <1800000 0x0>,
102			 <3300000 0x1>;
103	};
104};
105
106&main_pmx0 {
107	main_uart8_pins_default: main-uart8-pins-default {
108		pinctrl-single,pins = <
109			J784S4_IOPAD(0x040, PIN_INPUT, 14) /* (AF37) MCASP0_AXR0.UART8_CTSn */
110			J784S4_IOPAD(0x044, PIN_OUTPUT, 14) /* (AG37) MCASP0_AXR1.UART8_RTSn */
111			J784S4_IOPAD(0x0d0, PIN_INPUT, 11) /* (AP38) SPI0_CS1.UART8_RXD */
112			J784S4_IOPAD(0x0d4, PIN_OUTPUT, 11) /* (AN38) SPI0_CLK.UART8_TXD */
113		>;
114	};
115
116	main_i2c0_pins_default: main-i2c0-pins-default {
117		pinctrl-single,pins = <
118			J784S4_IOPAD(0x0e0, PIN_INPUT_PULLUP, 0) /* (AN36) I2C0_SCL */
119			J784S4_IOPAD(0x0e4, PIN_INPUT_PULLUP, 0) /* (AP37) I2C0_SDA */
120		>;
121	};
122
123	main_mmc1_pins_default: main-mmc1-pins-default {
124		pinctrl-single,pins = <
125			J784S4_IOPAD(0x104, PIN_INPUT, 0) /* (AB38) MMC1_CLK */
126			J784S4_IOPAD(0x108, PIN_INPUT, 0) /* (AB36) MMC1_CMD */
127			J784S4_IOPAD(0x100, PIN_INPUT, 0) /* (No Pin) MMC1_CLKLB */
128			J784S4_IOPAD(0x0fc, PIN_INPUT, 0) /* (AA33) MMC1_DAT0 */
129			J784S4_IOPAD(0x0f8, PIN_INPUT, 0) /* (AB34) MMC1_DAT1 */
130			J784S4_IOPAD(0x0f4, PIN_INPUT, 0) /* (AA32) MMC1_DAT2 */
131			J784S4_IOPAD(0x0f0, PIN_INPUT, 0) /* (AC38) MMC1_DAT3 */
132			J784S4_IOPAD(0x0e8, PIN_INPUT, 8) /* (AR38) TIMER_IO0.MMC1_SDCD */
133		>;
134	};
135
136	vdd_sd_dv_pins_default: vdd-sd-dv-pins-default {
137		pinctrl-single,pins = <
138			J784S4_IOPAD(0x020, PIN_INPUT, 7) /* (AJ35) MCAN15_RX.GPIO0_8 */
139		>;
140	};
141};
142
143&main_uart8 {
144	status = "okay";
145	pinctrl-names = "default";
146	pinctrl-0 = <&main_uart8_pins_default>;
147};
148
149&main_i2c0 {
150	status = "okay";
151	pinctrl-names = "default";
152	pinctrl-0 = <&main_i2c0_pins_default>;
153
154	clock-frequency = <400000>;
155
156	exp1: gpio@20 {
157		compatible = "ti,tca6416";
158		reg = <0x20>;
159		gpio-controller;
160		#gpio-cells = <2>;
161		gpio-line-names = "PCIE1_2L_MODE_SEL", "PCIE1_4L_PERSTZ", "PCIE1_2L_RC_RSTZ",
162				  "PCIE1_2L_EP_RST_EN", "PCIE0_4L_MODE_SEL", "PCIE0_4L_PERSTZ",
163				  "PCIE0_4L_RC_RSTZ", "PCIE0_4L_EP_RST_EN", "PCIE1_4L_PRSNT#",
164				  "PCIE0_4L_PRSNT#", "CDCI1_OE1/OE4", "CDCI1_OE2/OE3",
165				  "AUDIO_MUX_SEL", "EXP_MUX2", "EXP_MUX3", "GESI_EXP_PHY_RSTZ";
166	};
167
168	exp2: gpio@22 {
169		compatible = "ti,tca6424";
170		reg = <0x22>;
171		gpio-controller;
172		#gpio-cells = <2>;
173		gpio-line-names = "R_GPIO_RGMII1_RST", "ENET2_I2CMUX_SEL", "GPIO_USD_PWR_EN",
174				  "USBC_PWR_EN", "USBC_MODE_SEL1", "USBC_MODE_SEL0",
175				  "GPIO_LIN_EN", "R_CAN_STB", "CTRL_PM_I2C_OE#",
176				  "ENET2_EXP_PWRDN", "ENET2_EXP_SPARE2", "CDCI2_RSTZ",
177				  "USB2.0_MUX_SEL", "CANUART_MUX_SEL0", "CANUART_MUX2_SEL1",
178				  "CANUART_MUX1_SEL1", "ENET1_EXP_PWRDN", "ENET1_EXP_RESETZ",
179				  "ENET1_I2CMUX_SEL", "ENET1_EXP_SPARE2", "ENET2_EXP_RESETZ",
180				  "USER_INPUT1", "USER_LED1", "USER_LED2";
181	};
182};
183
184&main_sdhci1 {
185	/* SD card */
186	status = "okay";
187	pinctrl-0 = <&main_mmc1_pins_default>;
188	pinctrl-names = "default";
189	disable-wp;
190	vmmc-supply = <&vdd_mmc1>;
191	vqmmc-supply = <&vdd_sd_dv>;
192};
193
194&main_gpio0 {
195	status = "okay";
196};
197