am335x-evmsk.dts 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720
  1. /*
  2. * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. */
  8. /*
  9. * AM335x Starter Kit
  10. * http://www.ti.com/tool/tmdssk3358
  11. */
  12. /dts-v1/;
  13. #include "am33xx.dtsi"
  14. #include <dt-bindings/pwm/pwm.h>
  15. #include <dt-bindings/interrupt-controller/irq.h>
  16. / {
  17. model = "TI AM335x EVM-SK";
  18. compatible = "ti,am335x-evmsk", "ti,am33xx";
  19. chosen {
  20. stdout-path = &uart0;
  21. tick-timer = &timer2;
  22. };
  23. cpus {
  24. cpu@0 {
  25. cpu0-supply = <&vdd1_reg>;
  26. };
  27. };
  28. memory {
  29. device_type = "memory";
  30. reg = <0x80000000 0x10000000>; /* 256 MB */
  31. };
  32. vbat: fixedregulator@0 {
  33. compatible = "regulator-fixed";
  34. regulator-name = "vbat";
  35. regulator-min-microvolt = <5000000>;
  36. regulator-max-microvolt = <5000000>;
  37. regulator-boot-on;
  38. };
  39. lis3_reg: fixedregulator@1 {
  40. compatible = "regulator-fixed";
  41. regulator-name = "lis3_reg";
  42. regulator-boot-on;
  43. };
  44. wl12xx_vmmc: fixedregulator@2 {
  45. pinctrl-names = "default";
  46. pinctrl-0 = <&wl12xx_gpio>;
  47. compatible = "regulator-fixed";
  48. regulator-name = "vwl1271";
  49. regulator-min-microvolt = <1800000>;
  50. regulator-max-microvolt = <1800000>;
  51. gpio = <&gpio1 29 0>;
  52. startup-delay-us = <70000>;
  53. enable-active-high;
  54. };
  55. vtt_fixed: fixedregulator@3 {
  56. compatible = "regulator-fixed";
  57. regulator-name = "vtt";
  58. regulator-min-microvolt = <1500000>;
  59. regulator-max-microvolt = <1500000>;
  60. gpio = <&gpio0 7 GPIO_ACTIVE_HIGH>;
  61. regulator-always-on;
  62. regulator-boot-on;
  63. enable-active-high;
  64. };
  65. leds {
  66. pinctrl-names = "default";
  67. pinctrl-0 = <&user_leds_s0>;
  68. compatible = "gpio-leds";
  69. led@1 {
  70. label = "evmsk:green:usr0";
  71. gpios = <&gpio1 4 GPIO_ACTIVE_HIGH>;
  72. default-state = "off";
  73. };
  74. led@2 {
  75. label = "evmsk:green:usr1";
  76. gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
  77. default-state = "off";
  78. };
  79. led@3 {
  80. label = "evmsk:green:mmc0";
  81. gpios = <&gpio1 6 GPIO_ACTIVE_HIGH>;
  82. linux,default-trigger = "mmc0";
  83. default-state = "off";
  84. };
  85. led@4 {
  86. label = "evmsk:green:heartbeat";
  87. gpios = <&gpio1 7 GPIO_ACTIVE_HIGH>;
  88. linux,default-trigger = "heartbeat";
  89. default-state = "off";
  90. };
  91. };
  92. gpio_buttons: gpio_buttons@0 {
  93. compatible = "gpio-keys";
  94. #address-cells = <1>;
  95. #size-cells = <0>;
  96. switch@1 {
  97. label = "button0";
  98. linux,code = <0x100>;
  99. gpios = <&gpio2 3 GPIO_ACTIVE_HIGH>;
  100. };
  101. switch@2 {
  102. label = "button1";
  103. linux,code = <0x101>;
  104. gpios = <&gpio2 2 GPIO_ACTIVE_HIGH>;
  105. };
  106. switch@3 {
  107. label = "button2";
  108. linux,code = <0x102>;
  109. gpios = <&gpio0 30 GPIO_ACTIVE_HIGH>;
  110. wakeup-source;
  111. };
  112. switch@4 {
  113. label = "button3";
  114. linux,code = <0x103>;
  115. gpios = <&gpio2 5 GPIO_ACTIVE_HIGH>;
  116. };
  117. };
  118. backlight {
  119. compatible = "pwm-backlight";
  120. pwms = <&ecap2 0 50000 PWM_POLARITY_INVERTED>;
  121. brightness-levels = <0 58 61 66 75 90 125 170 255>;
  122. default-brightness-level = <8>;
  123. };
  124. sound {
  125. compatible = "simple-audio-card";
  126. simple-audio-card,name = "AM335x-EVMSK";
  127. simple-audio-card,widgets =
  128. "Headphone", "Headphone Jack";
  129. simple-audio-card,routing =
  130. "Headphone Jack", "HPLOUT",
  131. "Headphone Jack", "HPROUT";
  132. simple-audio-card,format = "dsp_b";
  133. simple-audio-card,bitclock-master = <&sound_master>;
  134. simple-audio-card,frame-master = <&sound_master>;
  135. simple-audio-card,bitclock-inversion;
  136. simple-audio-card,cpu {
  137. sound-dai = <&mcasp1>;
  138. };
  139. sound_master: simple-audio-card,codec {
  140. sound-dai = <&tlv320aic3106>;
  141. system-clock-frequency = <24000000>;
  142. };
  143. };
  144. panel {
  145. compatible = "ti,tilcdc,panel";
  146. pinctrl-names = "default", "sleep";
  147. pinctrl-0 = <&lcd_pins_default>;
  148. pinctrl-1 = <&lcd_pins_sleep>;
  149. status = "okay";
  150. panel-info {
  151. ac-bias = <255>;
  152. ac-bias-intrpt = <0>;
  153. dma-burst-sz = <16>;
  154. bpp = <32>;
  155. fdd = <0x80>;
  156. sync-edge = <0>;
  157. sync-ctrl = <1>;
  158. raster-order = <0>;
  159. fifo-th = <0>;
  160. };
  161. display-timings {
  162. 480x272 {
  163. hactive = <480>;
  164. vactive = <272>;
  165. hback-porch = <43>;
  166. hfront-porch = <8>;
  167. hsync-len = <4>;
  168. vback-porch = <12>;
  169. vfront-porch = <4>;
  170. vsync-len = <10>;
  171. clock-frequency = <9000000>;
  172. hsync-active = <0>;
  173. vsync-active = <0>;
  174. };
  175. };
  176. };
  177. };
  178. &am33xx_pinmux {
  179. pinctrl-names = "default";
  180. pinctrl-0 = <&gpio_keys_s0 &clkout2_pin>;
  181. lcd_pins_default: lcd_pins_default {
  182. pinctrl-single,pins = <
  183. AM33XX_IOPAD(0x820, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad8.lcd_data23 */
  184. AM33XX_IOPAD(0x824, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad9.lcd_data22 */
  185. AM33XX_IOPAD(0x828, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad10.lcd_data21 */
  186. AM33XX_IOPAD(0x82c, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad11.lcd_data20 */
  187. AM33XX_IOPAD(0x830, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad12.lcd_data19 */
  188. AM33XX_IOPAD(0x834, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad13.lcd_data18 */
  189. AM33XX_IOPAD(0x838, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad14.lcd_data17 */
  190. AM33XX_IOPAD(0x83c, PIN_OUTPUT | MUX_MODE1) /* gpmc_ad15.lcd_data16 */
  191. AM33XX_IOPAD(0x8a0, PIN_OUTPUT | MUX_MODE0) /* lcd_data0.lcd_data0 */
  192. AM33XX_IOPAD(0x8a4, PIN_OUTPUT | MUX_MODE0) /* lcd_data1.lcd_data1 */
  193. AM33XX_IOPAD(0x8a8, PIN_OUTPUT | MUX_MODE0) /* lcd_data2.lcd_data2 */
  194. AM33XX_IOPAD(0x8ac, PIN_OUTPUT | MUX_MODE0) /* lcd_data3.lcd_data3 */
  195. AM33XX_IOPAD(0x8b0, PIN_OUTPUT | MUX_MODE0) /* lcd_data4.lcd_data4 */
  196. AM33XX_IOPAD(0x8b4, PIN_OUTPUT | MUX_MODE0) /* lcd_data5.lcd_data5 */
  197. AM33XX_IOPAD(0x8b8, PIN_OUTPUT | MUX_MODE0) /* lcd_data6.lcd_data6 */
  198. AM33XX_IOPAD(0x8bc, PIN_OUTPUT | MUX_MODE0) /* lcd_data7.lcd_data7 */
  199. AM33XX_IOPAD(0x8c0, PIN_OUTPUT | MUX_MODE0) /* lcd_data8.lcd_data8 */
  200. AM33XX_IOPAD(0x8c4, PIN_OUTPUT | MUX_MODE0) /* lcd_data9.lcd_data9 */
  201. AM33XX_IOPAD(0x8c8, PIN_OUTPUT | MUX_MODE0) /* lcd_data10.lcd_data10 */
  202. AM33XX_IOPAD(0x8cc, PIN_OUTPUT | MUX_MODE0) /* lcd_data11.lcd_data11 */
  203. AM33XX_IOPAD(0x8d0, PIN_OUTPUT | MUX_MODE0) /* lcd_data12.lcd_data12 */
  204. AM33XX_IOPAD(0x8d4, PIN_OUTPUT | MUX_MODE0) /* lcd_data13.lcd_data13 */
  205. AM33XX_IOPAD(0x8d8, PIN_OUTPUT | MUX_MODE0) /* lcd_data14.lcd_data14 */
  206. AM33XX_IOPAD(0x8dc, PIN_OUTPUT | MUX_MODE0) /* lcd_data15.lcd_data15 */
  207. AM33XX_IOPAD(0x8e0, PIN_OUTPUT | MUX_MODE0) /* lcd_vsync.lcd_vsync */
  208. AM33XX_IOPAD(0x8e4, PIN_OUTPUT | MUX_MODE0) /* lcd_hsync.lcd_hsync */
  209. AM33XX_IOPAD(0x8e8, PIN_OUTPUT | MUX_MODE0) /* lcd_pclk.lcd_pclk */
  210. AM33XX_IOPAD(0x8ec, PIN_OUTPUT | MUX_MODE0) /* lcd_ac_bias_en.lcd_ac_bias_en */
  211. >;
  212. };
  213. lcd_pins_sleep: lcd_pins_sleep {
  214. pinctrl-single,pins = <
  215. AM33XX_IOPAD(0x820, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad8.lcd_data23 */
  216. AM33XX_IOPAD(0x824, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad9.lcd_data22 */
  217. AM33XX_IOPAD(0x828, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad10.lcd_data21 */
  218. AM33XX_IOPAD(0x82c, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad11.lcd_data20 */
  219. AM33XX_IOPAD(0x830, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad12.lcd_data19 */
  220. AM33XX_IOPAD(0x834, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad13.lcd_data18 */
  221. AM33XX_IOPAD(0x838, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad14.lcd_data17 */
  222. AM33XX_IOPAD(0x83c, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad15.lcd_data16 */
  223. AM33XX_IOPAD(0x8a0, PULL_DISABLE | MUX_MODE7) /* lcd_data0.lcd_data0 */
  224. AM33XX_IOPAD(0x8a4, PULL_DISABLE | MUX_MODE7) /* lcd_data1.lcd_data1 */
  225. AM33XX_IOPAD(0x8a8, PULL_DISABLE | MUX_MODE7) /* lcd_data2.lcd_data2 */
  226. AM33XX_IOPAD(0x8ac, PULL_DISABLE | MUX_MODE7) /* lcd_data3.lcd_data3 */
  227. AM33XX_IOPAD(0x8b0, PULL_DISABLE | MUX_MODE7) /* lcd_data4.lcd_data4 */
  228. AM33XX_IOPAD(0x8b4, PULL_DISABLE | MUX_MODE7) /* lcd_data5.lcd_data5 */
  229. AM33XX_IOPAD(0x8b8, PULL_DISABLE | MUX_MODE7) /* lcd_data6.lcd_data6 */
  230. AM33XX_IOPAD(0x8bc, PULL_DISABLE | MUX_MODE7) /* lcd_data7.lcd_data7 */
  231. AM33XX_IOPAD(0x8c0, PULL_DISABLE | MUX_MODE7) /* lcd_data8.lcd_data8 */
  232. AM33XX_IOPAD(0x8c4, PULL_DISABLE | MUX_MODE7) /* lcd_data9.lcd_data9 */
  233. AM33XX_IOPAD(0x8c8, PULL_DISABLE | MUX_MODE7) /* lcd_data10.lcd_data10 */
  234. AM33XX_IOPAD(0x8cc, PULL_DISABLE | MUX_MODE7) /* lcd_data11.lcd_data11 */
  235. AM33XX_IOPAD(0x8d0, PULL_DISABLE | MUX_MODE7) /* lcd_data12.lcd_data12 */
  236. AM33XX_IOPAD(0x8d4, PULL_DISABLE | MUX_MODE7) /* lcd_data13.lcd_data13 */
  237. AM33XX_IOPAD(0x8d8, PULL_DISABLE | MUX_MODE7) /* lcd_data14.lcd_data14 */
  238. AM33XX_IOPAD(0x8dc, PULL_DISABLE | MUX_MODE7) /* lcd_data15.lcd_data15 */
  239. AM33XX_IOPAD(0x8e0, PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_vsync.lcd_vsync */
  240. AM33XX_IOPAD(0x8e4, PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_hsync.lcd_hsync */
  241. AM33XX_IOPAD(0x8e8, PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_pclk.lcd_pclk */
  242. AM33XX_IOPAD(0x8ec, PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_ac_bias_en.lcd_ac_bias_en */
  243. >;
  244. };
  245. user_leds_s0: user_leds_s0 {
  246. pinctrl-single,pins = <
  247. AM33XX_IOPAD(0x810, PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad4.gpio1_4 */
  248. AM33XX_IOPAD(0x814, PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad5.gpio1_5 */
  249. AM33XX_IOPAD(0x818, PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad6.gpio1_6 */
  250. AM33XX_IOPAD(0x81c, PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad7.gpio1_7 */
  251. >;
  252. };
  253. gpio_keys_s0: gpio_keys_s0 {
  254. pinctrl-single,pins = <
  255. AM33XX_IOPAD(0x894, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_oen_ren.gpio2_3 */
  256. AM33XX_IOPAD(0x890, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_advn_ale.gpio2_2 */
  257. AM33XX_IOPAD(0x870, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_wait0.gpio0_30 */
  258. AM33XX_IOPAD(0x89c, PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ben0_cle.gpio2_5 */
  259. >;
  260. };
  261. i2c0_pins: pinmux_i2c0_pins {
  262. pinctrl-single,pins = <
  263. AM33XX_IOPAD(0x988, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c0_sda.i2c0_sda */
  264. AM33XX_IOPAD(0x98c, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c0_scl.i2c0_scl */
  265. >;
  266. };
  267. uart0_pins: pinmux_uart0_pins {
  268. pinctrl-single,pins = <
  269. AM33XX_IOPAD(0x970, PIN_INPUT_PULLUP | MUX_MODE0) /* uart0_rxd.uart0_rxd */
  270. AM33XX_IOPAD(0x974, PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* uart0_txd.uart0_txd */
  271. >;
  272. };
  273. clkout2_pin: pinmux_clkout2_pin {
  274. pinctrl-single,pins = <
  275. AM33XX_IOPAD(0x9b4, PIN_OUTPUT_PULLDOWN | MUX_MODE3) /* xdma_event_intr1.clkout2 */
  276. >;
  277. };
  278. ecap2_pins: backlight_pins {
  279. pinctrl-single,pins = <
  280. AM33XX_IOPAD(0x99c, MUX_MODE4) /* mcasp0_ahclkr.ecap2_in_pwm2_out */
  281. >;
  282. };
  283. cpsw_default: cpsw_default {
  284. pinctrl-single,pins = <
  285. /* Slave 1 */
  286. AM33XX_IOPAD(0x914, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txen.rgmii1_tctl */
  287. AM33XX_IOPAD(0x918, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxdv.rgmii1_rctl */
  288. AM33XX_IOPAD(0x91c, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd3.rgmii1_td3 */
  289. AM33XX_IOPAD(0x920, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd2.rgmii1_td2 */
  290. AM33XX_IOPAD(0x924, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd1.rgmii1_td1 */
  291. AM33XX_IOPAD(0x928, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd0.rgmii1_td0 */
  292. AM33XX_IOPAD(0x92c, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txclk.rgmii1_tclk */
  293. AM33XX_IOPAD(0x930, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxclk.rgmii1_rclk */
  294. AM33XX_IOPAD(0x934, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd3.rgmii1_rd3 */
  295. AM33XX_IOPAD(0x938, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd2.rgmii1_rd2 */
  296. AM33XX_IOPAD(0x93c, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd1.rgmii1_rd1 */
  297. AM33XX_IOPAD(0x940, PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd0.rgmii1_rd0 */
  298. /* Slave 2 */
  299. AM33XX_IOPAD(0x840, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a0.rgmii2_tctl */
  300. AM33XX_IOPAD(0x844, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a1.rgmii2_rctl */
  301. AM33XX_IOPAD(0x848, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a2.rgmii2_td3 */
  302. AM33XX_IOPAD(0x84c, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a3.rgmii2_td2 */
  303. AM33XX_IOPAD(0x850, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a4.rgmii2_td1 */
  304. AM33XX_IOPAD(0x854, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a5.rgmii2_td0 */
  305. AM33XX_IOPAD(0x858, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a6.rgmii2_tclk */
  306. AM33XX_IOPAD(0x85c, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a7.rgmii2_rclk */
  307. AM33XX_IOPAD(0x860, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a8.rgmii2_rd3 */
  308. AM33XX_IOPAD(0x864, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a9.rgmii2_rd2 */
  309. AM33XX_IOPAD(0x868, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a10.rgmii2_rd1 */
  310. AM33XX_IOPAD(0x86c, PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a11.rgmii2_rd0 */
  311. >;
  312. };
  313. cpsw_sleep: cpsw_sleep {
  314. pinctrl-single,pins = <
  315. /* Slave 1 reset value */
  316. AM33XX_IOPAD(0x914, PIN_INPUT_PULLDOWN | MUX_MODE7)
  317. AM33XX_IOPAD(0x918, PIN_INPUT_PULLDOWN | MUX_MODE7)
  318. AM33XX_IOPAD(0x91c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  319. AM33XX_IOPAD(0x920, PIN_INPUT_PULLDOWN | MUX_MODE7)
  320. AM33XX_IOPAD(0x924, PIN_INPUT_PULLDOWN | MUX_MODE7)
  321. AM33XX_IOPAD(0x928, PIN_INPUT_PULLDOWN | MUX_MODE7)
  322. AM33XX_IOPAD(0x92c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  323. AM33XX_IOPAD(0x930, PIN_INPUT_PULLDOWN | MUX_MODE7)
  324. AM33XX_IOPAD(0x934, PIN_INPUT_PULLDOWN | MUX_MODE7)
  325. AM33XX_IOPAD(0x938, PIN_INPUT_PULLDOWN | MUX_MODE7)
  326. AM33XX_IOPAD(0x93c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  327. AM33XX_IOPAD(0x940, PIN_INPUT_PULLDOWN | MUX_MODE7)
  328. /* Slave 2 reset value*/
  329. AM33XX_IOPAD(0x840, PIN_INPUT_PULLDOWN | MUX_MODE7)
  330. AM33XX_IOPAD(0x844, PIN_INPUT_PULLDOWN | MUX_MODE7)
  331. AM33XX_IOPAD(0x848, PIN_INPUT_PULLDOWN | MUX_MODE7)
  332. AM33XX_IOPAD(0x84c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  333. AM33XX_IOPAD(0x850, PIN_INPUT_PULLDOWN | MUX_MODE7)
  334. AM33XX_IOPAD(0x854, PIN_INPUT_PULLDOWN | MUX_MODE7)
  335. AM33XX_IOPAD(0x858, PIN_INPUT_PULLDOWN | MUX_MODE7)
  336. AM33XX_IOPAD(0x85c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  337. AM33XX_IOPAD(0x860, PIN_INPUT_PULLDOWN | MUX_MODE7)
  338. AM33XX_IOPAD(0x864, PIN_INPUT_PULLDOWN | MUX_MODE7)
  339. AM33XX_IOPAD(0x868, PIN_INPUT_PULLDOWN | MUX_MODE7)
  340. AM33XX_IOPAD(0x86c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  341. >;
  342. };
  343. davinci_mdio_default: davinci_mdio_default {
  344. pinctrl-single,pins = <
  345. /* MDIO */
  346. AM33XX_IOPAD(0x948, PIN_INPUT_PULLUP | SLEWCTRL_FAST | MUX_MODE0) /* mdio_data.mdio_data */
  347. AM33XX_IOPAD(0x94c, PIN_OUTPUT_PULLUP | MUX_MODE0) /* mdio_clk.mdio_clk */
  348. >;
  349. };
  350. davinci_mdio_sleep: davinci_mdio_sleep {
  351. pinctrl-single,pins = <
  352. /* MDIO reset value */
  353. AM33XX_IOPAD(0x948, PIN_INPUT_PULLDOWN | MUX_MODE7)
  354. AM33XX_IOPAD(0x94c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  355. >;
  356. };
  357. mmc1_pins: pinmux_mmc1_pins {
  358. pinctrl-single,pins = <
  359. AM33XX_IOPAD(0x960, PIN_INPUT | MUX_MODE7) /* spi0_cs1.gpio0_6 */
  360. >;
  361. };
  362. mcasp1_pins: mcasp1_pins {
  363. pinctrl-single,pins = <
  364. AM33XX_IOPAD(0x90c, PIN_INPUT_PULLDOWN | MUX_MODE4) /* mii1_crs.mcasp1_aclkx */
  365. AM33XX_IOPAD(0x910, PIN_INPUT_PULLDOWN | MUX_MODE4) /* mii1_rxerr.mcasp1_fsx */
  366. AM33XX_IOPAD(0x908, PIN_OUTPUT_PULLDOWN | MUX_MODE4) /* mii1_col.mcasp1_axr2 */
  367. AM33XX_IOPAD(0x944, PIN_INPUT_PULLDOWN | MUX_MODE4) /* rmii1_ref_clk.mcasp1_axr3 */
  368. >;
  369. };
  370. mcasp1_pins_sleep: mcasp1_pins_sleep {
  371. pinctrl-single,pins = <
  372. AM33XX_IOPAD(0x90c, PIN_INPUT_PULLDOWN | MUX_MODE7)
  373. AM33XX_IOPAD(0x910, PIN_INPUT_PULLDOWN | MUX_MODE7)
  374. AM33XX_IOPAD(0x908, PIN_INPUT_PULLDOWN | MUX_MODE7)
  375. AM33XX_IOPAD(0x944, PIN_INPUT_PULLDOWN | MUX_MODE7)
  376. >;
  377. };
  378. mmc2_pins: pinmux_mmc2_pins {
  379. pinctrl-single,pins = <
  380. AM33XX_IOPAD(0x874, PIN_INPUT_PULLUP | MUX_MODE7) /* gpmc_wpn.gpio0_31 */
  381. AM33XX_IOPAD(0x880, PIN_INPUT_PULLUP | MUX_MODE2) /* gpmc_csn1.mmc1_clk */
  382. AM33XX_IOPAD(0x884, PIN_INPUT_PULLUP | MUX_MODE2) /* gpmc_csn2.mmc1_cmd */
  383. AM33XX_IOPAD(0x800, PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad0.mmc1_dat0 */
  384. AM33XX_IOPAD(0x804, PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad1.mmc1_dat1 */
  385. AM33XX_IOPAD(0x808, PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad2.mmc1_dat2 */
  386. AM33XX_IOPAD(0x80c, PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad3.mmc1_dat3 */
  387. >;
  388. };
  389. wl12xx_gpio: pinmux_wl12xx_gpio {
  390. pinctrl-single,pins = <
  391. AM33XX_IOPAD(0x87c, PIN_OUTPUT_PULLUP | MUX_MODE7) /* gpmc_csn0.gpio1_29 */
  392. >;
  393. };
  394. };
  395. &uart0 {
  396. pinctrl-names = "default";
  397. pinctrl-0 = <&uart0_pins>;
  398. status = "okay";
  399. };
  400. &i2c0 {
  401. pinctrl-names = "default";
  402. pinctrl-0 = <&i2c0_pins>;
  403. status = "okay";
  404. clock-frequency = <400000>;
  405. tps: tps@2d {
  406. reg = <0x2d>;
  407. };
  408. lis331dlh: lis331dlh@18 {
  409. compatible = "st,lis331dlh", "st,lis3lv02d";
  410. reg = <0x18>;
  411. Vdd-supply = <&lis3_reg>;
  412. Vdd_IO-supply = <&lis3_reg>;
  413. st,click-single-x;
  414. st,click-single-y;
  415. st,click-single-z;
  416. st,click-thresh-x = <10>;
  417. st,click-thresh-y = <10>;
  418. st,click-thresh-z = <10>;
  419. st,irq1-click;
  420. st,irq2-click;
  421. st,wakeup-x-lo;
  422. st,wakeup-x-hi;
  423. st,wakeup-y-lo;
  424. st,wakeup-y-hi;
  425. st,wakeup-z-lo;
  426. st,wakeup-z-hi;
  427. st,min-limit-x = <120>;
  428. st,min-limit-y = <120>;
  429. st,min-limit-z = <140>;
  430. st,max-limit-x = <550>;
  431. st,max-limit-y = <550>;
  432. st,max-limit-z = <750>;
  433. };
  434. tlv320aic3106: tlv320aic3106@1b {
  435. #sound-dai-cells = <0>;
  436. compatible = "ti,tlv320aic3106";
  437. reg = <0x1b>;
  438. status = "okay";
  439. /* Regulators */
  440. AVDD-supply = <&vaux2_reg>;
  441. IOVDD-supply = <&vaux2_reg>;
  442. DRVDD-supply = <&vaux2_reg>;
  443. DVDD-supply = <&vbat>;
  444. };
  445. };
  446. &usb {
  447. status = "okay";
  448. };
  449. &usb_ctrl_mod {
  450. status = "okay";
  451. };
  452. &usb0_phy {
  453. status = "okay";
  454. };
  455. &usb1_phy {
  456. status = "okay";
  457. };
  458. &usb0 {
  459. status = "okay";
  460. };
  461. &usb1 {
  462. status = "okay";
  463. dr_mode = "host";
  464. };
  465. &cppi41dma {
  466. status = "okay";
  467. };
  468. &epwmss2 {
  469. status = "okay";
  470. ecap2: ecap@48304100 {
  471. status = "okay";
  472. pinctrl-names = "default";
  473. pinctrl-0 = <&ecap2_pins>;
  474. };
  475. };
  476. #include "tps65910.dtsi"
  477. &tps {
  478. vcc1-supply = <&vbat>;
  479. vcc2-supply = <&vbat>;
  480. vcc3-supply = <&vbat>;
  481. vcc4-supply = <&vbat>;
  482. vcc5-supply = <&vbat>;
  483. vcc6-supply = <&vbat>;
  484. vcc7-supply = <&vbat>;
  485. vccio-supply = <&vbat>;
  486. regulators {
  487. vrtc_reg: regulator@0 {
  488. regulator-always-on;
  489. };
  490. vio_reg: regulator@1 {
  491. regulator-always-on;
  492. };
  493. vdd1_reg: regulator@2 {
  494. /* VDD_MPU voltage limits 0.95V - 1.26V with +/-4% tolerance */
  495. regulator-name = "vdd_mpu";
  496. regulator-min-microvolt = <912500>;
  497. regulator-max-microvolt = <1312500>;
  498. regulator-boot-on;
  499. regulator-always-on;
  500. };
  501. vdd2_reg: regulator@3 {
  502. /* VDD_CORE voltage limits 0.95V - 1.1V with +/-4% tolerance */
  503. regulator-name = "vdd_core";
  504. regulator-min-microvolt = <912500>;
  505. regulator-max-microvolt = <1150000>;
  506. regulator-boot-on;
  507. regulator-always-on;
  508. };
  509. vdd3_reg: regulator@4 {
  510. regulator-always-on;
  511. };
  512. vdig1_reg: regulator@5 {
  513. regulator-always-on;
  514. };
  515. vdig2_reg: regulator@6 {
  516. regulator-always-on;
  517. };
  518. vpll_reg: regulator@7 {
  519. regulator-always-on;
  520. };
  521. vdac_reg: regulator@8 {
  522. regulator-always-on;
  523. };
  524. vaux1_reg: regulator@9 {
  525. regulator-always-on;
  526. };
  527. vaux2_reg: regulator@10 {
  528. regulator-always-on;
  529. };
  530. vaux33_reg: regulator@11 {
  531. regulator-always-on;
  532. };
  533. vmmc_reg: regulator@12 {
  534. regulator-min-microvolt = <1800000>;
  535. regulator-max-microvolt = <3300000>;
  536. regulator-always-on;
  537. };
  538. };
  539. };
  540. &mac {
  541. pinctrl-names = "default", "sleep";
  542. pinctrl-0 = <&cpsw_default>;
  543. pinctrl-1 = <&cpsw_sleep>;
  544. dual_emac = <1>;
  545. status = "okay";
  546. };
  547. &davinci_mdio {
  548. pinctrl-names = "default", "sleep";
  549. pinctrl-0 = <&davinci_mdio_default>;
  550. pinctrl-1 = <&davinci_mdio_sleep>;
  551. status = "okay";
  552. };
  553. &cpsw_emac0 {
  554. phy_id = <&davinci_mdio>, <0>;
  555. phy-mode = "rgmii-txid";
  556. dual_emac_res_vlan = <1>;
  557. };
  558. &cpsw_emac1 {
  559. phy_id = <&davinci_mdio>, <1>;
  560. phy-mode = "rgmii-txid";
  561. dual_emac_res_vlan = <2>;
  562. };
  563. &mmc1 {
  564. status = "okay";
  565. vmmc-supply = <&vmmc_reg>;
  566. bus-width = <4>;
  567. pinctrl-names = "default";
  568. pinctrl-0 = <&mmc1_pins>;
  569. cd-gpios = <&gpio0 6 GPIO_ACTIVE_LOW>;
  570. };
  571. &sham {
  572. status = "okay";
  573. };
  574. &aes {
  575. status = "okay";
  576. };
  577. &gpio0 {
  578. ti,no-reset-on-init;
  579. };
  580. &mmc2 {
  581. status = "okay";
  582. vmmc-supply = <&wl12xx_vmmc>;
  583. ti,non-removable;
  584. bus-width = <4>;
  585. cap-power-off-card;
  586. pinctrl-names = "default";
  587. pinctrl-0 = <&mmc2_pins>;
  588. #address-cells = <1>;
  589. #size-cells = <0>;
  590. wlcore: wlcore@2 {
  591. compatible = "ti,wl1271";
  592. reg = <2>;
  593. interrupt-parent = <&gpio0>;
  594. interrupts = <31 IRQ_TYPE_LEVEL_HIGH>; /* gpio 31 */
  595. ref-clock-frequency = <38400000>;
  596. };
  597. };
  598. &mcasp1 {
  599. #sound-dai-cells = <0>;
  600. pinctrl-names = "default", "sleep";
  601. pinctrl-0 = <&mcasp1_pins>;
  602. pinctrl-1 = <&mcasp1_pins_sleep>;
  603. status = "okay";
  604. op-mode = <0>; /* MCASP_IIS_MODE */
  605. tdm-slots = <2>;
  606. /* 4 serializers */
  607. serial-dir = < /* 0: INACTIVE, 1: TX, 2: RX */
  608. 0 0 1 2
  609. >;
  610. tx-num-evt = <32>;
  611. rx-num-evt = <32>;
  612. };
  613. &tscadc {
  614. status = "okay";
  615. tsc {
  616. ti,wires = <4>;
  617. ti,x-plate-resistance = <200>;
  618. ti,coordinate-readouts = <5>;
  619. ti,wire-config = <0x00 0x11 0x22 0x33>;
  620. };
  621. };
  622. &lcdc {
  623. status = "okay";
  624. };