imx6dl-victgo.dts 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. // SPDX-License-Identifier: GPL-2.0-or-later OR MIT
  2. /*
  3. * Copyright (c) 2016 Protonic Holland
  4. * Copyright (c) 2020 Oleksij Rempel <[email protected]>, Pengutronix
  5. */
  6. /dts-v1/;
  7. #include "imx6dl.dtsi"
  8. #include "imx6qdl-vicut1.dtsi"
  9. / {
  10. model = "Kverneland TGO";
  11. compatible = "kvg,victgo", "fsl,imx6dl";
  12. gpio-keys {
  13. compatible = "gpio-keys";
  14. pinctrl-names = "default";
  15. pinctrl-0 = <&pinctrl_gpiokeys>;
  16. autorepeat;
  17. key-power {
  18. label = "Power Button";
  19. gpios = <&gpio2 23 GPIO_ACTIVE_LOW>;
  20. linux,code = <KEY_POWER>;
  21. wakeup-source;
  22. };
  23. key-enter {
  24. label = "Rotary Key";
  25. gpios = <&gpio2 05 GPIO_ACTIVE_LOW>;
  26. linux,code = <KEY_ENTER>;
  27. wakeup-source;
  28. };
  29. };
  30. iio-hwmon {
  31. compatible = "iio-hwmon";
  32. io-channels = <&vdiv_vaccu>, <&vdiv_hitch_pos>;
  33. };
  34. panel {
  35. compatible = "lg,lb070wv8";
  36. backlight = <&backlight_lcd>;
  37. power-supply = <&reg_3v3>;
  38. port {
  39. panel_in: endpoint {
  40. remote-endpoint = <&lvds0_out>;
  41. };
  42. };
  43. };
  44. clk50m_phy: phy-clock {
  45. compatible = "fixed-clock";
  46. #clock-cells = <0>;
  47. clock-frequency = <50000000>;
  48. };
  49. rotary-encoder {
  50. compatible = "rotary-encoder";
  51. pinctrl-0 = <&pinctrl_rotary_ch>;
  52. gpios = <&gpio2 3 GPIO_ACTIVE_HIGH>,
  53. <&gpio2 4 GPIO_ACTIVE_HIGH>;
  54. linux,axis = <REL_WHEEL>;
  55. rotary-encoder,steps-per-period = <4>;
  56. rotary-encoder,relative-axis;
  57. rotary-encoder,rollover;
  58. wakeup-source;
  59. };
  60. thermal-zones {
  61. chassis-thermal {
  62. polling-delay = <20000>;
  63. polling-delay-passive = <0>;
  64. thermal-sensors = <&tsens0>;
  65. };
  66. touch-thermal0 {
  67. polling-delay = <20000>;
  68. polling-delay-passive = <0>;
  69. thermal-sensors = <&touch_temp0>;
  70. };
  71. touch-thermal1 {
  72. polling-delay = <20000>;
  73. polling-delay-passive = <0>;
  74. thermal-sensors = <&touch_temp1>;
  75. };
  76. };
  77. touchscreen {
  78. compatible = "resistive-adc-touch";
  79. io-channels = <&adc_ts 1>, <&adc_ts 3>, <&adc_ts 4>,
  80. <&adc_ts 5>;
  81. io-channel-names = "y", "z1", "z2", "x";
  82. touchscreen-min-pressure = <64687>;
  83. touchscreen-inverted-y;
  84. touchscreen-x-plate-ohms = <300>;
  85. touchscreen-y-plate-ohms = <800>;
  86. };
  87. touch_temp0: touch-temperature-sensor0 {
  88. compatible = "generic-adc-thermal";
  89. #thermal-sensor-cells = <0>;
  90. io-channels = <&adc_ts 0>;
  91. io-channel-names = "sensor-channel";
  92. temperature-lookup-table = < (-40000) 736
  93. 85000 474>;
  94. };
  95. touch_temp1: touch-temperature-sensor1 {
  96. compatible = "generic-adc-thermal";
  97. #thermal-sensor-cells = <0>;
  98. io-channels = <&adc_ts 7>;
  99. io-channel-names = "sensor-channel";
  100. temperature-lookup-table = < (-40000) 826
  101. 85000 609>;
  102. };
  103. vdiv_vaccu: voltage-divider-vaccu {
  104. compatible = "voltage-divider";
  105. io-channels = <&adc_ts 2>;
  106. output-ohms = <2500>;
  107. full-ohms = <64000>;
  108. #io-channel-cells = <0>;
  109. };
  110. vdiv_hitch_pos: voltage-divider-hitch-pos {
  111. compatible = "voltage-divider";
  112. io-channels = <&adc_ts 6>;
  113. output-ohms = <3300>;
  114. full-ohms = <13300>;
  115. #io-channel-cells = <0>;
  116. };
  117. };
  118. &ecspi2 {
  119. cs-gpios = <&gpio5 12 GPIO_ACTIVE_LOW>;
  120. pinctrl-names = "default";
  121. pinctrl-0 = <&pinctrl_ecspi2>;
  122. status = "okay";
  123. adc_ts: adc@0 {
  124. compatible = "ti,tsc2046e-adc";
  125. reg = <0>;
  126. pinctrl-0 = <&pinctrl_touchscreen>;
  127. pinctrl-names = "default";
  128. spi-max-frequency = <1000000>;
  129. interrupts-extended = <&gpio5 8 IRQ_TYPE_LEVEL_LOW>;
  130. #io-channel-cells = <1>;
  131. #address-cells = <1>;
  132. #size-cells = <0>;
  133. channel@1 {
  134. reg = <1>;
  135. settling-time-us = <700>;
  136. oversampling-ratio = <5>;
  137. };
  138. channel@3 {
  139. reg = <3>;
  140. settling-time-us = <700>;
  141. oversampling-ratio = <5>;
  142. };
  143. channel@4 {
  144. reg = <4>;
  145. settling-time-us = <700>;
  146. oversampling-ratio = <5>;
  147. };
  148. channel@5 {
  149. reg = <5>;
  150. settling-time-us = <700>;
  151. oversampling-ratio = <5>;
  152. };
  153. };
  154. };
  155. &fec {
  156. pinctrl-names = "default";
  157. pinctrl-0 = <&pinctrl_enet>;
  158. phy-mode = "rmii";
  159. clocks = <&clks IMX6QDL_CLK_ENET>,
  160. <&clks IMX6QDL_CLK_ENET>,
  161. <&clk50m_phy>;
  162. clock-names = "ipg", "ahb", "ptp";
  163. phy-handle = <&rmii_phy>;
  164. status = "okay";
  165. mdio {
  166. #address-cells = <1>;
  167. #size-cells = <0>;
  168. /* Microchip KSZ8081RNA PHY */
  169. rmii_phy: ethernet-phy@0 {
  170. reg = <0>;
  171. interrupts-extended = <&gpio4 30 IRQ_TYPE_LEVEL_LOW>;
  172. reset-gpios = <&gpio4 26 GPIO_ACTIVE_LOW>;
  173. reset-assert-us = <10000>;
  174. reset-deassert-us = <300>;
  175. };
  176. };
  177. };
  178. &gpio1 {
  179. gpio-line-names =
  180. "CAN1_TERM", "SD1_CD", "ITU656_RESET", "CAM1_MIRROR",
  181. "CAM2_MIRROR", "", "", "SMBALERT",
  182. "DEBUG_0", "DEBUG_1", "", "", "", "", "", "",
  183. "SD1_DATA0", "SD1_DATA1", "SD1_CMD", "SD1_DATA2", "SD1_CLK",
  184. "SD1_DATA3", "ETH_MDIO", "",
  185. "", "", "", "", "", "", "", "ETH_MDC";
  186. };
  187. &gpio4 {
  188. gpio-line-names =
  189. "", "", "", "", "", "", "UART4_TXD", "UART4_RXD",
  190. "UART5_TXD", "UART5_RXD", "CAN1_TX", "CAN1_RX", "CAN1_SR",
  191. "CAN2_SR", "CAN2_TX", "CAN2_RX",
  192. "", "", "DIP1_FB", "", "VCAM_EN", "ON1_CTRL", "ON2_CTRL",
  193. "HITCH_IN_OUT",
  194. "LIGHT_ON", "", "ETH_RESET", "CONTACT_IN", "BL_EN",
  195. "BL_PWM", "ETH_INT", "ISB_LED";
  196. };
  197. &gpio5 {
  198. gpio-line-names =
  199. "", "", "", "", "", "", "", "",
  200. "TSC_PENIRQ", "TSC_BUSY", "ECSPI2_MOSI", "ECSPI2_MISO",
  201. "ECSPI2_SS0", "ECSPI2_SCLK", "", "",
  202. "", "", "ITU656_CLK", "I2S_MCLK", "ITU656_PDN", "AUDIO_RESET",
  203. "I2S_BITCLK", "I2S_DOUT",
  204. "I2S_LRCLK", "I2S_DIN", "I2C1_SDA", "I2C1_SCL", "YACO_AUX_RX",
  205. "YACO_AUX_TX", "ITU656_D0", "ITU656_D1";
  206. };
  207. &gpio6 {
  208. gpio-line-names =
  209. "ITU656_D2", "ITU656_D3", "ITU656_D4", "ITU656_D5",
  210. "ITU656_D6", "ITU656_D7", "", "",
  211. "", "", "", "", "", "", "", "",
  212. "", "", "", "", "", "", "", "",
  213. "", "", "", "", "", "", "", "";
  214. };
  215. &i2c1 {
  216. keypad@70 {
  217. compatible = "holtek,ht16k33";
  218. pinctrl-names = "default";
  219. pinctrl-0 = <&pinctrl_keypad>;
  220. reg = <0x70>;
  221. refresh-rate-hz = <20>;
  222. debounce-delay-ms = <50>;
  223. interrupts-extended = <&gpio4 5 (IRQ_TYPE_LEVEL_HIGH | IRQ_TYPE_EDGE_RISING)>;
  224. keypad,num-rows = <12>;
  225. keypad,num-columns = <3>;
  226. linux,keymap = <
  227. MATRIX_KEY(2, 0, KEY_F6)
  228. MATRIX_KEY(3, 0, KEY_F8)
  229. MATRIX_KEY(4, 0, KEY_F10)
  230. MATRIX_KEY(5, 0, KEY_F4)
  231. MATRIX_KEY(6, 0, KEY_F2)
  232. MATRIX_KEY(2, 1, KEY_F5)
  233. MATRIX_KEY(3, 1, KEY_F7)
  234. MATRIX_KEY(4, 1, KEY_F9)
  235. MATRIX_KEY(5, 1, KEY_F3)
  236. MATRIX_KEY(6, 1, KEY_F1)
  237. >;
  238. };
  239. };
  240. &iomuxc {
  241. pinctrl_ecspi2: ecspi2grp {
  242. fsl,pins = <
  243. MX6QDL_PAD_DISP0_DAT16__ECSPI2_MOSI 0x100b1
  244. MX6QDL_PAD_DISP0_DAT17__ECSPI2_MISO 0x100b1
  245. MX6QDL_PAD_DISP0_DAT18__GPIO5_IO12 0x100b1
  246. MX6QDL_PAD_DISP0_DAT19__ECSPI2_SCLK 0x100b1
  247. >;
  248. };
  249. pinctrl_enet: enetgrp {
  250. fsl,pins = <
  251. /* MX6QDL_ENET_PINGRP4 */
  252. MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0
  253. MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0
  254. MX6QDL_PAD_ENET_RXD0__ENET_RX_DATA0 0x1b0b0
  255. MX6QDL_PAD_ENET_RXD1__ENET_RX_DATA1 0x1b0b0
  256. MX6QDL_PAD_ENET_RX_ER__ENET_RX_ER 0x1b0b0
  257. MX6QDL_PAD_ENET_TX_EN__ENET_TX_EN 0x1b0b0
  258. MX6QDL_PAD_ENET_TXD0__ENET_TX_DATA0 0x1b0b0
  259. MX6QDL_PAD_ENET_TXD1__ENET_TX_DATA1 0x1b0b0
  260. MX6QDL_PAD_ENET_CRS_DV__ENET_RX_EN 0x1b0b0
  261. MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x1b0b0
  262. /* Phy reset */
  263. MX6QDL_PAD_DISP0_DAT5__GPIO4_IO26 0x1b0b0
  264. /* nINTRP */
  265. MX6QDL_PAD_DISP0_DAT9__GPIO4_IO30 0x1b0b0
  266. >;
  267. };
  268. pinctrl_gpiokeys: gpiokeygrp {
  269. fsl,pins = <
  270. /* ROTARY_BTN */
  271. MX6QDL_PAD_NANDF_D5__GPIO2_IO05 0x1b0b0
  272. /* nON_SWITCH */
  273. MX6QDL_PAD_EIM_CS0__GPIO2_IO23 0x1b0b0
  274. >;
  275. };
  276. pinctrl_keypad: keypadgrp {
  277. fsl,pins = <
  278. MX6QDL_PAD_GPIO_19__GPIO4_IO05 0x1b0b0
  279. >;
  280. };
  281. pinctrl_rotary_ch: rotarychgrp {
  282. fsl,pins = <
  283. MX6QDL_PAD_NANDF_D3__GPIO2_IO03 0x1b0b0
  284. MX6QDL_PAD_NANDF_D4__GPIO2_IO04 0x1b0b0
  285. >;
  286. };
  287. pinctrl_touchscreen: touchscreengrp {
  288. fsl,pins = <
  289. MX6QDL_PAD_DISP0_DAT14__GPIO5_IO08 0x1b0b0
  290. MX6QDL_PAD_DISP0_DAT15__GPIO5_IO09 0x1b0b0
  291. >;
  292. };
  293. };