k3-am62a7-sk.dts 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * AM62A SK: https://www.ti.com/lit/zip/sprr459
  4. *
  5. * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
  6. */
  7. /dts-v1/;
  8. #include <dt-bindings/leds/common.h>
  9. #include <dt-bindings/gpio/gpio.h>
  10. #include "k3-am62a7.dtsi"
  11. / {
  12. compatible = "ti,am62a7-sk", "ti,am62a7";
  13. model = "Texas Instruments AM62A7 SK";
  14. aliases {
  15. serial2 = &main_uart0;
  16. mmc1 = &sdhci1;
  17. };
  18. chosen {
  19. stdout-path = "serial2:115200n8";
  20. };
  21. memory@80000000 {
  22. device_type = "memory";
  23. /* 4G RAM */
  24. reg = <0x00000000 0x80000000 0x00000000 0x80000000>,
  25. <0x00000008 0x80000000 0x00000000 0x80000000>;
  26. };
  27. reserved-memory {
  28. #address-cells = <2>;
  29. #size-cells = <2>;
  30. ranges;
  31. secure_tfa_ddr: tfa@9e780000 {
  32. reg = <0x00 0x9e780000 0x00 0x80000>;
  33. alignment = <0x1000>;
  34. no-map;
  35. };
  36. secure_ddr: optee@9e800000 {
  37. reg = <0x00 0x9e800000 0x00 0x01800000>; /* for OP-TEE */
  38. alignment = <0x1000>;
  39. no-map;
  40. };
  41. wkup_r5fss0_core0_memory_region: r5f-dma-memory@9c900000 {
  42. compatible = "shared-dma-pool";
  43. reg = <0x00 0x9c900000 0x00 0x01e00000>;
  44. no-map;
  45. };
  46. };
  47. vmain_pd: regulator-0 {
  48. /* TPS25750 PD CONTROLLER OUTPUT */
  49. compatible = "regulator-fixed";
  50. regulator-name = "vmain_pd";
  51. regulator-min-microvolt = <5000000>;
  52. regulator-max-microvolt = <5000000>;
  53. regulator-always-on;
  54. regulator-boot-on;
  55. };
  56. vcc_5v0: regulator-1 {
  57. /* Output of TPS63070 */
  58. compatible = "regulator-fixed";
  59. regulator-name = "vcc_5v0";
  60. regulator-min-microvolt = <5000000>;
  61. regulator-max-microvolt = <5000000>;
  62. vin-supply = <&vmain_pd>;
  63. regulator-always-on;
  64. regulator-boot-on;
  65. };
  66. vcc_3v3_sys: regulator-2 {
  67. /* output of LM5141-Q1 */
  68. compatible = "regulator-fixed";
  69. regulator-name = "vcc_3v3_sys";
  70. regulator-min-microvolt = <3300000>;
  71. regulator-max-microvolt = <3300000>;
  72. vin-supply = <&vmain_pd>;
  73. regulator-always-on;
  74. regulator-boot-on;
  75. };
  76. vdd_mmc1: regulator-3 {
  77. /* TPS22918DBVR */
  78. compatible = "regulator-fixed";
  79. regulator-name = "vdd_mmc1";
  80. regulator-min-microvolt = <3300000>;
  81. regulator-max-microvolt = <3300000>;
  82. regulator-boot-on;
  83. enable-active-high;
  84. gpio = <&exp1 3 GPIO_ACTIVE_HIGH>;
  85. };
  86. leds {
  87. compatible = "gpio-leds";
  88. pinctrl-names = "default";
  89. pinctrl-0 = <&usr_led_pins_default>;
  90. led-0 {
  91. label = "am62a-sk:green:heartbeat";
  92. gpios = <&main_gpio1 49 GPIO_ACTIVE_HIGH>;
  93. linux,default-trigger = "heartbeat";
  94. function = LED_FUNCTION_HEARTBEAT;
  95. default-state = "off";
  96. };
  97. };
  98. };
  99. &main_pmx0 {
  100. main_uart0_pins_default: main-uart0-pins-default {
  101. pinctrl-single,pins = <
  102. AM62AX_IOPAD(0x1c8, PIN_INPUT, 0) /* (D14) UART0_RXD */
  103. AM62AX_IOPAD(0x1cc, PIN_OUTPUT, 0) /* (E14) UART0_TXD */
  104. >;
  105. };
  106. main_i2c0_pins_default: main-i2c0-pins-default {
  107. pinctrl-single,pins = <
  108. AM62AX_IOPAD(0x1e0, PIN_INPUT_PULLUP, 0) /* (B16) I2C0_SCL */
  109. AM62AX_IOPAD(0x1e4, PIN_INPUT_PULLUP, 0) /* (A16) I2C0_SDA */
  110. >;
  111. };
  112. main_i2c1_pins_default: main-i2c1-pins-default {
  113. pinctrl-single,pins = <
  114. AM62AX_IOPAD(0x1e8, PIN_INPUT_PULLUP, 0) /* (B17) I2C1_SCL */
  115. AM62AX_IOPAD(0x1ec, PIN_INPUT_PULLUP, 0) /* (A17) I2C1_SDA */
  116. >;
  117. };
  118. main_i2c2_pins_default: main-i2c2-pins-default {
  119. pinctrl-single,pins = <
  120. AM62AX_IOPAD(0x0b0, PIN_INPUT_PULLUP, 1) /* (K22) GPMC0_CSn2.I2C2_SCL */
  121. AM62AX_IOPAD(0x0b4, PIN_INPUT_PULLUP, 1) /* (K24) GPMC0_CSn3.I2C2_SDA */
  122. >;
  123. };
  124. main_mmc1_pins_default: main-mmc1-pins-default {
  125. pinctrl-single,pins = <
  126. AM62AX_IOPAD(0x23c, PIN_INPUT, 0) /* (A21) MMC1_CMD */
  127. AM62AX_IOPAD(0x234, PIN_INPUT, 0) /* (B22) MMC1_CLK */
  128. AM62AX_IOPAD(0x230, PIN_INPUT, 0) /* (A22) MMC1_DAT0 */
  129. AM62AX_IOPAD(0x22c, PIN_INPUT, 0) /* (B21) MMC1_DAT1 */
  130. AM62AX_IOPAD(0x228, PIN_INPUT, 0) /* (C21) MMC1_DAT2 */
  131. AM62AX_IOPAD(0x224, PIN_INPUT, 0) /* (D22) MMC1_DAT3 */
  132. AM62AX_IOPAD(0x240, PIN_INPUT, 0) /* (D17) MMC1_SDCD */
  133. >;
  134. };
  135. usr_led_pins_default: usr-led-pins-default {
  136. pinctrl-single,pins = <
  137. AM62AX_IOPAD(0x244, PIN_OUTPUT, 7) /* (D18) MMC1_SDWP.GPIO1_49 */
  138. >;
  139. };
  140. };
  141. &main_i2c0 {
  142. status = "okay";
  143. pinctrl-names = "default";
  144. pinctrl-0 = <&main_i2c0_pins_default>;
  145. clock-frequency = <400000>;
  146. };
  147. &main_i2c1 {
  148. status = "okay";
  149. pinctrl-names = "default";
  150. pinctrl-0 = <&main_i2c1_pins_default>;
  151. clock-frequency = <100000>;
  152. exp1: gpio@22 {
  153. compatible = "ti,tca6424";
  154. reg = <0x22>;
  155. gpio-controller;
  156. #gpio-cells = <2>;
  157. gpio-line-names = "GPIO_CPSW2_RST", "GPIO_CPSW1_RST",
  158. "BT_EN_SOC", "MMC1_SD_EN",
  159. "VPP_EN", "EXP_PS_3V3_En",
  160. "EXP_PS_5V0_En", "EXP_HAT_DETECT",
  161. "GPIO_AUD_RSTn", "GPIO_eMMC_RSTn",
  162. "UART1_FET_BUF_EN", "BT_UART_WAKE_SOC",
  163. "GPIO_HDMI_RSTn", "CSI_GPIO0",
  164. "CSI_GPIO1", "WLAN_ALERTn",
  165. "HDMI_INTn", "TEST_GPIO2",
  166. "MCASP1_FET_EN", "MCASP1_BUF_BT_EN",
  167. "MCASP1_FET_SEL", "UART1_FET_SEL",
  168. "PD_I2C_IRQ", "IO_EXP_TEST_LED";
  169. };
  170. };
  171. &sdhci1 {
  172. /* SD/MMC */
  173. status = "okay";
  174. vmmc-supply = <&vdd_mmc1>;
  175. pinctrl-names = "default";
  176. pinctrl-0 = <&main_mmc1_pins_default>;
  177. ti,driver-strength-ohm = <50>;
  178. disable-wp;
  179. };
  180. &main_gpio0 {
  181. status = "okay";
  182. };
  183. &main_gpio1 {
  184. status = "okay";
  185. };
  186. &main_gpio_intr {
  187. status = "okay";
  188. };
  189. &main_uart0 {
  190. status = "okay";
  191. pinctrl-names = "default";
  192. pinctrl-0 = <&main_uart0_pins_default>;
  193. };