1// SPDX-License-Identifier: GPL-2.0 2/* 3 * Copyright (C) 2021 Texas Instruments Incorporated - https://www.ti.com/ 4 * 5 * J721E SK URL: https://www.ti.com/tool/SK-TDA4VM 6 */ 7 8/dts-v1/; 9 10#include "k3-j721e.dtsi" 11#include <dt-bindings/gpio/gpio.h> 12#include <dt-bindings/input/input.h> 13#include <dt-bindings/net/ti-dp83867.h> 14 15/ { 16 compatible = "ti,j721e-sk", "ti,j721e"; 17 model = "Texas Instruments J721E SK"; 18 19 aliases { 20 serial0 = &wkup_uart0; 21 serial1 = &mcu_uart0; 22 serial2 = &main_uart0; 23 serial3 = &main_uart1; 24 ethernet0 = &cpsw_port1; 25 mmc1 = &main_sdhci1; 26 }; 27 28 chosen { 29 stdout-path = "serial2:115200n8"; 30 }; 31 32 memory@80000000 { 33 device_type = "memory"; 34 /* 4G RAM */ 35 reg = <0x00000000 0x80000000 0x00000000 0x80000000>, 36 <0x00000008 0x80000000 0x00000000 0x80000000>; 37 }; 38 39 reserved_memory: reserved-memory { 40 #address-cells = <2>; 41 #size-cells = <2>; 42 ranges; 43 44 secure_ddr: optee@9e800000 { 45 reg = <0x00 0x9e800000 0x00 0x01800000>; 46 alignment = <0x1000>; 47 no-map; 48 }; 49 50 mcu_r5fss0_core0_dma_memory_region: r5f-dma-memory@a0000000 { 51 compatible = "shared-dma-pool"; 52 reg = <0x00 0xa0000000 0x00 0x100000>; 53 no-map; 54 }; 55 56 mcu_r5fss0_core0_memory_region: r5f-memory@a0100000 { 57 compatible = "shared-dma-pool"; 58 reg = <0x00 0xa0100000 0x00 0xf00000>; 59 no-map; 60 }; 61 62 mcu_r5fss0_core1_dma_memory_region: r5f-dma-memory@a1000000 { 63 compatible = "shared-dma-pool"; 64 reg = <0x00 0xa1000000 0x00 0x100000>; 65 no-map; 66 }; 67 68 mcu_r5fss0_core1_memory_region: r5f-memory@a1100000 { 69 compatible = "shared-dma-pool"; 70 reg = <0x00 0xa1100000 0x00 0xf00000>; 71 no-map; 72 }; 73 74 main_r5fss0_core0_dma_memory_region: r5f-dma-memory@a2000000 { 75 compatible = "shared-dma-pool"; 76 reg = <0x00 0xa2000000 0x00 0x100000>; 77 no-map; 78 }; 79 80 main_r5fss0_core0_memory_region: r5f-memory@a2100000 { 81 compatible = "shared-dma-pool"; 82 reg = <0x00 0xa2100000 0x00 0xf00000>; 83 no-map; 84 }; 85 86 main_r5fss0_core1_dma_memory_region: r5f-dma-memory@a3000000 { 87 compatible = "shared-dma-pool"; 88 reg = <0x00 0xa3000000 0x00 0x100000>; 89 no-map; 90 }; 91 92 main_r5fss0_core1_memory_region: r5f-memory@a3100000 { 93 compatible = "shared-dma-pool"; 94 reg = <0x00 0xa3100000 0x00 0xf00000>; 95 no-map; 96 }; 97 98 main_r5fss1_core0_dma_memory_region: r5f-dma-memory@a4000000 { 99 compatible = "shared-dma-pool"; 100 reg = <0x00 0xa4000000 0x00 0x100000>; 101 no-map; 102 }; 103 104 main_r5fss1_core0_memory_region: r5f-memory@a4100000 { 105 compatible = "shared-dma-pool"; 106 reg = <0x00 0xa4100000 0x00 0xf00000>; 107 no-map; 108 }; 109 110 main_r5fss1_core1_dma_memory_region: r5f-dma-memory@a5000000 { 111 compatible = "shared-dma-pool"; 112 reg = <0x00 0xa5000000 0x00 0x100000>; 113 no-map; 114 }; 115 116 main_r5fss1_core1_memory_region: r5f-memory@a5100000 { 117 compatible = "shared-dma-pool"; 118 reg = <0x00 0xa5100000 0x00 0xf00000>; 119 no-map; 120 }; 121 122 c66_0_dma_memory_region: c66-dma-memory@a6000000 { 123 compatible = "shared-dma-pool"; 124 reg = <0x00 0xa6000000 0x00 0x100000>; 125 no-map; 126 }; 127 128 c66_0_memory_region: c66-memory@a6100000 { 129 compatible = "shared-dma-pool"; 130 reg = <0x00 0xa6100000 0x00 0xf00000>; 131 no-map; 132 }; 133 134 c66_1_dma_memory_region: c66-dma-memory@a7000000 { 135 compatible = "shared-dma-pool"; 136 reg = <0x00 0xa7000000 0x00 0x100000>; 137 no-map; 138 }; 139 140 c66_1_memory_region: c66-memory@a7100000 { 141 compatible = "shared-dma-pool"; 142 reg = <0x00 0xa7100000 0x00 0xf00000>; 143 no-map; 144 }; 145 146 c71_0_dma_memory_region: c71-dma-memory@a8000000 { 147 compatible = "shared-dma-pool"; 148 reg = <0x00 0xa8000000 0x00 0x100000>; 149 no-map; 150 }; 151 152 c71_0_memory_region: c71-memory@a8100000 { 153 compatible = "shared-dma-pool"; 154 reg = <0x00 0xa8100000 0x00 0xf00000>; 155 no-map; 156 }; 157 158 rtos_ipc_memory_region: ipc-memories@aa000000 { 159 reg = <0x00 0xaa000000 0x00 0x01c00000>; 160 alignment = <0x1000>; 161 no-map; 162 }; 163 }; 164 165 vusb_main: fixedregulator-vusb-main5v0 { 166 /* USB MAIN INPUT 5V DC */ 167 compatible = "regulator-fixed"; 168 regulator-name = "vusb-main5v0"; 169 regulator-min-microvolt = <5000000>; 170 regulator-max-microvolt = <5000000>; 171 regulator-always-on; 172 regulator-boot-on; 173 }; 174 175 vsys_3v3: fixedregulator-vsys3v3 { 176 /* Output of LM5141 */ 177 compatible = "regulator-fixed"; 178 regulator-name = "vsys_3v3"; 179 regulator-min-microvolt = <3300000>; 180 regulator-max-microvolt = <3300000>; 181 vin-supply = <&vusb_main>; 182 regulator-always-on; 183 regulator-boot-on; 184 }; 185 186 vdd_mmc1: fixedregulator-sd { 187 compatible = "regulator-fixed"; 188 pinctrl-names = "default"; 189 pinctrl-0 = <&vdd_mmc1_en_pins_default>; 190 regulator-name = "vdd_mmc1"; 191 regulator-min-microvolt = <3300000>; 192 regulator-max-microvolt = <3300000>; 193 regulator-boot-on; 194 enable-active-high; 195 vin-supply = <&vsys_3v3>; 196 gpio = <&wkup_gpio0 8 GPIO_ACTIVE_HIGH>; 197 }; 198 199 vdd_sd_dv_alt: gpio-regulator-tps659411 { 200 compatible = "regulator-gpio"; 201 pinctrl-names = "default"; 202 pinctrl-0 = <&vdd_sd_dv_alt_pins_default>; 203 regulator-name = "tps659411"; 204 regulator-min-microvolt = <1800000>; 205 regulator-max-microvolt = <3300000>; 206 regulator-boot-on; 207 vin-supply = <&vsys_3v3>; 208 gpios = <&wkup_gpio0 9 GPIO_ACTIVE_HIGH>; 209 states = <1800000 0x0>, 210 <3300000 0x1>; 211 }; 212 213 dp_pwr_3v3: fixedregulator-dp-prw { 214 compatible = "regulator-fixed"; 215 regulator-name = "dp-pwr"; 216 regulator-min-microvolt = <3300000>; 217 regulator-max-microvolt = <3300000>; 218 pinctrl-names = "default"; 219 pinctrl-0 = <&dp_pwr_en_pins_default>; 220 gpio = <&main_gpio0 111 0>; /* DP0_3V3 _EN */ 221 enable-active-high; 222 }; 223 224 dp0: connector { 225 compatible = "dp-connector"; 226 label = "DP0"; 227 type = "full-size"; 228 dp-pwr-supply = <&dp_pwr_3v3>; 229 230 port { 231 dp_connector_in: endpoint { 232 remote-endpoint = <&dp0_out>; 233 }; 234 }; 235 }; 236 237 hdmi-connector { 238 compatible = "hdmi-connector"; 239 label = "hdmi"; 240 type = "a"; 241 242 pinctrl-names = "default"; 243 pinctrl-0 = <&hdmi_hpd_pins_default>; 244 245 ddc-i2c-bus = <&main_i2c1>; 246 247 /* HDMI_HPD */ 248 hpd-gpios = <&main_gpio1 0 GPIO_ACTIVE_HIGH>; 249 250 port { 251 hdmi_connector_in: endpoint { 252 remote-endpoint = <&tfp410_out>; 253 }; 254 }; 255 }; 256 257 dvi-bridge { 258 compatible = "ti,tfp410"; 259 260 pinctrl-names = "default"; 261 pinctrl-0 = <&hdmi_pdn_pins_default>; 262 263 powerdown-gpios = <&main_gpio0 127 GPIO_ACTIVE_LOW>; 264 ti,deskew = <0>; 265 266 ports { 267 #address-cells = <1>; 268 #size-cells = <0>; 269 270 port@0 { 271 reg = <0>; 272 273 tfp410_in: endpoint { 274 remote-endpoint = <&dpi1_out>; 275 pclk-sample = <1>; 276 }; 277 }; 278 279 port@1 { 280 reg = <1>; 281 282 tfp410_out: endpoint { 283 remote-endpoint = 284 <&hdmi_connector_in>; 285 }; 286 }; 287 }; 288 }; 289}; 290 291&main_pmx0 { 292 main_mmc1_pins_default: main-mmc1-default-pins { 293 pinctrl-single,pins = < 294 J721E_IOPAD(0x254, PIN_INPUT, 0) /* (R29) MMC1_CMD */ 295 J721E_IOPAD(0x250, PIN_INPUT, 0) /* (P25) MMC1_CLK */ 296 J721E_IOPAD(0x2ac, PIN_INPUT, 0) /* (P25) MMC1_CLKLB */ 297 J721E_IOPAD(0x24c, PIN_INPUT, 0) /* (R24) MMC1_DAT0 */ 298 J721E_IOPAD(0x248, PIN_INPUT, 0) /* (P24) MMC1_DAT1 */ 299 J721E_IOPAD(0x244, PIN_INPUT, 0) /* (R25) MMC1_DAT2 */ 300 J721E_IOPAD(0x240, PIN_INPUT, 0) /* (R26) MMC1_DAT3 */ 301 J721E_IOPAD(0x258, PIN_INPUT, 0) /* (P23) MMC1_SDCD */ 302 >; 303 }; 304 305 main_uart0_pins_default: main-uart0-default-pins { 306 pinctrl-single,pins = < 307 J721E_IOPAD(0x1f0, PIN_INPUT, 0) /* (AC2) UART0_CTSn */ 308 J721E_IOPAD(0x1f4, PIN_OUTPUT, 0) /* (AB1) UART0_RTSn */ 309 J721E_IOPAD(0x1e8, PIN_INPUT, 0) /* (AB2) UART0_RXD */ 310 J721E_IOPAD(0x1ec, PIN_OUTPUT, 0) /* (AB3) UART0_TXD */ 311 >; 312 }; 313 314 main_uart1_pins_default: main-uart1-default-pins { 315 pinctrl-single,pins = < 316 J721E_IOPAD(0x1f8, PIN_INPUT, 0) /* (AA4) UART1_RXD */ 317 J721E_IOPAD(0x1fc, PIN_OUTPUT, 0) /* (AB4) UART1_TXD */ 318 >; 319 }; 320 321 main_i2c0_pins_default: main-i2c0-default-pins { 322 pinctrl-single,pins = < 323 J721E_IOPAD(0x220, PIN_INPUT_PULLUP, 0) /* (AC5) I2C0_SCL */ 324 J721E_IOPAD(0x224, PIN_INPUT_PULLUP, 0) /* (AA5) I2C0_SDA */ 325 >; 326 }; 327 328 main_i2c1_pins_default: main-i2c1-default-pins { 329 pinctrl-single,pins = < 330 J721E_IOPAD(0x228, PIN_INPUT_PULLUP, 0) /* (Y6) I2C1_SCL */ 331 J721E_IOPAD(0x22c, PIN_INPUT_PULLUP, 0) /* (AA6) I2C1_SDA */ 332 >; 333 }; 334 335 main_i2c3_pins_default: main-i2c3-default-pins { 336 pinctrl-single,pins = < 337 J721E_IOPAD(0x270, PIN_INPUT_PULLUP, 4) /* (T26) MMC2_CLK.I2C3_SCL */ 338 J721E_IOPAD(0x274, PIN_INPUT_PULLUP, 4) /* (T25) MMC2_CMD.I2C3_SDA */ 339 >; 340 }; 341 342 main_usbss0_pins_default: main-usbss0-default-pins { 343 pinctrl-single,pins = < 344 J721E_IOPAD(0x290, PIN_OUTPUT, 0) /* (U6) USB0_DRVVBUS */ 345 J721E_IOPAD(0x210, PIN_INPUT, 7) /* (W3) MCAN1_RX.GPIO1_3 */ 346 >; 347 }; 348 349 main_usbss1_pins_default: main-usbss1-default-pins { 350 pinctrl-single,pins = < 351 J721E_IOPAD(0x214, PIN_OUTPUT, 4) /* (V4) MCAN1_TX.USB1_DRVVBUS */ 352 >; 353 }; 354 355 dp0_pins_default: dp0-default-pins { 356 pinctrl-single,pins = < 357 J721E_IOPAD(0x1c4, PIN_INPUT, 5) /* SPI0_CS1.DP0_HPD */ 358 >; 359 }; 360 361 dp_pwr_en_pins_default: dp-pwr-en-default-pins { 362 pinctrl-single,pins = < 363 J721E_IOPAD(0x1c0, PIN_INPUT, 7) /* (AA2) SPI0_CS0.GPIO0_111 */ 364 >; 365 }; 366 367 dss_vout0_pins_default: dss-vout0-default-pins { 368 pinctrl-single,pins = < 369 J721E_IOPAD(0x58, PIN_OUTPUT, 10) /* (AE22) PRG1_PRU1_GPO0.VOUT0_DATA0 */ 370 J721E_IOPAD(0x5c, PIN_OUTPUT, 10) /* (AG23) PRG1_PRU1_GPO1.VOUT0_DATA1 */ 371 J721E_IOPAD(0x60, PIN_OUTPUT, 10) /* (AF23) PRG1_PRU1_GPO2.VOUT0_DATA2 */ 372 J721E_IOPAD(0x64, PIN_OUTPUT, 10) /* (AD23) PRG1_PRU1_GPO3.VOUT0_DATA3 */ 373 J721E_IOPAD(0x68, PIN_OUTPUT, 10) /* (AH24) PRG1_PRU1_GPO4.VOUT0_DATA4 */ 374 J721E_IOPAD(0x6c, PIN_OUTPUT, 10) /* (AG21) PRG1_PRU1_GPO5.VOUT0_DATA5 */ 375 J721E_IOPAD(0x70, PIN_OUTPUT, 10) /* (AE23) PRG1_PRU1_GPO6.VOUT0_DATA6 */ 376 J721E_IOPAD(0x74, PIN_OUTPUT, 10) /* (AC21) PRG1_PRU1_GPO7.VOUT0_DATA7 */ 377 J721E_IOPAD(0x78, PIN_OUTPUT, 10) /* (Y23) PRG1_PRU1_GPO8.VOUT0_DATA8 */ 378 J721E_IOPAD(0x7c, PIN_OUTPUT, 10) /* (AF21) PRG1_PRU1_GPO9.VOUT0_DATA9 */ 379 J721E_IOPAD(0x80, PIN_OUTPUT, 10) /* (AB23) PRG1_PRU1_GPO10.VOUT0_DATA10 */ 380 J721E_IOPAD(0x84, PIN_OUTPUT, 10) /* (AJ25) PRG1_PRU1_GPO11.VOUT0_DATA11 */ 381 J721E_IOPAD(0x88, PIN_OUTPUT, 10) /* (AH25) PRG1_PRU1_GPO12.VOUT0_DATA12 */ 382 J721E_IOPAD(0x8c, PIN_OUTPUT, 10) /* (AG25) PRG1_PRU1_GPO13.VOUT0_DATA13 */ 383 J721E_IOPAD(0x90, PIN_OUTPUT, 10) /* (AH26) PRG1_PRU1_GPO14.VOUT0_DATA14 */ 384 J721E_IOPAD(0x94, PIN_OUTPUT, 10) /* (AJ27) PRG1_PRU1_GPO15.VOUT0_DATA15 */ 385 J721E_IOPAD(0x30, PIN_OUTPUT, 10) /* (AF24) PRG1_PRU0_GPO11.VOUT0_DATA16 */ 386 J721E_IOPAD(0x34, PIN_OUTPUT, 10) /* (AJ24) PRG1_PRU0_GPO12.VOUT0_DATA17 */ 387 J721E_IOPAD(0x38, PIN_OUTPUT, 10) /* (AG24) PRG1_PRU0_GPO13.VOUT0_DATA18 */ 388 J721E_IOPAD(0x3c, PIN_OUTPUT, 10) /* (AD24) PRG1_PRU0_GPO14.VOUT0_DATA19 */ 389 J721E_IOPAD(0x40, PIN_OUTPUT, 10) /* (AC24) PRG1_PRU0_GPO15.VOUT0_DATA20 */ 390 J721E_IOPAD(0x44, PIN_OUTPUT, 10) /* (AE24) PRG1_PRU0_GPO16.VOUT0_DATA21 */ 391 J721E_IOPAD(0x24, PIN_OUTPUT, 10) /* (AJ20) PRG1_PRU0_GPO8.VOUT0_DATA22 */ 392 J721E_IOPAD(0x28, PIN_OUTPUT, 10) /* (AG20) PRG1_PRU0_GPO9.VOUT0_DATA23 */ 393 J721E_IOPAD(0x9c, PIN_OUTPUT, 10) /* (AC22) PRG1_PRU1_GPO17.VOUT0_DE */ 394 J721E_IOPAD(0x98, PIN_OUTPUT, 10) /* (AJ26) PRG1_PRU1_GPO16.VOUT0_HSYNC */ 395 J721E_IOPAD(0xa4, PIN_OUTPUT, 10) /* (AH22) PRG1_PRU1_GPO19.VOUT0_PCLK */ 396 J721E_IOPAD(0xa0, PIN_OUTPUT, 10) /* (AJ22) PRG1_PRU1_GPO18.VOUT0_VSYNC */ 397 >; 398 }; 399 400 hdmi_hpd_pins_default: hdmi-hpd-default-pins { 401 pinctrl-single,pins = < 402 J721E_IOPAD(0x204, PIN_INPUT, 7) /* (AD5) UART1_RTSn.GPIO1_0 */ 403 >; 404 }; 405 406 hdmi_pdn_pins_default: hdmi-pdn-default-pins { 407 pinctrl-single,pins = < 408 J721E_IOPAD(0x200, PIN_INPUT, 7) /* (AC4) UART1_CTSn.GPIO0_127 */ 409 >; 410 }; 411 412 /* Reset for M.2 E Key slot on PCIe0 */ 413 ekey_reset_pins_default: ekey-reset-pns-default-pins { 414 pinctrl-single,pins = < 415 J721E_IOPAD(0x124, PIN_INPUT, 7) /* (Y24) PRG0_PRU1_GPO9.GPIO0_72 */ 416 >; 417 }; 418 419 main_i2c5_pins_default: main-i2c5-default-pins { 420 pinctrl-single,pins = < 421 J721E_IOPAD(0x150, PIN_INPUT_PULLUP, 2) /* (Y26) PRG0_MDIO0_MDIO.I2C5_SCL */ 422 J721E_IOPAD(0x154, PIN_INPUT_PULLUP, 2) /* (AA27) PRG0_MDIO0_MDC.I2C5_SDA */ 423 >; 424 }; 425 426 rpi_header_gpio0_pins_default: rpi-header-gpio0-default-pins { 427 pinctrl-single,pins = < 428 J721E_IOPAD(0x01C, PIN_INPUT, 7) /* (AD22) PRG1_PRU0_GPO6.GPIO0_7 */ 429 J721E_IOPAD(0x120, PIN_INPUT, 7) /* (AA28) PRG0_PRU1_GPO8.GPIO0_71 */ 430 J721E_IOPAD(0x14C, PIN_INPUT, 7) /* (AA29) PRG0_PRU1_GPO19.GPIO0_82 */ 431 J721E_IOPAD(0x02C, PIN_INPUT, 7) /* (AD21) PRG1_PRU0_GPO10.GPIO0_11 */ 432 J721E_IOPAD(0x198, PIN_INPUT, 7) /* (V25) RGMII6_TD1.GPIO0_101 */ 433 J721E_IOPAD(0x1B0, PIN_INPUT, 7) /* (W24) RGMII6_RD1.GPIO0_107 */ 434 J721E_IOPAD(0x1A0, PIN_INPUT, 7) /* (W29) RGMII6_TXC.GPIO0_103 */ 435 J721E_IOPAD(0x008, PIN_INPUT, 7) /* (AG22) PRG1_PRU0_GPO1.GPIO0_2 */ 436 J721E_IOPAD(0x1D0, PIN_INPUT, 7) /* (AA3) SPI0_D1.GPIO0_115 */ 437 J721E_IOPAD(0x11C, PIN_INPUT, 7) /* (AA24) PRG0_PRU1_GPO7.GPIO0_70 */ 438 J721E_IOPAD(0x148, PIN_INPUT, 7) /* (AA26) PRG0_PRU1_GPO18.GPIO0_81 */ 439 J721E_IOPAD(0x004, PIN_INPUT, 7) /* (AC23) PRG1_PRU0_GPO0.GPIO0_1 */ 440 J721E_IOPAD(0x014, PIN_INPUT, 7) /* (AH23) PRG1_PRU0_GPO4.GPIO0_5 */ 441 J721E_IOPAD(0x020, PIN_INPUT, 7) /* (AE20) PRG1_PRU0_GPO7.GPIO0_8 */ 442 J721E_IOPAD(0x19C, PIN_INPUT, 7) /* (W27) RGMII6_TD0.GPIO0_102 */ 443 J721E_IOPAD(0x1B4, PIN_INPUT, 7) /* (W25) RGMII6_RD0.GPIO0_108 */ 444 J721E_IOPAD(0x188, PIN_INPUT, 7) /* (Y28) RGMII6_TX_CTL.GPIO0_97 */ 445 J721E_IOPAD(0x00C, PIN_INPUT, 7) /* (AF22) PRG1_PRU0_GPO2.GPIO0_3 */ 446 J721E_IOPAD(0x010, PIN_INPUT, 7) /* (AJ23) PRG1_PRU0_GPO3.GPIO0_4 */ 447 J721E_IOPAD(0x178, PIN_INPUT, 7) /* (U27) RGMII5_RD3.GPIO0_93 */ 448 J721E_IOPAD(0x17C, PIN_INPUT, 7) /* (U24) RGMII5_RD2.GPIO0_94 */ 449 J721E_IOPAD(0x190, PIN_INPUT, 7) /* (W23) RGMII6_TD3.GPIO0_99 */ 450 J721E_IOPAD(0x18C, PIN_INPUT, 7) /* (V23) RGMII6_RX_CTL.GPIO0_98 */ 451 >; 452 }; 453 454 rpi_header_gpio1_pins_default: rpi-header-gpio1-default-pins { 455 pinctrl-single,pins = < 456 J721E_IOPAD(0x234, PIN_INPUT, 7) /* (U3) EXT_REFCLK1.GPIO1_12 */ 457 >; 458 }; 459}; 460 461&wkup_pmx0 { 462 mcu_cpsw_pins_default: mcu-cpsw-default-pins { 463 pinctrl-single,pins = < 464 J721E_WKUP_IOPAD(0x84, PIN_INPUT, 0) /* (B24) MCU_RGMII1_RD0 */ 465 J721E_WKUP_IOPAD(0x80, PIN_INPUT, 0) /* (A24) MCU_RGMII1_RD1 */ 466 J721E_WKUP_IOPAD(0x7c, PIN_INPUT, 0) /* (D24) MCU_RGMII1_RD2 */ 467 J721E_WKUP_IOPAD(0x78, PIN_INPUT, 0) /* (A25) MCU_RGMII1_RD3 */ 468 J721E_WKUP_IOPAD(0x74, PIN_INPUT, 0) /* (C24) MCU_RGMII1_RXC */ 469 J721E_WKUP_IOPAD(0x5c, PIN_INPUT, 0) /* (C25) MCU_RGMII1_RX_CTL */ 470 J721E_WKUP_IOPAD(0x6c, PIN_OUTPUT, 0) /* (B25) MCU_RGMII1_TD0 */ 471 J721E_WKUP_IOPAD(0x68, PIN_OUTPUT, 0) /* (A26) MCU_RGMII1_TD1 */ 472 J721E_WKUP_IOPAD(0x64, PIN_OUTPUT, 0) /* (A27) MCU_RGMII1_TD2 */ 473 J721E_WKUP_IOPAD(0x60, PIN_OUTPUT, 0) /* (A28) MCU_RGMII1_TD3 */ 474 J721E_WKUP_IOPAD(0x70, PIN_OUTPUT, 0) /* (B26) MCU_RGMII1_TXC */ 475 J721E_WKUP_IOPAD(0x58, PIN_OUTPUT, 0) /* (B27) MCU_RGMII1_TX_CTL */ 476 >; 477 }; 478 479 mcu_mdio_pins_default: mcu-mdio1-default-pins { 480 pinctrl-single,pins = < 481 J721E_WKUP_IOPAD(0x8c, PIN_OUTPUT, 0) /* (F23) MCU_MDIO0_MDC */ 482 J721E_WKUP_IOPAD(0x88, PIN_INPUT, 0) /* (E23) MCU_MDIO0_MDIO */ 483 >; 484 }; 485 486 mcu_fss0_ospi0_pins_default: mcu-fss0-ospi0-default-pins { 487 pinctrl-single,pins = < 488 J721E_WKUP_IOPAD(0x0, PIN_OUTPUT, 0) /* (E20) MCU_OSPI0_CLK */ 489 J721E_WKUP_IOPAD(0x2c, PIN_OUTPUT, 0) /* (F19) MCU_OSPI0_CSn0 */ 490 J721E_WKUP_IOPAD(0xc, PIN_INPUT, 0) /* (D20) MCU_OSPI0_D0 */ 491 J721E_WKUP_IOPAD(0x10, PIN_INPUT, 0) /* (G19) MCU_OSPI0_D1 */ 492 J721E_WKUP_IOPAD(0x14, PIN_INPUT, 0) /* (G20) MCU_OSPI0_D2 */ 493 J721E_WKUP_IOPAD(0x18, PIN_INPUT, 0) /* (F20) MCU_OSPI0_D3 */ 494 J721E_WKUP_IOPAD(0x1c, PIN_INPUT, 0) /* (F21) MCU_OSPI0_D4 */ 495 J721E_WKUP_IOPAD(0x20, PIN_INPUT, 0) /* (E21) MCU_OSPI0_D5 */ 496 J721E_WKUP_IOPAD(0x24, PIN_INPUT, 0) /* (B22) MCU_OSPI0_D6 */ 497 J721E_WKUP_IOPAD(0x28, PIN_INPUT, 0) /* (G21) MCU_OSPI0_D7 */ 498 J721E_WKUP_IOPAD(0x8, PIN_INPUT, 0) /* (D21) MCU_OSPI0_DQS */ 499 >; 500 }; 501 502 vdd_mmc1_en_pins_default: vdd-mmc1-en-default-pins { 503 pinctrl-single,pins = < 504 J721E_WKUP_IOPAD(0xd0, PIN_OUTPUT, 7) /* (G27) WKUP_GPIO0_8 */ 505 >; 506 }; 507 508 vdd_sd_dv_alt_pins_default: vdd-sd-dv-alt-default-pins { 509 pinctrl-single,pins = < 510 J721E_WKUP_IOPAD(0xd4, PIN_OUTPUT, 7) /* (G26) WKUP_GPIO0_9 */ 511 >; 512 }; 513 514 wkup_uart0_pins_default: wkup-uart0-default-pins { 515 pinctrl-single,pins = < 516 J721E_WKUP_IOPAD(0xa0, PIN_INPUT, 0) /* (J29) WKUP_UART0_RXD */ 517 J721E_WKUP_IOPAD(0xa4, PIN_OUTPUT, 0) /* (J28) WKUP_UART0_TXD */ 518 >; 519 }; 520 521 mcu_uart0_pins_default: mcu-uart0-default-pins { 522 pinctrl-single,pins = < 523 J721E_WKUP_IOPAD(0xf0, PIN_INPUT, 2) /* (D26) MCU_I3C0_SCL.MCU_UART0_CTSn */ 524 J721E_WKUP_IOPAD(0xf4, PIN_OUTPUT, 2)/* (D25) MCU_I3C0_SDA.MCU_UART0_RTSn */ 525 J721E_WKUP_IOPAD(0xe4, PIN_INPUT, 0) /* (H28) WKUP_GPIO0_13.MCU_UART0_RXD */ 526 J721E_WKUP_IOPAD(0xe0, PIN_OUTPUT, 0)/* (G29) WKUP_GPIO0_12.MCU_UART0_TXD */ 527 >; 528 }; 529 530 wkup_i2c0_pins_default: wkup-i2c0-default-pins { 531 pinctrl-single,pins = < 532 J721E_WKUP_IOPAD(0xf8, PIN_INPUT_PULLUP, 0) /* (J25) WKUP_I2C0_SCL */ 533 J721E_WKUP_IOPAD(0xfc, PIN_INPUT_PULLUP, 0) /* (H24) WKUP_I2C0_SDA */ 534 >; 535 }; 536 537 /* Reset for M.2 M Key slot on PCIe1 */ 538 mkey_reset_pins_default: mkey-reset-pns-default-pins { 539 pinctrl-single,pins = < 540 J721E_WKUP_IOPAD(0xdc, PIN_INPUT, 7) /* (H27) WKUP_GPIO0_11 */ 541 >; 542 }; 543}; 544 545&wkup_uart0 { 546 /* Wakeup UART is used by System firmware */ 547 status = "reserved"; 548 pinctrl-names = "default"; 549 pinctrl-0 = <&wkup_uart0_pins_default>; 550}; 551 552&wkup_i2c0 { 553 status = "okay"; 554 pinctrl-names = "default"; 555 pinctrl-0 = <&wkup_i2c0_pins_default>; 556 clock-frequency = <400000>; 557 558 eeprom@51 { 559 /* AT24C512C-MAHM-T */ 560 compatible = "atmel,24c512"; 561 reg = <0x51>; 562 }; 563}; 564 565&mcu_uart0 { 566 status = "okay"; 567 pinctrl-names = "default"; 568 pinctrl-0 = <&mcu_uart0_pins_default>; 569}; 570 571&main_uart0 { 572 status = "okay"; 573 pinctrl-names = "default"; 574 pinctrl-0 = <&main_uart0_pins_default>; 575 /* Shared with ATF on this platform */ 576 power-domains = <&k3_pds 146 TI_SCI_PD_SHARED>; 577}; 578 579&main_uart1 { 580 status = "okay"; 581 pinctrl-names = "default"; 582 pinctrl-0 = <&main_uart1_pins_default>; 583}; 584 585&main_sdhci1 { 586 /* SD Card */ 587 status = "okay"; 588 vmmc-supply = <&vdd_mmc1>; 589 vqmmc-supply = <&vdd_sd_dv_alt>; 590 pinctrl-names = "default"; 591 pinctrl-0 = <&main_mmc1_pins_default>; 592 ti,driver-strength-ohm = <50>; 593 disable-wp; 594}; 595 596&ospi0 { 597 status = "okay"; 598 pinctrl-names = "default"; 599 pinctrl-0 = <&mcu_fss0_ospi0_pins_default>; 600 601 flash@0 { 602 compatible = "jedec,spi-nor"; 603 reg = <0x0>; 604 spi-tx-bus-width = <8>; 605 spi-rx-bus-width = <8>; 606 spi-max-frequency = <25000000>; 607 cdns,tshsl-ns = <60>; 608 cdns,tsd2d-ns = <60>; 609 cdns,tchsh-ns = <60>; 610 cdns,tslch-ns = <60>; 611 cdns,read-delay = <4>; 612 613 partitions { 614 compatible = "fixed-partitions"; 615 #address-cells = <1>; 616 #size-cells = <1>; 617 618 partition@0 { 619 label = "ospi.tiboot3"; 620 reg = <0x0 0x80000>; 621 }; 622 623 partition@80000 { 624 label = "ospi.tispl"; 625 reg = <0x80000 0x200000>; 626 }; 627 628 partition@280000 { 629 label = "ospi.u-boot"; 630 reg = <0x280000 0x400000>; 631 }; 632 633 partition@680000 { 634 label = "ospi.env"; 635 reg = <0x680000 0x40000>; 636 }; 637 638 partition@6c0000 { 639 label = "ospi.sysfw"; 640 reg = <0x6c0000 0x100000>; 641 }; 642 643 partition@7c0000 { 644 label = "ospi.env.backup"; 645 reg = <0x7c0000 0x40000>; 646 }; 647 648 partition@800000 { 649 label = "ospi.rootfs"; 650 reg = <0x800000 0x37c0000>; 651 }; 652 653 partition@3fc0000 { 654 label = "ospi.phypattern"; 655 reg = <0x3fc0000 0x40000>; 656 }; 657 }; 658 }; 659}; 660 661&main_i2c0 { 662 status = "okay"; 663 pinctrl-names = "default"; 664 pinctrl-0 = <&main_i2c0_pins_default>; 665 clock-frequency = <400000>; 666 667 i2c-mux@71 { 668 compatible = "nxp,pca9543"; 669 #address-cells = <1>; 670 #size-cells = <0>; 671 reg = <0x71>; 672 673 /* PCIe1 M.2 M Key I2C */ 674 i2c@0 { 675 #address-cells = <1>; 676 #size-cells = <0>; 677 reg = <0>; 678 }; 679 680 /* PCIe0 M.2 E Key I2C */ 681 i2c@1 { 682 #address-cells = <1>; 683 #size-cells = <0>; 684 reg = <1>; 685 }; 686 }; 687}; 688 689&main_i2c1 { 690 status = "okay"; 691 pinctrl-names = "default"; 692 pinctrl-0 = <&main_i2c1_pins_default>; 693 /* i2c1 is used for DVI DDC, so we need to use 100kHz */ 694 clock-frequency = <100000>; 695}; 696 697&main_i2c3 { 698 status = "okay"; 699 pinctrl-names = "default"; 700 pinctrl-0 = <&main_i2c3_pins_default>; 701 clock-frequency = <400000>; 702 703 i2c-mux@70 { 704 compatible = "nxp,pca9543"; 705 #address-cells = <1>; 706 #size-cells = <0>; 707 reg = <0x70>; 708 709 /* CSI0 I2C */ 710 i2c@0 { 711 #address-cells = <1>; 712 #size-cells = <0>; 713 reg = <0>; 714 }; 715 716 /* CSI1 I2C */ 717 i2c@1 { 718 #address-cells = <1>; 719 #size-cells = <0>; 720 reg = <1>; 721 }; 722 }; 723}; 724 725&main_i2c5 { 726 /* Brought out on RPi Header */ 727 status = "okay"; 728 pinctrl-names = "default"; 729 pinctrl-0 = <&main_i2c5_pins_default>; 730 clock-frequency = <400000>; 731}; 732 733&main_gpio0 { 734 status = "okay"; 735 pinctrl-names = "default"; 736 pinctrl-0 = <&rpi_header_gpio0_pins_default>; 737}; 738 739&main_gpio1 { 740 status = "okay"; 741 pinctrl-names = "default"; 742 pinctrl-0 = <&rpi_header_gpio1_pins_default>; 743}; 744 745&wkup_gpio0 { 746 status = "okay"; 747}; 748 749&usb_serdes_mux { 750 idle-states = <1>, <1>; /* USB0 to SERDES3, USB1 to SERDES2 */ 751}; 752 753&serdes_ln_ctrl { 754 idle-states = <J721E_SERDES0_LANE0_PCIE0_LANE0>, <J721E_SERDES0_LANE1_IP4_UNUSED>, 755 <J721E_SERDES1_LANE0_PCIE1_LANE0>, <J721E_SERDES1_LANE1_PCIE1_LANE1>, 756 <J721E_SERDES2_LANE0_IP1_UNUSED>, <J721E_SERDES2_LANE1_USB3_1>, 757 <J721E_SERDES3_LANE0_USB3_0_SWAP>, <J721E_SERDES3_LANE1_USB3_0>, 758 <J721E_SERDES4_LANE0_EDP_LANE0>, <J721E_SERDES4_LANE1_EDP_LANE1>, 759 <J721E_SERDES4_LANE2_EDP_LANE2>, <J721E_SERDES4_LANE3_EDP_LANE3>; 760}; 761 762&serdes_wiz3 { 763 typec-dir-gpios = <&main_gpio1 3 GPIO_ACTIVE_HIGH>; 764 typec-dir-debounce-ms = <700>; /* TUSB321, tCCB_DEFAULT 133 ms */ 765}; 766 767&serdes3 { 768 serdes3_usb_link: phy@0 { 769 reg = <0>; 770 cdns,num-lanes = <2>; 771 #phy-cells = <0>; 772 cdns,phy-type = <PHY_TYPE_USB3>; 773 resets = <&serdes_wiz3 1>, <&serdes_wiz3 2>; 774 }; 775}; 776 777&serdes4 { 778 torrent_phy_dp: phy@0 { 779 reg = <0>; 780 resets = <&serdes_wiz4 1>; 781 cdns,phy-type = <PHY_TYPE_DP>; 782 cdns,num-lanes = <4>; 783 cdns,max-bit-rate = <5400>; 784 #phy-cells = <0>; 785 }; 786}; 787 788&mhdp { 789 phys = <&torrent_phy_dp>; 790 phy-names = "dpphy"; 791 pinctrl-names = "default"; 792 pinctrl-0 = <&dp0_pins_default>; 793}; 794 795&usbss0 { 796 pinctrl-names = "default"; 797 pinctrl-0 = <&main_usbss0_pins_default>; 798 ti,vbus-divider; 799}; 800 801&usb0 { 802 dr_mode = "otg"; 803 maximum-speed = "super-speed"; 804 phys = <&serdes3_usb_link>; 805 phy-names = "cdns3,usb3-phy"; 806}; 807 808&serdes2 { 809 serdes2_usb_link: phy@1 { 810 reg = <1>; 811 cdns,num-lanes = <1>; 812 #phy-cells = <0>; 813 cdns,phy-type = <PHY_TYPE_USB3>; 814 resets = <&serdes_wiz2 2>; 815 }; 816}; 817 818&usbss1 { 819 pinctrl-names = "default"; 820 pinctrl-0 = <&main_usbss1_pins_default>; 821 ti,vbus-divider; 822}; 823 824&usb1 { 825 dr_mode = "host"; 826 maximum-speed = "super-speed"; 827 phys = <&serdes2_usb_link>; 828 phy-names = "cdns3,usb3-phy"; 829}; 830 831&mcu_cpsw { 832 pinctrl-names = "default"; 833 pinctrl-0 = <&mcu_cpsw_pins_default>, <&mcu_mdio_pins_default>; 834}; 835 836&davinci_mdio { 837 phy0: ethernet-phy@0 { 838 reg = <0>; 839 ti,rx-internal-delay = <DP83867_RGMIIDCTL_2_00_NS>; 840 ti,fifo-depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>; 841 }; 842}; 843 844&cpsw_port1 { 845 phy-mode = "rgmii-rxid"; 846 phy-handle = <&phy0>; 847}; 848 849&dss { 850 pinctrl-names = "default"; 851 pinctrl-0 = <&dss_vout0_pins_default>; 852 853 assigned-clocks = <&k3_clks 152 1>, /* VP 1 pixel clock */ 854 <&k3_clks 152 4>, /* VP 2 pixel clock */ 855 <&k3_clks 152 9>, /* VP 3 pixel clock */ 856 <&k3_clks 152 13>; /* VP 4 pixel clock */ 857 assigned-clock-parents = <&k3_clks 152 2>, /* PLL16_HSDIV0 */ 858 <&k3_clks 152 6>, /* DPI0_EXT_CLKSEL_OUT0 */ 859 <&k3_clks 152 11>, /* PLL18_HSDIV0 */ 860 <&k3_clks 152 18>; /* DPI1_EXT_CLKSEL_OUT0 */ 861}; 862 863&dss_ports { 864 #address-cells = <1>; 865 #size-cells = <0>; 866 867 port@0 { 868 reg = <0>; 869 870 dpi0_out: endpoint { 871 remote-endpoint = <&dp0_in>; 872 }; 873 }; 874 875 port@1 { 876 reg = <1>; 877 878 dpi1_out: endpoint { 879 remote-endpoint = <&tfp410_in>; 880 }; 881 }; 882}; 883 884&dp0_ports { 885 #address-cells = <1>; 886 #size-cells = <0>; 887 888 port@0 { 889 reg = <0>; 890 dp0_in: endpoint { 891 remote-endpoint = <&dpi0_out>; 892 }; 893 }; 894 895 port@4 { 896 reg = <4>; 897 dp0_out: endpoint { 898 remote-endpoint = <&dp_connector_in>; 899 }; 900 }; 901}; 902 903&serdes0 { 904 serdes0_pcie_link: phy@0 { 905 reg = <0>; 906 cdns,num-lanes = <1>; 907 #phy-cells = <0>; 908 cdns,phy-type = <PHY_TYPE_PCIE>; 909 resets = <&serdes_wiz0 1>; 910 }; 911}; 912 913&serdes1 { 914 serdes1_pcie_link: phy@0 { 915 reg = <0>; 916 cdns,num-lanes = <2>; 917 #phy-cells = <0>; 918 cdns,phy-type = <PHY_TYPE_PCIE>; 919 resets = <&serdes_wiz1 1>, <&serdes_wiz1 2>; 920 }; 921}; 922 923&pcie0_rc { 924 status = "okay"; 925 pinctrl-names = "default"; 926 pinctrl-0 = <&ekey_reset_pins_default>; 927 reset-gpios = <&main_gpio0 72 GPIO_ACTIVE_HIGH>; 928 929 phys = <&serdes0_pcie_link>; 930 phy-names = "pcie-phy"; 931 num-lanes = <1>; 932}; 933 934&pcie1_rc { 935 status = "okay"; 936 pinctrl-names = "default"; 937 pinctrl-0 = <&mkey_reset_pins_default>; 938 reset-gpios = <&wkup_gpio0 11 GPIO_ACTIVE_HIGH>; 939 940 phys = <&serdes1_pcie_link>; 941 phy-names = "pcie-phy"; 942 num-lanes = <2>; 943}; 944 945&ufs_wrapper { 946 status = "disabled"; 947}; 948 949&mailbox0_cluster0 { 950 status = "okay"; 951 interrupts = <436>; 952 953 mbox_mcu_r5fss0_core0: mbox-mcu-r5fss0-core0 { 954 ti,mbox-rx = <0 0 0>; 955 ti,mbox-tx = <1 0 0>; 956 }; 957 958 mbox_mcu_r5fss0_core1: mbox-mcu-r5fss0-core1 { 959 ti,mbox-rx = <2 0 0>; 960 ti,mbox-tx = <3 0 0>; 961 }; 962}; 963 964&mailbox0_cluster1 { 965 status = "okay"; 966 interrupts = <432>; 967 968 mbox_main_r5fss0_core0: mbox-main-r5fss0-core0 { 969 ti,mbox-rx = <0 0 0>; 970 ti,mbox-tx = <1 0 0>; 971 }; 972 973 mbox_main_r5fss0_core1: mbox-main-r5fss0-core1 { 974 ti,mbox-rx = <2 0 0>; 975 ti,mbox-tx = <3 0 0>; 976 }; 977}; 978 979&mailbox0_cluster2 { 980 status = "okay"; 981 interrupts = <428>; 982 983 mbox_main_r5fss1_core0: mbox-main-r5fss1-core0 { 984 ti,mbox-rx = <0 0 0>; 985 ti,mbox-tx = <1 0 0>; 986 }; 987 988 mbox_main_r5fss1_core1: mbox-main-r5fss1-core1 { 989 ti,mbox-rx = <2 0 0>; 990 ti,mbox-tx = <3 0 0>; 991 }; 992}; 993 994&mailbox0_cluster3 { 995 status = "okay"; 996 interrupts = <424>; 997 998 mbox_c66_0: mbox-c66-0 { 999 ti,mbox-rx = <0 0 0>; 1000 ti,mbox-tx = <1 0 0>; 1001 }; 1002 1003 mbox_c66_1: mbox-c66-1 { 1004 ti,mbox-rx = <2 0 0>; 1005 ti,mbox-tx = <3 0 0>; 1006 }; 1007}; 1008 1009&mailbox0_cluster4 { 1010 status = "okay"; 1011 interrupts = <420>; 1012 1013 mbox_c71_0: mbox-c71-0 { 1014 ti,mbox-rx = <0 0 0>; 1015 ti,mbox-tx = <1 0 0>; 1016 }; 1017}; 1018 1019&mcu_r5fss0_core0 { 1020 mboxes = <&mailbox0_cluster0>, <&mbox_mcu_r5fss0_core0>; 1021 memory-region = <&mcu_r5fss0_core0_dma_memory_region>, 1022 <&mcu_r5fss0_core0_memory_region>; 1023}; 1024 1025&mcu_r5fss0_core1 { 1026 mboxes = <&mailbox0_cluster0>, <&mbox_mcu_r5fss0_core1>; 1027 memory-region = <&mcu_r5fss0_core1_dma_memory_region>, 1028 <&mcu_r5fss0_core1_memory_region>; 1029}; 1030 1031&main_r5fss0_core0 { 1032 mboxes = <&mailbox0_cluster1>, <&mbox_main_r5fss0_core0>; 1033 memory-region = <&main_r5fss0_core0_dma_memory_region>, 1034 <&main_r5fss0_core0_memory_region>; 1035}; 1036 1037&main_r5fss0_core1 { 1038 mboxes = <&mailbox0_cluster1>, <&mbox_main_r5fss0_core1>; 1039 memory-region = <&main_r5fss0_core1_dma_memory_region>, 1040 <&main_r5fss0_core1_memory_region>; 1041}; 1042 1043&main_r5fss1_core0 { 1044 mboxes = <&mailbox0_cluster2>, <&mbox_main_r5fss1_core0>; 1045 memory-region = <&main_r5fss1_core0_dma_memory_region>, 1046 <&main_r5fss1_core0_memory_region>; 1047}; 1048 1049&main_r5fss1_core1 { 1050 mboxes = <&mailbox0_cluster2>, <&mbox_main_r5fss1_core1>; 1051 memory-region = <&main_r5fss1_core1_dma_memory_region>, 1052 <&main_r5fss1_core1_memory_region>; 1053}; 1054 1055&c66_0 { 1056 status = "okay"; 1057 mboxes = <&mailbox0_cluster3>, <&mbox_c66_0>; 1058 memory-region = <&c66_0_dma_memory_region>, 1059 <&c66_0_memory_region>; 1060}; 1061 1062&c66_1 { 1063 status = "okay"; 1064 mboxes = <&mailbox0_cluster3>, <&mbox_c66_1>; 1065 memory-region = <&c66_1_dma_memory_region>, 1066 <&c66_1_memory_region>; 1067}; 1068 1069&c71_0 { 1070 status = "okay"; 1071 mboxes = <&mailbox0_cluster4>, <&mbox_c71_0>; 1072 memory-region = <&c71_0_dma_memory_region>, 1073 <&c71_0_memory_region>; 1074}; 1075