imx6qdl-phytec-pfla02.dtsi 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. /*
  2. * Copyright 2013 Christian Hemp, Phytec Messtechnik GmbH
  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. #include <dt-bindings/gpio/gpio.h>
  12. / {
  13. model = "Phytec phyFLEX-i.MX6 Quad";
  14. compatible = "phytec,imx6q-pfla02", "fsl,imx6q";
  15. memory {
  16. reg = <0x10000000 0x80000000>;
  17. };
  18. regulators {
  19. compatible = "simple-bus";
  20. #address-cells = <1>;
  21. #size-cells = <0>;
  22. reg_usb_otg_vbus: regulator@0 {
  23. compatible = "regulator-fixed";
  24. reg = <0>;
  25. regulator-name = "usb_otg_vbus";
  26. regulator-min-microvolt = <5000000>;
  27. regulator-max-microvolt = <5000000>;
  28. gpio = <&gpio4 15 0>;
  29. enable-active-high;
  30. };
  31. reg_usb_h1_vbus: regulator@1 {
  32. compatible = "regulator-fixed";
  33. reg = <1>;
  34. regulator-name = "usb_h1_vbus";
  35. regulator-min-microvolt = <5000000>;
  36. regulator-max-microvolt = <5000000>;
  37. gpio = <&gpio1 0 0>;
  38. enable-active-high;
  39. };
  40. };
  41. gpio_leds: leds {
  42. compatible = "gpio-leds";
  43. green {
  44. label = "phyflex:green";
  45. gpios = <&gpio1 30 0>;
  46. };
  47. red {
  48. label = "phyflex:red";
  49. gpios = <&gpio2 31 0>;
  50. };
  51. };
  52. };
  53. &audmux {
  54. pinctrl-names = "default";
  55. pinctrl-0 = <&pinctrl_audmux>;
  56. status = "disabled";
  57. };
  58. &can1 {
  59. pinctrl-names = "default";
  60. pinctrl-0 = <&pinctrl_flexcan1>;
  61. status = "disabled";
  62. };
  63. &ecspi3 {
  64. pinctrl-names = "default";
  65. pinctrl-0 = <&pinctrl_ecspi3>;
  66. status = "okay";
  67. fsl,spi-num-chipselects = <1>;
  68. cs-gpios = <&gpio4 24 0>;
  69. flash@0 {
  70. compatible = "m25p80", "jedec,spi-nor";
  71. spi-max-frequency = <20000000>;
  72. reg = <0>;
  73. };
  74. };
  75. &fec {
  76. pinctrl-names = "default";
  77. pinctrl-0 = <&pinctrl_enet>;
  78. phy-mode = "rgmii";
  79. phy-reset-gpios = <&gpio3 23 GPIO_ACTIVE_LOW>;
  80. phy-supply = <&vdd_eth_io_reg>;
  81. status = "disabled";
  82. };
  83. &gpmi {
  84. pinctrl-names = "default";
  85. pinctrl-0 = <&pinctrl_gpmi_nand>;
  86. nand-on-flash-bbt;
  87. status = "okay";
  88. };
  89. &i2c1 {
  90. pinctrl-names = "default";
  91. pinctrl-0 = <&pinctrl_i2c1>;
  92. status = "okay";
  93. eeprom@50 {
  94. compatible = "atmel,24c32";
  95. reg = <0x50>;
  96. };
  97. pmic@58 {
  98. compatible = "dlg,da9063";
  99. reg = <0x58>;
  100. interrupt-parent = <&gpio2>;
  101. interrupts = <9 0x8>; /* active-low GPIO2_9 */
  102. regulators {
  103. vddcore_reg: bcore1 {
  104. regulator-min-microvolt = <730000>;
  105. regulator-max-microvolt = <1380000>;
  106. regulator-always-on;
  107. };
  108. vddsoc_reg: bcore2 {
  109. regulator-min-microvolt = <730000>;
  110. regulator-max-microvolt = <1380000>;
  111. regulator-always-on;
  112. };
  113. vdd_ddr3_reg: bpro {
  114. regulator-min-microvolt = <1500000>;
  115. regulator-max-microvolt = <1500000>;
  116. regulator-always-on;
  117. };
  118. vdd_3v3_reg: bperi {
  119. regulator-min-microvolt = <3300000>;
  120. regulator-max-microvolt = <3300000>;
  121. regulator-always-on;
  122. };
  123. vdd_buckmem_reg: bmem {
  124. regulator-min-microvolt = <3300000>;
  125. regulator-max-microvolt = <3300000>;
  126. regulator-always-on;
  127. };
  128. vdd_eth_reg: bio {
  129. regulator-min-microvolt = <1200000>;
  130. regulator-max-microvolt = <1200000>;
  131. regulator-always-on;
  132. };
  133. vdd_eth_io_reg: ldo4 {
  134. regulator-min-microvolt = <2500000>;
  135. regulator-max-microvolt = <2500000>;
  136. regulator-always-on;
  137. };
  138. vdd_mx6_snvs_reg: ldo5 {
  139. regulator-min-microvolt = <3000000>;
  140. regulator-max-microvolt = <3000000>;
  141. regulator-always-on;
  142. };
  143. vdd_3v3_pmic_io_reg: ldo6 {
  144. regulator-min-microvolt = <3300000>;
  145. regulator-max-microvolt = <3300000>;
  146. regulator-always-on;
  147. };
  148. vdd_sd0_reg: ldo9 {
  149. regulator-min-microvolt = <3300000>;
  150. regulator-max-microvolt = <3300000>;
  151. };
  152. vdd_sd1_reg: ldo10 {
  153. regulator-min-microvolt = <3300000>;
  154. regulator-max-microvolt = <3300000>;
  155. };
  156. vdd_mx6_high_reg: ldo11 {
  157. regulator-min-microvolt = <3000000>;
  158. regulator-max-microvolt = <3000000>;
  159. regulator-always-on;
  160. };
  161. };
  162. };
  163. };
  164. &i2c2 {
  165. pinctrl-names = "default";
  166. pinctrl-0 = <&pinctrl_i2c2>;
  167. clock-frequency = <100000>;
  168. };
  169. &i2c3 {
  170. pinctrl-names = "default";
  171. pinctrl-0 = <&pinctrl_i2c3>;
  172. clock-frequency = <100000>;
  173. };
  174. &iomuxc {
  175. pinctrl-names = "default";
  176. pinctrl-0 = <&pinctrl_hog>;
  177. imx6q-phytec-pfla02 {
  178. pinctrl_hog: hoggrp {
  179. fsl,pins = <
  180. MX6QDL_PAD_EIM_D23__GPIO3_IO23 0x80000000
  181. MX6QDL_PAD_DISP0_DAT3__GPIO4_IO24 0x80000000 /* SPI NOR chipselect */
  182. MX6QDL_PAD_SD4_DAT1__GPIO2_IO09 0x80000000 /* PMIC interrupt */
  183. MX6QDL_PAD_ENET_TXD0__GPIO1_IO30 0x80000000 /* Green LED */
  184. MX6QDL_PAD_EIM_EB3__GPIO2_IO31 0x80000000 /* Red LED */
  185. >;
  186. };
  187. pinctrl_ecspi3: ecspi3grp {
  188. fsl,pins = <
  189. MX6QDL_PAD_DISP0_DAT2__ECSPI3_MISO 0x100b1
  190. MX6QDL_PAD_DISP0_DAT1__ECSPI3_MOSI 0x100b1
  191. MX6QDL_PAD_DISP0_DAT0__ECSPI3_SCLK 0x100b1
  192. >;
  193. };
  194. pinctrl_enet: enetgrp {
  195. fsl,pins = <
  196. MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0
  197. MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0
  198. MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030
  199. MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030
  200. MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030
  201. MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030
  202. MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030
  203. MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030
  204. MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0
  205. MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030
  206. MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b030
  207. MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b030
  208. MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030
  209. MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030
  210. MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b030
  211. MX6QDL_PAD_ENET_TX_EN__ENET_TX_EN 0x1b0b0
  212. >;
  213. };
  214. pinctrl_flexcan1: flexcan1grp {
  215. fsl,pins = <
  216. MX6QDL_PAD_KEY_ROW2__FLEXCAN1_RX 0x1b0b0
  217. MX6QDL_PAD_KEY_COL2__FLEXCAN1_TX 0x1b0b0
  218. >;
  219. };
  220. pinctrl_gpmi_nand: gpminandgrp {
  221. fsl,pins = <
  222. MX6QDL_PAD_NANDF_CLE__NAND_CLE 0xb0b1
  223. MX6QDL_PAD_NANDF_ALE__NAND_ALE 0xb0b1
  224. MX6QDL_PAD_NANDF_WP_B__NAND_WP_B 0xb0b1
  225. MX6QDL_PAD_NANDF_RB0__NAND_READY_B 0xb000
  226. MX6QDL_PAD_NANDF_CS0__NAND_CE0_B 0xb0b1
  227. MX6QDL_PAD_NANDF_CS1__NAND_CE1_B 0xb0b1
  228. MX6QDL_PAD_SD4_CMD__NAND_RE_B 0xb0b1
  229. MX6QDL_PAD_SD4_CLK__NAND_WE_B 0xb0b1
  230. MX6QDL_PAD_NANDF_D0__NAND_DATA00 0xb0b1
  231. MX6QDL_PAD_NANDF_D1__NAND_DATA01 0xb0b1
  232. MX6QDL_PAD_NANDF_D2__NAND_DATA02 0xb0b1
  233. MX6QDL_PAD_NANDF_D3__NAND_DATA03 0xb0b1
  234. MX6QDL_PAD_NANDF_D4__NAND_DATA04 0xb0b1
  235. MX6QDL_PAD_NANDF_D5__NAND_DATA05 0xb0b1
  236. MX6QDL_PAD_NANDF_D6__NAND_DATA06 0xb0b1
  237. MX6QDL_PAD_NANDF_D7__NAND_DATA07 0xb0b1
  238. MX6QDL_PAD_SD4_DAT0__NAND_DQS 0x00b1
  239. >;
  240. };
  241. pinctrl_i2c1: i2c1grp {
  242. fsl,pins = <
  243. MX6QDL_PAD_EIM_D21__I2C1_SCL 0x4001b8b1
  244. MX6QDL_PAD_EIM_D28__I2C1_SDA 0x4001b8b1
  245. >;
  246. };
  247. pinctrl_i2c2: i2c2grp {
  248. fsl,pins = <
  249. MX6QDL_PAD_EIM_EB2__I2C2_SCL 0x4001b8b1
  250. MX6QDL_PAD_EIM_D16__I2C2_SDA 0x4001b8b1
  251. >;
  252. };
  253. pinctrl_i2c3: i2c3grp {
  254. fsl,pins = <
  255. MX6QDL_PAD_EIM_D17__I2C3_SCL 0x4001b8b1
  256. MX6QDL_PAD_EIM_D18__I2C3_SDA 0x4001b8b1
  257. >;
  258. };
  259. pinctrl_pcie: pciegrp {
  260. fsl,pins = <MX6QDL_PAD_DI0_PIN15__GPIO4_IO17 0x80000000>;
  261. };
  262. pinctrl_uart3: uart3grp {
  263. fsl,pins = <
  264. MX6QDL_PAD_EIM_D24__UART3_TX_DATA 0x1b0b1
  265. MX6QDL_PAD_EIM_D25__UART3_RX_DATA 0x1b0b1
  266. MX6QDL_PAD_EIM_D30__UART3_RTS_B 0x1b0b1
  267. MX6QDL_PAD_EIM_D31__UART3_CTS_B 0x1b0b1
  268. >;
  269. };
  270. pinctrl_uart4: uart4grp {
  271. fsl,pins = <
  272. MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1
  273. MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1
  274. >;
  275. };
  276. pinctrl_usbh1: usbh1grp {
  277. fsl,pins = <
  278. MX6QDL_PAD_GPIO_0__USB_H1_PWR 0x80000000
  279. >;
  280. };
  281. pinctrl_usbotg: usbotggrp {
  282. fsl,pins = <
  283. MX6QDL_PAD_GPIO_1__USB_OTG_ID 0x17059
  284. MX6QDL_PAD_KEY_COL4__USB_OTG_OC 0x1b0b0
  285. MX6QDL_PAD_KEY_ROW4__GPIO4_IO15 0x80000000
  286. >;
  287. };
  288. pinctrl_usdhc2: usdhc2grp {
  289. fsl,pins = <
  290. MX6QDL_PAD_SD2_CMD__SD2_CMD 0x17059
  291. MX6QDL_PAD_SD2_CLK__SD2_CLK 0x10059
  292. MX6QDL_PAD_SD2_DAT0__SD2_DATA0 0x17059
  293. MX6QDL_PAD_SD2_DAT1__SD2_DATA1 0x17059
  294. MX6QDL_PAD_SD2_DAT2__SD2_DATA2 0x17059
  295. MX6QDL_PAD_SD2_DAT3__SD2_DATA3 0x17059
  296. >;
  297. };
  298. pinctrl_usdhc3: usdhc3grp {
  299. fsl,pins = <
  300. MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17059
  301. MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10059
  302. MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059
  303. MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059
  304. MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059
  305. MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059
  306. >;
  307. };
  308. pinctrl_usdhc3_cdwp: usdhc3cdwp {
  309. fsl,pins = <
  310. MX6QDL_PAD_ENET_RXD0__GPIO1_IO27 0x80000000
  311. MX6QDL_PAD_ENET_TXD1__GPIO1_IO29 0x80000000
  312. >;
  313. };
  314. pinctrl_audmux: audmuxgrp {
  315. fsl,pins = <
  316. MX6QDL_PAD_DISP0_DAT16__AUD5_TXC 0x130b0
  317. MX6QDL_PAD_DISP0_DAT17__AUD5_TXD 0x110b0
  318. MX6QDL_PAD_DISP0_DAT18__AUD5_TXFS 0x130b0
  319. MX6QDL_PAD_DISP0_DAT19__AUD5_RXD 0x130b0
  320. >;
  321. };
  322. };
  323. };
  324. &pcie {
  325. pinctrl-names = "default";
  326. pinctrl-0 = <&pinctrl_pcie>;
  327. reset-gpio = <&gpio4 17 0>;
  328. status = "disabled";
  329. };
  330. &reg_arm {
  331. vin-supply = <&vddcore_reg>;
  332. };
  333. &reg_pu {
  334. vin-supply = <&vddsoc_reg>;
  335. };
  336. &reg_soc {
  337. vin-supply = <&vddsoc_reg>;
  338. };
  339. &uart3 {
  340. pinctrl-names = "default";
  341. pinctrl-0 = <&pinctrl_uart3>;
  342. status = "disabled";
  343. };
  344. &uart4 {
  345. pinctrl-names = "default";
  346. pinctrl-0 = <&pinctrl_uart4>;
  347. status = "disabled";
  348. };
  349. &usbh1 {
  350. vbus-supply = <&reg_usb_h1_vbus>;
  351. pinctrl-names = "default";
  352. pinctrl-0 = <&pinctrl_usbh1>;
  353. status = "disabled";
  354. };
  355. &usbotg {
  356. vbus-supply = <&reg_usb_otg_vbus>;
  357. pinctrl-names = "default";
  358. pinctrl-0 = <&pinctrl_usbotg>;
  359. disable-over-current;
  360. status = "disabled";
  361. };
  362. &usdhc2 {
  363. pinctrl-names = "default";
  364. pinctrl-0 = <&pinctrl_usdhc2>;
  365. cd-gpios = <&gpio1 4 GPIO_ACTIVE_LOW>;
  366. wp-gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
  367. status = "disabled";
  368. };
  369. &usdhc3 {
  370. pinctrl-names = "default";
  371. pinctrl-0 = <&pinctrl_usdhc3
  372. &pinctrl_usdhc3_cdwp>;
  373. cd-gpios = <&gpio1 27 GPIO_ACTIVE_LOW>;
  374. wp-gpios = <&gpio1 29 GPIO_ACTIVE_HIGH>;
  375. status = "disabled";
  376. };