imx6q-gk802.dts 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /*
  2. * Copyright (C) 2013 Philipp Zabel
  3. *
  4. * This file is licensed under the terms of the GNU General Public License
  5. * version 2. This program is licensed "as is" without any warranty of any
  6. * kind, whether express or implied.
  7. */
  8. /dts-v1/;
  9. #include "imx6q.dtsi"
  10. / {
  11. model = "Zealz GK802";
  12. compatible = "zealz,imx6q-gk802", "fsl,imx6q";
  13. chosen {
  14. stdout-path = &uart4;
  15. };
  16. memory {
  17. reg = <0x10000000 0x40000000>;
  18. };
  19. regulators {
  20. compatible = "simple-bus";
  21. #address-cells = <1>;
  22. #size-cells = <0>;
  23. reg_3p3v: regulator@0 {
  24. compatible = "regulator-fixed";
  25. reg = <0>;
  26. regulator-name = "3P3V";
  27. regulator-min-microvolt = <3300000>;
  28. regulator-max-microvolt = <3300000>;
  29. regulator-always-on;
  30. };
  31. };
  32. gpio-keys {
  33. compatible = "gpio-keys";
  34. recovery-button {
  35. label = "recovery";
  36. gpios = <&gpio3 16 1>;
  37. linux,code = <0x198>; /* KEY_RESTART */
  38. gpio-key,wakeup;
  39. };
  40. };
  41. };
  42. &hdmi {
  43. ddc-i2c-bus = <&i2c3>;
  44. status = "okay";
  45. };
  46. /* Internal I2C */
  47. &i2c2 {
  48. pinctrl-names = "default";
  49. pinctrl-0 = <&pinctrl_i2c2>;
  50. clock-frequency = <100000>;
  51. status = "okay";
  52. /* SDMC DM2016 1024 bit EEPROM + 128 bit OTP */
  53. eeprom: dm2016@51 {
  54. compatible = "sdmc,dm2016";
  55. reg = <0x51>;
  56. };
  57. };
  58. /* External I2C via HDMI */
  59. &i2c3 {
  60. pinctrl-names = "default";
  61. pinctrl-0 = <&pinctrl_i2c3>;
  62. clock-frequency = <100000>;
  63. status = "okay";
  64. };
  65. &iomuxc {
  66. pinctrl-names = "default";
  67. pinctrl-0 = <&pinctrl_hog>;
  68. imx6q-gk802 {
  69. pinctrl_hog: hoggrp {
  70. fsl,pins = <
  71. /* Recovery button, active-low */
  72. MX6QDL_PAD_EIM_D16__GPIO3_IO16 0x100b1
  73. /* RTL8192CU enable GPIO, active-low */
  74. MX6QDL_PAD_NANDF_D0__GPIO2_IO00 0x1b0b0
  75. >;
  76. };
  77. pinctrl_i2c2: i2c2grp {
  78. fsl,pins = <
  79. MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1
  80. MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1
  81. >;
  82. };
  83. pinctrl_i2c3: i2c3grp {
  84. fsl,pins = <
  85. MX6QDL_PAD_GPIO_5__I2C3_SCL 0x4001b8b1
  86. MX6QDL_PAD_GPIO_16__I2C3_SDA 0x4001b8b1
  87. >;
  88. };
  89. pinctrl_uart4: uart4grp {
  90. fsl,pins = <
  91. MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1
  92. MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1
  93. >;
  94. };
  95. pinctrl_usdhc3: usdhc3grp {
  96. fsl,pins = <
  97. MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17059
  98. MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10059
  99. MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059
  100. MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059
  101. MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059
  102. MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059
  103. >;
  104. };
  105. pinctrl_usdhc4: usdhc4grp {
  106. fsl,pins = <
  107. MX6QDL_PAD_SD4_CMD__SD4_CMD 0x17059
  108. MX6QDL_PAD_SD4_CLK__SD4_CLK 0x10059
  109. MX6QDL_PAD_SD4_DAT0__SD4_DATA0 0x17059
  110. MX6QDL_PAD_SD4_DAT1__SD4_DATA1 0x17059
  111. MX6QDL_PAD_SD4_DAT2__SD4_DATA2 0x17059
  112. MX6QDL_PAD_SD4_DAT3__SD4_DATA3 0x17059
  113. >;
  114. };
  115. };
  116. };
  117. &uart2 {
  118. status = "okay";
  119. };
  120. &uart4 {
  121. pinctrl-names = "default";
  122. pinctrl-0 = <&pinctrl_uart4>;
  123. status = "okay";
  124. };
  125. /* External USB-A port (USBOTG) */
  126. &usbotg {
  127. disable-over-current;
  128. status = "okay";
  129. };
  130. /* Internal USB port (USBH1), connected to RTL8192CU */
  131. &usbh1 {
  132. disable-over-current;
  133. status = "okay";
  134. };
  135. /* External microSD */
  136. &usdhc3 {
  137. pinctrl-names = "default";
  138. pinctrl-0 = <&pinctrl_usdhc3>;
  139. bus-width = <4>;
  140. cd-gpios = <&gpio6 11 0>;
  141. vmmc-supply = <&reg_3p3v>;
  142. status = "okay";
  143. };
  144. /* Internal microSD */
  145. &usdhc4 {
  146. pinctrl-names = "default";
  147. pinctrl-0 = <&pinctrl_usdhc4>;
  148. bus-width = <4>;
  149. vmmc-supply = <&reg_3p3v>;
  150. status = "okay";
  151. };