imx28-cfa10049.dts 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436
  1. /*
  2. * Copyright 2012 Free Electrons
  3. *
  4. * The code contained herein is licensed under the GNU General Public
  5. * License. You may obtain a copy of the GNU General Public License
  6. * Version 2 or later at the following locations:
  7. *
  8. * http://www.opensource.org/licenses/gpl-license.html
  9. * http://www.gnu.org/copyleft/gpl.html
  10. */
  11. /*
  12. * The CFA-10049 is an expansion board for the CFA-10036 module, thus we
  13. * need to include the CFA-10036 DTS.
  14. */
  15. #include "imx28-cfa10036.dts"
  16. / {
  17. model = "Crystalfontz CFA-10049 Board";
  18. compatible = "crystalfontz,cfa10049", "crystalfontz,cfa10036", "fsl,imx28";
  19. apb@80000000 {
  20. apbh@80000000 {
  21. pinctrl@80018000 {
  22. usb_pins_cfa10049: usb-10049@0 {
  23. reg = <0>;
  24. fsl,pinmux-ids = <
  25. MX28_PAD_GPMI_D07__GPIO_0_7
  26. >;
  27. fsl,drive-strength = <MXS_DRIVE_4mA>;
  28. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  29. fsl,pull-up = <MXS_PULL_DISABLE>;
  30. };
  31. i2cmux_pins_cfa10049: i2cmux-10049@0 {
  32. reg = <0>;
  33. fsl,pinmux-ids = <
  34. MX28_PAD_LCD_D22__GPIO_1_22
  35. MX28_PAD_LCD_D23__GPIO_1_23
  36. >;
  37. fsl,drive-strength = <MXS_DRIVE_4mA>;
  38. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  39. fsl,pull-up = <MXS_PULL_DISABLE>;
  40. };
  41. mac0_pins_cfa10049: mac0-10049@0 {
  42. reg = <0>;
  43. fsl,pinmux-ids = <
  44. MX28_PAD_SSP2_SS2__GPIO_2_21
  45. >;
  46. fsl,drive-strength = <MXS_DRIVE_4mA>;
  47. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  48. fsl,pull-up = <MXS_PULL_DISABLE>;
  49. };
  50. pca_pins_cfa10049: pca-10049@0 {
  51. reg = <0>;
  52. fsl,pinmux-ids = <
  53. MX28_PAD_SSP2_SS0__GPIO_2_19
  54. >;
  55. fsl,drive-strength = <MXS_DRIVE_4mA>;
  56. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  57. fsl,pull-up = <MXS_PULL_ENABLE>;
  58. };
  59. rotary_pins_cfa10049: rotary-10049@0 {
  60. reg = <0>;
  61. fsl,pinmux-ids = <
  62. MX28_PAD_I2C0_SCL__GPIO_3_24
  63. MX28_PAD_I2C0_SDA__GPIO_3_25
  64. >;
  65. fsl,drive-strength = <MXS_DRIVE_4mA>;
  66. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  67. fsl,pull-up = <MXS_PULL_ENABLE>;
  68. };
  69. rotary_btn_pins_cfa10049: rotary-btn-10049@0 {
  70. reg = <0>;
  71. fsl,pinmux-ids = <
  72. MX28_PAD_SAIF1_SDATA0__GPIO_3_26
  73. >;
  74. fsl,drive-strength = <MXS_DRIVE_4mA>;
  75. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  76. fsl,pull-up = <MXS_PULL_ENABLE>;
  77. };
  78. spi2_pins_cfa10049: spi2-cfa10049@0 {
  79. reg = <0>;
  80. fsl,pinmux-ids = <
  81. MX28_PAD_SSP2_SCK__GPIO_2_16
  82. MX28_PAD_SSP2_MOSI__GPIO_2_17
  83. MX28_PAD_SSP2_MISO__GPIO_2_18
  84. MX28_PAD_AUART1_TX__GPIO_3_5
  85. >;
  86. fsl,drive-strength = <MXS_DRIVE_8mA>;
  87. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  88. fsl,pull-up = <MXS_PULL_ENABLE>;
  89. };
  90. spi3_pins_cfa10049: spi3-cfa10049@0 {
  91. reg = <0>;
  92. fsl,pinmux-ids = <
  93. MX28_PAD_GPMI_RDN__GPIO_0_24
  94. MX28_PAD_GPMI_RESETN__GPIO_0_28
  95. MX28_PAD_GPMI_CE1N__GPIO_0_17
  96. MX28_PAD_GPMI_ALE__GPIO_0_26
  97. MX28_PAD_GPMI_CLE__GPIO_0_27
  98. >;
  99. fsl,drive-strength = <MXS_DRIVE_8mA>;
  100. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  101. fsl,pull-up = <MXS_PULL_ENABLE>;
  102. };
  103. lcdif_18bit_pins_cfa10049: lcdif-18bit@0 {
  104. reg = <0>;
  105. fsl,pinmux-ids = <
  106. MX28_PAD_LCD_D00__LCD_D0
  107. MX28_PAD_LCD_D01__LCD_D1
  108. MX28_PAD_LCD_D02__LCD_D2
  109. MX28_PAD_LCD_D03__LCD_D3
  110. MX28_PAD_LCD_D04__LCD_D4
  111. MX28_PAD_LCD_D05__LCD_D5
  112. MX28_PAD_LCD_D06__LCD_D6
  113. MX28_PAD_LCD_D07__LCD_D7
  114. MX28_PAD_LCD_D08__LCD_D8
  115. MX28_PAD_LCD_D09__LCD_D9
  116. MX28_PAD_LCD_D10__LCD_D10
  117. MX28_PAD_LCD_D11__LCD_D11
  118. MX28_PAD_LCD_D12__LCD_D12
  119. MX28_PAD_LCD_D13__LCD_D13
  120. MX28_PAD_LCD_D14__LCD_D14
  121. MX28_PAD_LCD_D15__LCD_D15
  122. MX28_PAD_LCD_D16__LCD_D16
  123. MX28_PAD_LCD_D17__LCD_D17
  124. >;
  125. fsl,drive-strength = <MXS_DRIVE_4mA>;
  126. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  127. fsl,pull-up = <MXS_PULL_DISABLE>;
  128. };
  129. lcdif_pins_cfa10049: lcdif-evk@0 {
  130. reg = <0>;
  131. fsl,pinmux-ids = <
  132. MX28_PAD_LCD_RD_E__LCD_VSYNC
  133. MX28_PAD_LCD_WR_RWN__LCD_HSYNC
  134. MX28_PAD_LCD_RS__LCD_DOTCLK
  135. MX28_PAD_LCD_CS__LCD_ENABLE
  136. >;
  137. fsl,drive-strength = <MXS_DRIVE_4mA>;
  138. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  139. fsl,pull-up = <MXS_PULL_DISABLE>;
  140. };
  141. lcdif_pins_cfa10049_pullup: lcdif-10049-pullup@0 {
  142. reg = <0>;
  143. fsl,pinmux-ids = <
  144. MX28_PAD_LCD_RESET__GPIO_3_30
  145. >;
  146. fsl,drive-strength = <MXS_DRIVE_4mA>;
  147. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  148. fsl,pull-up = <MXS_PULL_ENABLE>;
  149. };
  150. w1_gpio_pins: w1-gpio@0 {
  151. reg = <0>;
  152. fsl,pinmux-ids = <
  153. MX28_PAD_LCD_D21__GPIO_1_21
  154. >;
  155. fsl,drive-strength = <MXS_DRIVE_8mA>;
  156. fsl,voltage = <MXS_VOLTAGE_HIGH>;
  157. fsl,pull-up = <MXS_PULL_DISABLE>; /* 0 will enable the keeper */
  158. };
  159. };
  160. lcdif@80030000 {
  161. pinctrl-names = "default";
  162. pinctrl-0 = <&lcdif_18bit_pins_cfa10049
  163. &lcdif_pins_cfa10049
  164. &lcdif_pins_cfa10049_pullup>;
  165. display = <&display0>;
  166. status = "okay";
  167. display0: display0 {
  168. bits-per-pixel = <32>;
  169. bus-width = <18>;
  170. display-timings {
  171. native-mode = <&timing0>;
  172. timing0: timing0 {
  173. clock-frequency = <9216000>;
  174. hactive = <320>;
  175. vactive = <480>;
  176. hback-porch = <2>;
  177. hfront-porch = <2>;
  178. vback-porch = <2>;
  179. vfront-porch = <2>;
  180. hsync-len = <15>;
  181. vsync-len = <15>;
  182. hsync-active = <0>;
  183. vsync-active = <0>;
  184. de-active = <1>;
  185. pixelclk-active = <1>;
  186. };
  187. };
  188. };
  189. };
  190. };
  191. apbx@80040000 {
  192. pwm: pwm@80064000 {
  193. pinctrl-names = "default";
  194. pinctrl-0 = <&pwm3_pins_b>;
  195. status = "okay";
  196. };
  197. i2c1: i2c@8005a000 {
  198. pinctrl-names = "default";
  199. pinctrl-0 = <&i2c1_pins_a>;
  200. status = "okay";
  201. };
  202. i2cmux {
  203. compatible = "i2c-mux-gpio";
  204. #address-cells = <1>;
  205. #size-cells = <0>;
  206. pinctrl-names = "default";
  207. pinctrl-0 = <&i2cmux_pins_cfa10049>;
  208. mux-gpios = <&gpio1 22 0 &gpio1 23 0>;
  209. i2c-parent = <&i2c1>;
  210. i2c@0 {
  211. #address-cells = <1>;
  212. #size-cells = <0>;
  213. reg = <0>;
  214. adc0: nau7802@2a {
  215. compatible = "nuvoton,nau7802";
  216. reg = <0x2a>;
  217. nuvoton,vldo = <3000>;
  218. };
  219. };
  220. i2c@1 {
  221. #address-cells = <1>;
  222. #size-cells = <0>;
  223. reg = <1>;
  224. adc1: nau7802@2a {
  225. compatible = "nuvoton,nau7802";
  226. reg = <0x2a>;
  227. nuvoton,vldo = <3000>;
  228. };
  229. };
  230. i2c@2 {
  231. #address-cells = <1>;
  232. #size-cells = <0>;
  233. reg = <2>;
  234. adc2: nau7802@2a {
  235. compatible = "nuvoton,nau7802";
  236. reg = <0x2a>;
  237. nuvoton,vldo = <3000>;
  238. };
  239. };
  240. i2c@3 {
  241. reg = <3>;
  242. #address-cells = <1>;
  243. #size-cells = <0>;
  244. pca9555: pca9555@20 {
  245. compatible = "nxp,pca9555";
  246. pinctrl-names = "default";
  247. pinctrl-0 = <&pca_pins_cfa10049>;
  248. interrupt-parent = <&gpio2>;
  249. interrupts = <19 0x2>;
  250. gpio-controller;
  251. #gpio-cells = <2>;
  252. interrupt-controller;
  253. #interrupt-cells = <2>;
  254. reg = <0x20>;
  255. };
  256. };
  257. };
  258. usbphy1: usbphy@8007e000 {
  259. status = "okay";
  260. };
  261. lradc@80050000 {
  262. status = "okay";
  263. fsl,lradc-touchscreen-wires = <4>;
  264. };
  265. };
  266. };
  267. ahb@80080000 {
  268. usb1: usb@80090000 {
  269. vbus-supply = <&reg_usb1_vbus>;
  270. pinctrl-0 = <&usb1_pins_a>;
  271. pinctrl-names = "default";
  272. status = "okay";
  273. };
  274. };
  275. regulators {
  276. compatible = "simple-bus";
  277. #address-cells = <1>;
  278. #size-cells = <0>;
  279. reg_usb1_vbus: regulator@0 {
  280. compatible = "regulator-fixed";
  281. reg = <0>;
  282. pinctrl-names = "default";
  283. pinctrl-0 = <&usb_pins_cfa10049>;
  284. regulator-name = "usb1_vbus";
  285. regulator-min-microvolt = <5000000>;
  286. regulator-max-microvolt = <5000000>;
  287. gpio = <&gpio0 7 1>;
  288. };
  289. };
  290. ahb@80080000 {
  291. mac0: ethernet@800f0000 {
  292. phy-mode = "rmii";
  293. pinctrl-names = "default";
  294. pinctrl-0 = <&mac0_pins_a
  295. &mac0_pins_cfa10049>;
  296. phy-reset-gpios = <&gpio2 21 0>;
  297. phy-reset-duration = <100>;
  298. status = "okay";
  299. };
  300. };
  301. spi2 {
  302. compatible = "spi-gpio";
  303. pinctrl-names = "default";
  304. pinctrl-0 = <&spi2_pins_cfa10049>;
  305. status = "okay";
  306. gpio-sck = <&gpio2 16 0>;
  307. gpio-mosi = <&gpio2 17 0>;
  308. gpio-miso = <&gpio2 18 0>;
  309. cs-gpios = <&gpio3 5 0>;
  310. num-chipselects = <1>;
  311. #address-cells = <1>;
  312. #size-cells = <0>;
  313. hx8357: hx8357@0 {
  314. compatible = "himax,hx8357b", "himax,hx8357";
  315. reg = <0>;
  316. spi-max-frequency = <100000>;
  317. spi-cpol;
  318. spi-cpha;
  319. gpios-reset = <&gpio3 30 0>;
  320. im-gpios = <&gpio5 4 0 &gpio5 5 0 &gpio5 6 0>;
  321. };
  322. };
  323. spi3 {
  324. compatible = "spi-gpio";
  325. pinctrl-names = "default";
  326. pinctrl-0 = <&spi3_pins_cfa10049>;
  327. status = "okay";
  328. gpio-sck = <&gpio0 24 0>;
  329. gpio-mosi = <&gpio0 28 0>;
  330. cs-gpios = <&gpio0 17 0 &gpio0 26 0 &gpio0 27 0>;
  331. num-chipselects = <3>;
  332. #address-cells = <1>;
  333. #size-cells = <0>;
  334. gpio5: gpio5@0 {
  335. compatible = "fairchild,74hc595";
  336. gpio-controller;
  337. #gpio-cells = <2>;
  338. reg = <0>;
  339. registers-number = <2>;
  340. spi-max-frequency = <100000>;
  341. };
  342. gpio6: gpio6@1 {
  343. compatible = "fairchild,74hc595";
  344. gpio-controller;
  345. #gpio-cells = <2>;
  346. reg = <1>;
  347. registers-number = <4>;
  348. spi-max-frequency = <100000>;
  349. };
  350. dac0: dh2228@2 {
  351. compatible = "rohm,dh2228fv";
  352. reg = <2>;
  353. spi-max-frequency = <100000>;
  354. };
  355. };
  356. gpio_keys {
  357. compatible = "gpio-keys";
  358. pinctrl-names = "default";
  359. pinctrl-0 = <&rotary_btn_pins_cfa10049>;
  360. #address-cells = <1>;
  361. #size-cells = <0>;
  362. rotary_button {
  363. label = "rotary_button";
  364. gpios = <&gpio3 26 1>;
  365. debounce-interval = <10>;
  366. linux,code = <28>;
  367. };
  368. };
  369. rotary {
  370. compatible = "rotary-encoder";
  371. pinctrl-names = "default";
  372. pinctrl-0 = <&rotary_pins_cfa10049>;
  373. gpios = <&gpio3 24 1>, <&gpio3 25 1>;
  374. linux,axis = <1>; /* REL_Y */
  375. rotary-encoder,relative-axis;
  376. };
  377. backlight {
  378. compatible = "pwm-backlight";
  379. pwms = <&pwm 3 5000000>;
  380. brightness-levels = <0 4 8 16 32 64 128 255>;
  381. default-brightness-level = <6>;
  382. };
  383. onewire@0 {
  384. compatible = "w1-gpio";
  385. pinctrl-names = "default";
  386. pinctrl-0 = <&w1_gpio_pins>;
  387. status = "okay";
  388. gpios = <&gpio1 21 0>;
  389. };
  390. };