am335x-evmsk.dts 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680
  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. / {
  16. model = "TI AM335x EVM-SK";
  17. compatible = "ti,am335x-evmsk", "ti,am33xx";
  18. cpus {
  19. cpu@0 {
  20. cpu0-supply = <&vdd1_reg>;
  21. };
  22. };
  23. memory {
  24. device_type = "memory";
  25. reg = <0x80000000 0x10000000>; /* 256 MB */
  26. };
  27. vbat: fixedregulator@0 {
  28. compatible = "regulator-fixed";
  29. regulator-name = "vbat";
  30. regulator-min-microvolt = <5000000>;
  31. regulator-max-microvolt = <5000000>;
  32. regulator-boot-on;
  33. };
  34. lis3_reg: fixedregulator@1 {
  35. compatible = "regulator-fixed";
  36. regulator-name = "lis3_reg";
  37. regulator-boot-on;
  38. };
  39. wl12xx_vmmc: fixedregulator@2 {
  40. pinctrl-names = "default";
  41. pinctrl-0 = <&wl12xx_gpio>;
  42. compatible = "regulator-fixed";
  43. regulator-name = "vwl1271";
  44. regulator-min-microvolt = <1800000>;
  45. regulator-max-microvolt = <1800000>;
  46. gpio = <&gpio1 29 0>;
  47. startup-delay-us = <70000>;
  48. enable-active-high;
  49. };
  50. vtt_fixed: fixedregulator@3 {
  51. compatible = "regulator-fixed";
  52. regulator-name = "vtt";
  53. regulator-min-microvolt = <1500000>;
  54. regulator-max-microvolt = <1500000>;
  55. gpio = <&gpio0 7 GPIO_ACTIVE_HIGH>;
  56. regulator-always-on;
  57. regulator-boot-on;
  58. enable-active-high;
  59. };
  60. leds {
  61. pinctrl-names = "default";
  62. pinctrl-0 = <&user_leds_s0>;
  63. compatible = "gpio-leds";
  64. led@1 {
  65. label = "evmsk:green:usr0";
  66. gpios = <&gpio1 4 GPIO_ACTIVE_HIGH>;
  67. default-state = "off";
  68. };
  69. led@2 {
  70. label = "evmsk:green:usr1";
  71. gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
  72. default-state = "off";
  73. };
  74. led@3 {
  75. label = "evmsk:green:mmc0";
  76. gpios = <&gpio1 6 GPIO_ACTIVE_HIGH>;
  77. linux,default-trigger = "mmc0";
  78. default-state = "off";
  79. };
  80. led@4 {
  81. label = "evmsk:green:heartbeat";
  82. gpios = <&gpio1 7 GPIO_ACTIVE_HIGH>;
  83. linux,default-trigger = "heartbeat";
  84. default-state = "off";
  85. };
  86. };
  87. gpio_buttons: gpio_buttons@0 {
  88. compatible = "gpio-keys";
  89. #address-cells = <1>;
  90. #size-cells = <0>;
  91. switch@1 {
  92. label = "button0";
  93. linux,code = <0x100>;
  94. gpios = <&gpio2 3 GPIO_ACTIVE_HIGH>;
  95. };
  96. switch@2 {
  97. label = "button1";
  98. linux,code = <0x101>;
  99. gpios = <&gpio2 2 GPIO_ACTIVE_HIGH>;
  100. };
  101. switch@3 {
  102. label = "button2";
  103. linux,code = <0x102>;
  104. gpios = <&gpio0 30 GPIO_ACTIVE_HIGH>;
  105. gpio-key,wakeup;
  106. };
  107. switch@4 {
  108. label = "button3";
  109. linux,code = <0x103>;
  110. gpios = <&gpio2 5 GPIO_ACTIVE_HIGH>;
  111. };
  112. };
  113. backlight {
  114. compatible = "pwm-backlight";
  115. pwms = <&ecap2 0 50000 PWM_POLARITY_INVERTED>;
  116. brightness-levels = <0 58 61 66 75 90 125 170 255>;
  117. default-brightness-level = <8>;
  118. };
  119. sound {
  120. compatible = "ti,da830-evm-audio";
  121. ti,model = "AM335x-EVMSK";
  122. ti,audio-codec = <&tlv320aic3106>;
  123. ti,mcasp-controller = <&mcasp1>;
  124. ti,codec-clock-rate = <24000000>;
  125. ti,audio-routing =
  126. "Headphone Jack", "HPLOUT",
  127. "Headphone Jack", "HPROUT";
  128. };
  129. panel {
  130. compatible = "ti,tilcdc,panel";
  131. pinctrl-names = "default", "sleep";
  132. pinctrl-0 = <&lcd_pins_default>;
  133. pinctrl-1 = <&lcd_pins_sleep>;
  134. status = "okay";
  135. panel-info {
  136. ac-bias = <255>;
  137. ac-bias-intrpt = <0>;
  138. dma-burst-sz = <16>;
  139. bpp = <32>;
  140. fdd = <0x80>;
  141. sync-edge = <0>;
  142. sync-ctrl = <1>;
  143. raster-order = <0>;
  144. fifo-th = <0>;
  145. };
  146. display-timings {
  147. 480x272 {
  148. hactive = <480>;
  149. vactive = <272>;
  150. hback-porch = <43>;
  151. hfront-porch = <8>;
  152. hsync-len = <4>;
  153. vback-porch = <12>;
  154. vfront-porch = <4>;
  155. vsync-len = <10>;
  156. clock-frequency = <9000000>;
  157. hsync-active = <0>;
  158. vsync-active = <0>;
  159. };
  160. };
  161. };
  162. };
  163. &am33xx_pinmux {
  164. pinctrl-names = "default";
  165. pinctrl-0 = <&gpio_keys_s0 &clkout2_pin>;
  166. lcd_pins_default: lcd_pins_default {
  167. pinctrl-single,pins = <
  168. 0x20 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad8.lcd_data23 */
  169. 0x24 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad9.lcd_data22 */
  170. 0x28 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad10.lcd_data21 */
  171. 0x2c (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad11.lcd_data20 */
  172. 0x30 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad12.lcd_data19 */
  173. 0x34 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad13.lcd_data18 */
  174. 0x38 (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad14.lcd_data17 */
  175. 0x3c (PIN_OUTPUT | MUX_MODE1) /* gpmc_ad15.lcd_data16 */
  176. 0xa0 (PIN_OUTPUT | MUX_MODE0) /* lcd_data0.lcd_data0 */
  177. 0xa4 (PIN_OUTPUT | MUX_MODE0) /* lcd_data1.lcd_data1 */
  178. 0xa8 (PIN_OUTPUT | MUX_MODE0) /* lcd_data2.lcd_data2 */
  179. 0xac (PIN_OUTPUT | MUX_MODE0) /* lcd_data3.lcd_data3 */
  180. 0xb0 (PIN_OUTPUT | MUX_MODE0) /* lcd_data4.lcd_data4 */
  181. 0xb4 (PIN_OUTPUT | MUX_MODE0) /* lcd_data5.lcd_data5 */
  182. 0xb8 (PIN_OUTPUT | MUX_MODE0) /* lcd_data6.lcd_data6 */
  183. 0xbc (PIN_OUTPUT | MUX_MODE0) /* lcd_data7.lcd_data7 */
  184. 0xc0 (PIN_OUTPUT | MUX_MODE0) /* lcd_data8.lcd_data8 */
  185. 0xc4 (PIN_OUTPUT | MUX_MODE0) /* lcd_data9.lcd_data9 */
  186. 0xc8 (PIN_OUTPUT | MUX_MODE0) /* lcd_data10.lcd_data10 */
  187. 0xcc (PIN_OUTPUT | MUX_MODE0) /* lcd_data11.lcd_data11 */
  188. 0xd0 (PIN_OUTPUT | MUX_MODE0) /* lcd_data12.lcd_data12 */
  189. 0xd4 (PIN_OUTPUT | MUX_MODE0) /* lcd_data13.lcd_data13 */
  190. 0xd8 (PIN_OUTPUT | MUX_MODE0) /* lcd_data14.lcd_data14 */
  191. 0xdc (PIN_OUTPUT | MUX_MODE0) /* lcd_data15.lcd_data15 */
  192. 0xe0 (PIN_OUTPUT | MUX_MODE0) /* lcd_vsync.lcd_vsync */
  193. 0xe4 (PIN_OUTPUT | MUX_MODE0) /* lcd_hsync.lcd_hsync */
  194. 0xe8 (PIN_OUTPUT | MUX_MODE0) /* lcd_pclk.lcd_pclk */
  195. 0xec (PIN_OUTPUT | MUX_MODE0) /* lcd_ac_bias_en.lcd_ac_bias_en */
  196. >;
  197. };
  198. lcd_pins_sleep: lcd_pins_sleep {
  199. pinctrl-single,pins = <
  200. 0x20 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad8.lcd_data23 */
  201. 0x24 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad9.lcd_data22 */
  202. 0x28 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad10.lcd_data21 */
  203. 0x2c (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad11.lcd_data20 */
  204. 0x30 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad12.lcd_data19 */
  205. 0x34 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad13.lcd_data18 */
  206. 0x38 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad14.lcd_data17 */
  207. 0x3c (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad15.lcd_data16 */
  208. 0xa0 (PULL_DISABLE | MUX_MODE7) /* lcd_data0.lcd_data0 */
  209. 0xa4 (PULL_DISABLE | MUX_MODE7) /* lcd_data1.lcd_data1 */
  210. 0xa8 (PULL_DISABLE | MUX_MODE7) /* lcd_data2.lcd_data2 */
  211. 0xac (PULL_DISABLE | MUX_MODE7) /* lcd_data3.lcd_data3 */
  212. 0xb0 (PULL_DISABLE | MUX_MODE7) /* lcd_data4.lcd_data4 */
  213. 0xb4 (PULL_DISABLE | MUX_MODE7) /* lcd_data5.lcd_data5 */
  214. 0xb8 (PULL_DISABLE | MUX_MODE7) /* lcd_data6.lcd_data6 */
  215. 0xbc (PULL_DISABLE | MUX_MODE7) /* lcd_data7.lcd_data7 */
  216. 0xc0 (PULL_DISABLE | MUX_MODE7) /* lcd_data8.lcd_data8 */
  217. 0xc4 (PULL_DISABLE | MUX_MODE7) /* lcd_data9.lcd_data9 */
  218. 0xc8 (PULL_DISABLE | MUX_MODE7) /* lcd_data10.lcd_data10 */
  219. 0xcc (PULL_DISABLE | MUX_MODE7) /* lcd_data11.lcd_data11 */
  220. 0xd0 (PULL_DISABLE | MUX_MODE7) /* lcd_data12.lcd_data12 */
  221. 0xd4 (PULL_DISABLE | MUX_MODE7) /* lcd_data13.lcd_data13 */
  222. 0xd8 (PULL_DISABLE | MUX_MODE7) /* lcd_data14.lcd_data14 */
  223. 0xdc (PULL_DISABLE | MUX_MODE7) /* lcd_data15.lcd_data15 */
  224. 0xe0 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_vsync.lcd_vsync */
  225. 0xe4 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_hsync.lcd_hsync */
  226. 0xe8 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_pclk.lcd_pclk */
  227. 0xec (PIN_INPUT_PULLDOWN | MUX_MODE7) /* lcd_ac_bias_en.lcd_ac_bias_en */
  228. >;
  229. };
  230. user_leds_s0: user_leds_s0 {
  231. pinctrl-single,pins = <
  232. 0x10 (PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad4.gpio1_4 */
  233. 0x14 (PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad5.gpio1_5 */
  234. 0x18 (PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad6.gpio1_6 */
  235. 0x1c (PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_ad7.gpio1_7 */
  236. >;
  237. };
  238. gpio_keys_s0: gpio_keys_s0 {
  239. pinctrl-single,pins = <
  240. 0x94 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_oen_ren.gpio2_3 */
  241. 0x90 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_advn_ale.gpio2_2 */
  242. 0x70 (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_wait0.gpio0_30 */
  243. 0x9c (PIN_INPUT_PULLDOWN | MUX_MODE7) /* gpmc_ben0_cle.gpio2_5 */
  244. >;
  245. };
  246. i2c0_pins: pinmux_i2c0_pins {
  247. pinctrl-single,pins = <
  248. 0x188 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c0_sda.i2c0_sda */
  249. 0x18c (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c0_scl.i2c0_scl */
  250. >;
  251. };
  252. uart0_pins: pinmux_uart0_pins {
  253. pinctrl-single,pins = <
  254. 0x170 (PIN_INPUT_PULLUP | MUX_MODE0) /* uart0_rxd.uart0_rxd */
  255. 0x174 (PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* uart0_txd.uart0_txd */
  256. >;
  257. };
  258. clkout2_pin: pinmux_clkout2_pin {
  259. pinctrl-single,pins = <
  260. 0x1b4 (PIN_OUTPUT_PULLDOWN | MUX_MODE3) /* xdma_event_intr1.clkout2 */
  261. >;
  262. };
  263. ecap2_pins: backlight_pins {
  264. pinctrl-single,pins = <
  265. 0x19c 0x4 /* mcasp0_ahclkr.ecap2_in_pwm2_out MODE4 */
  266. >;
  267. };
  268. cpsw_default: cpsw_default {
  269. pinctrl-single,pins = <
  270. /* Slave 1 */
  271. 0x114 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txen.rgmii1_tctl */
  272. 0x118 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxdv.rgmii1_rctl */
  273. 0x11c (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd3.rgmii1_td3 */
  274. 0x120 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd2.rgmii1_td2 */
  275. 0x124 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd1.rgmii1_td1 */
  276. 0x128 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txd0.rgmii1_td0 */
  277. 0x12c (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mii1_txclk.rgmii1_tclk */
  278. 0x130 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxclk.rgmii1_rclk */
  279. 0x134 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd3.rgmii1_rd3 */
  280. 0x138 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd2.rgmii1_rd2 */
  281. 0x13c (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd1.rgmii1_rd1 */
  282. 0x140 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* mii1_rxd0.rgmii1_rd0 */
  283. /* Slave 2 */
  284. 0x40 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a0.rgmii2_tctl */
  285. 0x44 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a1.rgmii2_rctl */
  286. 0x48 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a2.rgmii2_td3 */
  287. 0x4c (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a3.rgmii2_td2 */
  288. 0x50 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a4.rgmii2_td1 */
  289. 0x54 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a5.rgmii2_td0 */
  290. 0x58 (PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* gpmc_a6.rgmii2_tclk */
  291. 0x5c (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a7.rgmii2_rclk */
  292. 0x60 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a8.rgmii2_rd3 */
  293. 0x64 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a9.rgmii2_rd2 */
  294. 0x68 (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a10.rgmii2_rd1 */
  295. 0x6c (PIN_INPUT_PULLDOWN | MUX_MODE2) /* gpmc_a11.rgmii2_rd0 */
  296. >;
  297. };
  298. cpsw_sleep: cpsw_sleep {
  299. pinctrl-single,pins = <
  300. /* Slave 1 reset value */
  301. 0x114 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  302. 0x118 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  303. 0x11c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  304. 0x120 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  305. 0x124 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  306. 0x128 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  307. 0x12c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  308. 0x130 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  309. 0x134 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  310. 0x138 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  311. 0x13c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  312. 0x140 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  313. /* Slave 2 reset value*/
  314. 0x40 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  315. 0x44 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  316. 0x48 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  317. 0x4c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  318. 0x50 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  319. 0x54 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  320. 0x58 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  321. 0x5c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  322. 0x60 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  323. 0x64 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  324. 0x68 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  325. 0x6c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  326. >;
  327. };
  328. davinci_mdio_default: davinci_mdio_default {
  329. pinctrl-single,pins = <
  330. /* MDIO */
  331. 0x148 (PIN_INPUT_PULLUP | SLEWCTRL_FAST | MUX_MODE0) /* mdio_data.mdio_data */
  332. 0x14c (PIN_OUTPUT_PULLUP | MUX_MODE0) /* mdio_clk.mdio_clk */
  333. >;
  334. };
  335. davinci_mdio_sleep: davinci_mdio_sleep {
  336. pinctrl-single,pins = <
  337. /* MDIO reset value */
  338. 0x148 (PIN_INPUT_PULLDOWN | MUX_MODE7)
  339. 0x14c (PIN_INPUT_PULLDOWN | MUX_MODE7)
  340. >;
  341. };
  342. mmc1_pins: pinmux_mmc1_pins {
  343. pinctrl-single,pins = <
  344. 0x160 (PIN_INPUT | MUX_MODE7) /* spi0_cs1.gpio0_6 */
  345. >;
  346. };
  347. mcasp1_pins: mcasp1_pins {
  348. pinctrl-single,pins = <
  349. 0x10c (PIN_INPUT_PULLDOWN | MUX_MODE4) /* mii1_crs.mcasp1_aclkx */
  350. 0x110 (PIN_INPUT_PULLDOWN | MUX_MODE4) /* mii1_rxerr.mcasp1_fsx */
  351. 0x108 (PIN_OUTPUT_PULLDOWN | MUX_MODE4) /* mii1_col.mcasp1_axr2 */
  352. 0x144 (PIN_INPUT_PULLDOWN | MUX_MODE4) /* rmii1_ref_clk.mcasp1_axr3 */
  353. >;
  354. };
  355. mmc2_pins: pinmux_mmc2_pins {
  356. pinctrl-single,pins = <
  357. 0x74 (PIN_INPUT_PULLUP | MUX_MODE7) /* gpmc_wpn.gpio0_31 */
  358. 0x80 (PIN_INPUT_PULLUP | MUX_MODE2) /* gpmc_csn1.mmc1_clk */
  359. 0x84 (PIN_INPUT_PULLUP | MUX_MODE2) /* gpmc_csn2.mmc1_cmd */
  360. 0x00 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad0.mmc1_dat0 */
  361. 0x04 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad1.mmc1_dat1 */
  362. 0x08 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad2.mmc1_dat2 */
  363. 0x0c (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_ad3.mmc1_dat3 */
  364. >;
  365. };
  366. wl12xx_gpio: pinmux_wl12xx_gpio {
  367. pinctrl-single,pins = <
  368. 0x7c (PIN_OUTPUT_PULLUP | MUX_MODE7) /* gpmc_csn0.gpio1_29 */
  369. >;
  370. };
  371. };
  372. &uart0 {
  373. pinctrl-names = "default";
  374. pinctrl-0 = <&uart0_pins>;
  375. status = "okay";
  376. };
  377. &i2c0 {
  378. pinctrl-names = "default";
  379. pinctrl-0 = <&i2c0_pins>;
  380. status = "okay";
  381. clock-frequency = <400000>;
  382. tps: tps@2d {
  383. reg = <0x2d>;
  384. };
  385. lis331dlh: lis331dlh@18 {
  386. compatible = "st,lis331dlh", "st,lis3lv02d";
  387. reg = <0x18>;
  388. Vdd-supply = <&lis3_reg>;
  389. Vdd_IO-supply = <&lis3_reg>;
  390. st,click-single-x;
  391. st,click-single-y;
  392. st,click-single-z;
  393. st,click-thresh-x = <10>;
  394. st,click-thresh-y = <10>;
  395. st,click-thresh-z = <10>;
  396. st,irq1-click;
  397. st,irq2-click;
  398. st,wakeup-x-lo;
  399. st,wakeup-x-hi;
  400. st,wakeup-y-lo;
  401. st,wakeup-y-hi;
  402. st,wakeup-z-lo;
  403. st,wakeup-z-hi;
  404. st,min-limit-x = <120>;
  405. st,min-limit-y = <120>;
  406. st,min-limit-z = <140>;
  407. st,max-limit-x = <550>;
  408. st,max-limit-y = <550>;
  409. st,max-limit-z = <750>;
  410. };
  411. tlv320aic3106: tlv320aic3106@1b {
  412. compatible = "ti,tlv320aic3106";
  413. reg = <0x1b>;
  414. status = "okay";
  415. /* Regulators */
  416. AVDD-supply = <&vaux2_reg>;
  417. IOVDD-supply = <&vaux2_reg>;
  418. DRVDD-supply = <&vaux2_reg>;
  419. DVDD-supply = <&vbat>;
  420. };
  421. };
  422. &usb {
  423. status = "okay";
  424. };
  425. &usb_ctrl_mod {
  426. status = "okay";
  427. };
  428. &usb0_phy {
  429. status = "okay";
  430. };
  431. &usb1_phy {
  432. status = "okay";
  433. };
  434. &usb0 {
  435. status = "okay";
  436. };
  437. &usb1 {
  438. status = "okay";
  439. dr_mode = "host";
  440. };
  441. &cppi41dma {
  442. status = "okay";
  443. };
  444. &epwmss2 {
  445. status = "okay";
  446. ecap2: ecap@48304100 {
  447. status = "okay";
  448. pinctrl-names = "default";
  449. pinctrl-0 = <&ecap2_pins>;
  450. };
  451. };
  452. #include "tps65910.dtsi"
  453. &tps {
  454. vcc1-supply = <&vbat>;
  455. vcc2-supply = <&vbat>;
  456. vcc3-supply = <&vbat>;
  457. vcc4-supply = <&vbat>;
  458. vcc5-supply = <&vbat>;
  459. vcc6-supply = <&vbat>;
  460. vcc7-supply = <&vbat>;
  461. vccio-supply = <&vbat>;
  462. regulators {
  463. vrtc_reg: regulator@0 {
  464. regulator-always-on;
  465. };
  466. vio_reg: regulator@1 {
  467. regulator-always-on;
  468. };
  469. vdd1_reg: regulator@2 {
  470. /* VDD_MPU voltage limits 0.95V - 1.26V with +/-4% tolerance */
  471. regulator-name = "vdd_mpu";
  472. regulator-min-microvolt = <912500>;
  473. regulator-max-microvolt = <1312500>;
  474. regulator-boot-on;
  475. regulator-always-on;
  476. };
  477. vdd2_reg: regulator@3 {
  478. /* VDD_CORE voltage limits 0.95V - 1.1V with +/-4% tolerance */
  479. regulator-name = "vdd_core";
  480. regulator-min-microvolt = <912500>;
  481. regulator-max-microvolt = <1150000>;
  482. regulator-boot-on;
  483. regulator-always-on;
  484. };
  485. vdd3_reg: regulator@4 {
  486. regulator-always-on;
  487. };
  488. vdig1_reg: regulator@5 {
  489. regulator-always-on;
  490. };
  491. vdig2_reg: regulator@6 {
  492. regulator-always-on;
  493. };
  494. vpll_reg: regulator@7 {
  495. regulator-always-on;
  496. };
  497. vdac_reg: regulator@8 {
  498. regulator-always-on;
  499. };
  500. vaux1_reg: regulator@9 {
  501. regulator-always-on;
  502. };
  503. vaux2_reg: regulator@10 {
  504. regulator-always-on;
  505. };
  506. vaux33_reg: regulator@11 {
  507. regulator-always-on;
  508. };
  509. vmmc_reg: regulator@12 {
  510. regulator-min-microvolt = <1800000>;
  511. regulator-max-microvolt = <3300000>;
  512. regulator-always-on;
  513. };
  514. };
  515. };
  516. &mac {
  517. pinctrl-names = "default", "sleep";
  518. pinctrl-0 = <&cpsw_default>;
  519. pinctrl-1 = <&cpsw_sleep>;
  520. dual_emac = <1>;
  521. status = "okay";
  522. };
  523. &davinci_mdio {
  524. pinctrl-names = "default", "sleep";
  525. pinctrl-0 = <&davinci_mdio_default>;
  526. pinctrl-1 = <&davinci_mdio_sleep>;
  527. status = "okay";
  528. };
  529. &cpsw_emac0 {
  530. phy_id = <&davinci_mdio>, <0>;
  531. phy-mode = "rgmii-txid";
  532. dual_emac_res_vlan = <1>;
  533. };
  534. &cpsw_emac1 {
  535. phy_id = <&davinci_mdio>, <1>;
  536. phy-mode = "rgmii-txid";
  537. dual_emac_res_vlan = <2>;
  538. };
  539. &mmc1 {
  540. status = "okay";
  541. vmmc-supply = <&vmmc_reg>;
  542. bus-width = <4>;
  543. pinctrl-names = "default";
  544. pinctrl-0 = <&mmc1_pins>;
  545. cd-gpios = <&gpio0 6 GPIO_ACTIVE_HIGH>;
  546. };
  547. &sham {
  548. status = "okay";
  549. };
  550. &aes {
  551. status = "okay";
  552. };
  553. &gpio0 {
  554. ti,no-reset-on-init;
  555. };
  556. &mmc2 {
  557. status = "okay";
  558. vmmc-supply = <&wl12xx_vmmc>;
  559. ti,non-removable;
  560. bus-width = <4>;
  561. cap-power-off-card;
  562. pinctrl-names = "default";
  563. pinctrl-0 = <&mmc2_pins>;
  564. };
  565. &mcasp1 {
  566. pinctrl-names = "default";
  567. pinctrl-0 = <&mcasp1_pins>;
  568. status = "okay";
  569. op-mode = <0>; /* MCASP_IIS_MODE */
  570. tdm-slots = <2>;
  571. /* 4 serializers */
  572. serial-dir = < /* 0: INACTIVE, 1: TX, 2: RX */
  573. 0 0 1 2
  574. >;
  575. tx-num-evt = <32>;
  576. rx-num-evt = <32>;
  577. };
  578. &tscadc {
  579. status = "okay";
  580. tsc {
  581. ti,wires = <4>;
  582. ti,x-plate-resistance = <200>;
  583. ti,coordinate-readouts = <5>;
  584. ti,wire-config = <0x00 0x11 0x22 0x33>;
  585. };
  586. };
  587. &lcdc {
  588. status = "okay";
  589. };