am335x-lxm.dts 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2014 NovaTech LLC - https://www.novatechweb.com
  4. */
  5. /dts-v1/;
  6. #include "am33xx.dtsi"
  7. / {
  8. model = "NovaTech OrionLXm";
  9. compatible = "novatech,am335x-lxm", "ti,am33xx";
  10. cpus {
  11. cpu@0 {
  12. cpu0-supply = <&vdd1_reg>;
  13. };
  14. };
  15. memory@80000000 {
  16. device_type = "memory";
  17. reg = <0x80000000 0x20000000>; /* 512 MB */
  18. };
  19. /* Power supply provides a fixed 5V @2A */
  20. vbat: fixedregulator0 {
  21. compatible = "regulator-fixed";
  22. regulator-name = "vbat";
  23. regulator-min-microvolt = <5000000>;
  24. regulator-max-microvolt = <5000000>;
  25. regulator-boot-on;
  26. };
  27. /* Power supply provides a fixed 3.3V @3A */
  28. vmmcsd_fixed: fixedregulator1 {
  29. compatible = "regulator-fixed";
  30. regulator-name = "vmmcsd_fixed";
  31. regulator-min-microvolt = <3300000>;
  32. regulator-max-microvolt = <3300000>;
  33. regulator-boot-on;
  34. };
  35. };
  36. &am33xx_pinmux {
  37. mmc1_pins: pinmux_mmc1_pins {
  38. pinctrl-single,pins = <
  39. AM33XX_PADCONF(AM335X_PIN_MMC0_DAT3, PIN_INPUT_PULLUP, MUX_MODE0)
  40. AM33XX_PADCONF(AM335X_PIN_MMC0_DAT2, PIN_INPUT_PULLUP, MUX_MODE0)
  41. AM33XX_PADCONF(AM335X_PIN_MMC0_DAT1, PIN_INPUT_PULLUP, MUX_MODE0)
  42. AM33XX_PADCONF(AM335X_PIN_MMC0_DAT0, PIN_INPUT_PULLUP, MUX_MODE0)
  43. AM33XX_PADCONF(AM335X_PIN_MMC0_CLK, PIN_INPUT_PULLUP, MUX_MODE0)
  44. AM33XX_PADCONF(AM335X_PIN_MMC0_CMD, PIN_INPUT_PULLUP, MUX_MODE0)
  45. >;
  46. };
  47. i2c0_pins: pinmux_i2c0_pins {
  48. pinctrl-single,pins = <
  49. AM33XX_PADCONF(AM335X_PIN_I2C0_SDA, PIN_INPUT, MUX_MODE0)
  50. AM33XX_PADCONF(AM335X_PIN_I2C0_SCL, PIN_INPUT, MUX_MODE0)
  51. >;
  52. };
  53. cpsw_default: cpsw_default {
  54. pinctrl-single,pins = <
  55. /* Slave 1 */
  56. AM33XX_PADCONF(AM335X_PIN_GPMC_A9, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_int */
  57. AM33XX_PADCONF(AM335X_PIN_MII1_CRS, PIN_INPUT_PULLDOWN, MUX_MODE1) /* rmii1_crs_dv */
  58. AM33XX_PADCONF(AM335X_PIN_MII1_RX_ER, PIN_INPUT_PULLDOWN, MUX_MODE1) /* rmii1_rxer */
  59. AM33XX_PADCONF(AM335X_PIN_MII1_TX_EN, PIN_OUTPUT_PULLDOWN, MUX_MODE1) /* rmii1_txen */
  60. AM33XX_PADCONF(AM335X_PIN_MII1_TXD1, PIN_OUTPUT_PULLDOWN, MUX_MODE1) /* rmii1_td1 */
  61. AM33XX_PADCONF(AM335X_PIN_MII1_TXD0, PIN_OUTPUT_PULLDOWN, MUX_MODE1) /* rmii1_td0 */
  62. AM33XX_PADCONF(AM335X_PIN_MII1_RXD1, PIN_INPUT_PULLDOWN, MUX_MODE1) /* rmii1_rd1 */
  63. AM33XX_PADCONF(AM335X_PIN_MII1_RXD0, PIN_INPUT_PULLDOWN, MUX_MODE1) /* rmii1_rd0 */
  64. AM33XX_PADCONF(AM335X_PIN_RMII1_REF_CLK, PIN_INPUT_PULLDOWN, MUX_MODE0)
  65. /* Slave 2 */
  66. AM33XX_PADCONF(AM335X_PIN_GPMC_A0, PIN_OUTPUT_PULLDOWN, MUX_MODE3) /* rmii2_txen */
  67. AM33XX_PADCONF(AM335X_PIN_GPMC_A4, PIN_OUTPUT_PULLDOWN, MUX_MODE3) /* rmii2_td1 */
  68. AM33XX_PADCONF(AM335X_PIN_GPMC_A5, PIN_OUTPUT_PULLDOWN, MUX_MODE3) /* rmii2_td0 */
  69. AM33XX_PADCONF(AM335X_PIN_GPMC_A10, PIN_INPUT_PULLDOWN, MUX_MODE3) /* rmii2_rd1 */
  70. AM33XX_PADCONF(AM335X_PIN_GPMC_A11, PIN_INPUT_PULLDOWN, MUX_MODE3) /* rmii2_rd0 */
  71. AM33XX_PADCONF(AM335X_PIN_GPMC_WAIT0, PIN_INPUT_PULLDOWN, MUX_MODE3) /* rmii2_crs_dv */
  72. AM33XX_PADCONF(AM335X_PIN_GPMC_WPN, PIN_INPUT_PULLDOWN, MUX_MODE3) /* rmii2_rxer */
  73. AM33XX_PADCONF(AM335X_PIN_GPMC_BEN1, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_int */
  74. AM33XX_PADCONF(AM335X_PIN_MII1_COL, PIN_INPUT_PULLDOWN, MUX_MODE1) /* rmii2_refclk */
  75. >;
  76. };
  77. cpsw_sleep: cpsw_sleep {
  78. pinctrl-single,pins = <
  79. /* Slave 1 reset value */
  80. AM33XX_PADCONF(AM335X_PIN_GPMC_A9, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_int */
  81. AM33XX_PADCONF(AM335X_PIN_MII1_CRS, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_crs_dv */
  82. AM33XX_PADCONF(AM335X_PIN_MII1_RX_ER, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_rxer */
  83. AM33XX_PADCONF(AM335X_PIN_MII1_TX_EN, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_txen */
  84. AM33XX_PADCONF(AM335X_PIN_MII1_TXD1, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_td1 */
  85. AM33XX_PADCONF(AM335X_PIN_MII1_TXD0, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_td0 */
  86. AM33XX_PADCONF(AM335X_PIN_MII1_RXD1, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_rd1 */
  87. AM33XX_PADCONF(AM335X_PIN_MII1_RXD0, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_rd0 */
  88. AM33XX_PADCONF(AM335X_PIN_RMII1_REF_CLK, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii1_refclk */
  89. /* Slave 2 reset value*/
  90. AM33XX_PADCONF(AM335X_PIN_GPMC_A0, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_txen */
  91. AM33XX_PADCONF(AM335X_PIN_GPMC_A4, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_td1 */
  92. AM33XX_PADCONF(AM335X_PIN_GPMC_A5, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_td0 */
  93. AM33XX_PADCONF(AM335X_PIN_GPMC_A10, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_rd1 */
  94. AM33XX_PADCONF(AM335X_PIN_GPMC_A11, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_rd0 */
  95. AM33XX_PADCONF(AM335X_PIN_GPMC_WAIT0, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_crs_dv */
  96. AM33XX_PADCONF(AM335X_PIN_GPMC_WPN, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_rxer */
  97. AM33XX_PADCONF(AM335X_PIN_GPMC_BEN1, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_int */
  98. AM33XX_PADCONF(AM335X_PIN_MII1_COL, PIN_INPUT_PULLDOWN, MUX_MODE7) /* rmii2_refclk */
  99. >;
  100. };
  101. davinci_mdio_default: davinci_mdio_default {
  102. pinctrl-single,pins = <
  103. /* MDIO */
  104. AM33XX_PADCONF(AM335X_PIN_MDIO, PIN_INPUT_PULLUP | SLEWCTRL_FAST, MUX_MODE0)
  105. AM33XX_PADCONF(AM335X_PIN_MDC, PIN_OUTPUT_PULLUP, MUX_MODE0)
  106. >;
  107. };
  108. davinci_mdio_sleep: davinci_mdio_sleep {
  109. pinctrl-single,pins = <
  110. /* MDIO reset value */
  111. AM33XX_PADCONF(AM335X_PIN_MDIO, PIN_INPUT_PULLDOWN, MUX_MODE7)
  112. AM33XX_PADCONF(AM335X_PIN_MDC, PIN_INPUT_PULLDOWN, MUX_MODE7)
  113. >;
  114. };
  115. emmc_pins: pinmux_emmc_pins {
  116. pinctrl-single,pins = <
  117. AM33XX_PADCONF(AM335X_PIN_GPMC_CSN1, PIN_INPUT_PULLUP, MUX_MODE2) /* gpmc_csn1.mmc1_clk */
  118. AM33XX_PADCONF(AM335X_PIN_GPMC_CSN2, PIN_INPUT_PULLUP, MUX_MODE2) /* gpmc_csn2.mmc1_cmd */
  119. AM33XX_PADCONF(AM335X_PIN_GPMC_AD0, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad0.mmc1_dat0 */
  120. AM33XX_PADCONF(AM335X_PIN_GPMC_AD1, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad1.mmc1_dat1 */
  121. AM33XX_PADCONF(AM335X_PIN_GPMC_AD2, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad2.mmc1_dat2 */
  122. AM33XX_PADCONF(AM335X_PIN_GPMC_AD3, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad3.mmc1_dat3 */
  123. AM33XX_PADCONF(AM335X_PIN_GPMC_AD4, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad4.mmc1_dat4 */
  124. AM33XX_PADCONF(AM335X_PIN_GPMC_AD5, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad5.mmc1_dat5 */
  125. AM33XX_PADCONF(AM335X_PIN_GPMC_AD6, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad6.mmc1_dat6 */
  126. AM33XX_PADCONF(AM335X_PIN_GPMC_AD7, PIN_INPUT_PULLUP, MUX_MODE1) /* gpmc_ad7.mmc1_dat7 */
  127. >;
  128. };
  129. uart0_pins: pinmux_uart0_pins {
  130. pinctrl-single,pins = <
  131. AM33XX_PADCONF(AM335X_PIN_UART0_RXD, PIN_INPUT_PULLUP, MUX_MODE0)
  132. AM33XX_PADCONF(AM335X_PIN_UART0_TXD, PIN_OUTPUT_PULLDOWN, MUX_MODE0)
  133. >;
  134. };
  135. };
  136. &i2c0 {
  137. pinctrl-names = "default";
  138. pinctrl-0 = <&i2c0_pins>;
  139. status = "okay";
  140. clock-frequency = <400000>;
  141. serial_config1: serial_config1@20 {
  142. compatible = "nxp,pca9539";
  143. reg = <0x20>;
  144. gpio-controller;
  145. #gpio-cells = <2>;
  146. };
  147. serial_config2: serial_config2@21 {
  148. compatible = "nxp,pca9539";
  149. reg = <0x21>;
  150. gpio-controller;
  151. #gpio-cells = <2>;
  152. };
  153. tps: tps@2d {
  154. compatible = "ti,tps65910";
  155. reg = <0x2d>;
  156. };
  157. };
  158. /include/ "tps65910.dtsi"
  159. &tps {
  160. vcc1-supply = <&vbat>;
  161. vcc2-supply = <&vbat>;
  162. vcc3-supply = <&vbat>;
  163. vcc4-supply = <&vbat>;
  164. vcc5-supply = <&vbat>;
  165. vcc6-supply = <&vbat>;
  166. vcc7-supply = <&vbat>;
  167. vccio-supply = <&vbat>;
  168. regulators {
  169. /* vrtc - unused */
  170. vio_reg: regulator@1 {
  171. regulator-name = "vio_1v5,ddr";
  172. regulator-min-microvolt = <1500000>;
  173. regulator-max-microvolt = <1500000>;
  174. regulator-boot-on;
  175. regulator-always-on;
  176. };
  177. vdd1_reg: regulator@2 {
  178. regulator-name = "vdd1,mpu";
  179. regulator-min-microvolt = <600000>;
  180. regulator-max-microvolt = <1500000>;
  181. regulator-boot-on;
  182. regulator-always-on;
  183. };
  184. vdd2_reg: regulator@3 {
  185. regulator-name = "vdd2_1v1,core";
  186. regulator-min-microvolt = <1100000>;
  187. regulator-max-microvolt = <1100000>;
  188. regulator-boot-on;
  189. regulator-always-on;
  190. };
  191. /* vdd3 - unused */
  192. /* vdig1 - unused */
  193. vdig2_reg: regulator@6 {
  194. regulator-name = "vdig2_1v8,vdds_pll";
  195. regulator-min-microvolt = <1800000>;
  196. regulator-max-microvolt = <1800000>;
  197. regulator-boot-on;
  198. regulator-always-on;
  199. };
  200. /* vpll - unused */
  201. vdac_reg: regulator@8 {
  202. regulator-name = "vdac_1v8,vdds";
  203. regulator-min-microvolt = <1800000>;
  204. regulator-max-microvolt = <1800000>;
  205. regulator-boot-on;
  206. regulator-always-on;
  207. };
  208. vaux1_reg: regulator@9 {
  209. regulator-name = "vaux1_1v8,usb";
  210. regulator-min-microvolt = <1800000>;
  211. regulator-max-microvolt = <1800000>;
  212. regulator-boot-on;
  213. regulator-always-on;
  214. };
  215. vaux2_reg: regulator@10 {
  216. regulator-name = "vaux2_3v3,io";
  217. regulator-min-microvolt = <3300000>;
  218. regulator-max-microvolt = <3300000>;
  219. regulator-boot-on;
  220. regulator-always-on;
  221. };
  222. vaux33_reg: regulator@11 {
  223. regulator-name = "vaux33_3v3,usb";
  224. regulator-min-microvolt = <3300000>;
  225. regulator-max-microvolt = <3300000>;
  226. regulator-boot-on;
  227. regulator-always-on;
  228. };
  229. vmmc_reg: regulator@12 {
  230. regulator-name = "vmmc_3v3,io";
  231. regulator-min-microvolt = <3300000>;
  232. regulator-max-microvolt = <3300000>;
  233. regulator-boot-on;
  234. regulator-always-on;
  235. };
  236. };
  237. };
  238. &sham {
  239. status = "okay";
  240. };
  241. &aes {
  242. status = "okay";
  243. };
  244. &uart0 {
  245. pinctrl-names = "default";
  246. pinctrl-0 = <&uart0_pins>;
  247. status = "okay";
  248. };
  249. &usb0 {
  250. dr_mode = "host";
  251. };
  252. &usb1 {
  253. dr_mode = "host";
  254. };
  255. &cpsw_port1 {
  256. phy-handle = <&ethphy0>;
  257. phy-mode = "rmii";
  258. ti,dual-emac-pvid = <2>;
  259. };
  260. &cpsw_port2 {
  261. phy-handle = <&ethphy1>;
  262. phy-mode = "rmii";
  263. ti,dual-emac-pvid = <3>;
  264. };
  265. &mac_sw {
  266. pinctrl-names = "default", "sleep";
  267. pinctrl-0 = <&cpsw_default>;
  268. pinctrl-1 = <&cpsw_sleep>;
  269. status = "okay";
  270. };
  271. &davinci_mdio_sw {
  272. pinctrl-names = "default", "sleep";
  273. pinctrl-0 = <&davinci_mdio_default>;
  274. pinctrl-1 = <&davinci_mdio_sleep>;
  275. ethphy0: ethernet-phy@5 {
  276. reg = <5>;
  277. };
  278. ethphy1: ethernet-phy@4 {
  279. reg = <4>;
  280. };
  281. };
  282. &mmc1 {
  283. pinctrl-names = "default";
  284. pinctrl-0 = <&mmc1_pins>;
  285. vmmc-supply = <&vmmcsd_fixed>;
  286. bus-width = <4>;
  287. status = "okay";
  288. };
  289. &mmc2 {
  290. pinctrl-names = "default";
  291. pinctrl-0 = <&emmc_pins>;
  292. vmmc-supply = <&vmmcsd_fixed>;
  293. bus-width = <8>;
  294. non-removable;
  295. status = "okay";
  296. };