ark1668e-pinctrl.dtsi 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. #include <dt-bindings/pinctrl/ark-pinfunc.h>
  2. &pinctrl0 {
  3. i2c0 {
  4. pinctrl_i2c0: i2c0-0 {
  5. ark,pins =
  6. <ARK_PBANK_3 22 ARK_PVAL_1 /* i2c0 scl */
  7. ARK_PBANK_3 23 ARK_PVAL_1>; /* i2c0 sda */
  8. };
  9. };
  10. pwm {
  11. pinctrl_pwm0: pwm-0 {
  12. ark,pins =
  13. <ARK_PBANK_1 18 ARK_PVAL_1>;
  14. };
  15. pinctrl_pwm1: pwm-1 {
  16. ark,pins =
  17. <ARK_PBANK_1 19 ARK_PVAL_1>;
  18. };
  19. pinctrl_pwm2: pwm-2 {
  20. ark,pins =
  21. <ARK_PBANK_1 20 ARK_PVAL_1>;
  22. };
  23. pinctrl_pwm3: pwm-3 {
  24. ark,pins =
  25. <ARK_PBANK_1 21 ARK_PVAL_1>;
  26. };
  27. pinctrl_pwm4: pwm-4 {
  28. ark,pins =
  29. <ARK_PBANK_3 0 ARK_PVAL_2>;
  30. };
  31. pinctrl_pwm5: pwm-5 {
  32. ark,pins =
  33. <ARK_PBANK_3 1 ARK_PVAL_2>;
  34. };
  35. };
  36. spi {
  37. pinctrl_ecspi: ecspi {
  38. ark,pins =
  39. <ARK_PBANK_4 30 ARK_PVAL_1 /* rxd */
  40. ARK_PBANK_4 31 ARK_PVAL_1 /* clk */
  41. ARK_PBANK_5 0 ARK_PVAL_1>; /* txd */
  42. //ARK_PBANK_5 1 ARK_PVAL_1>; /* cs */
  43. group-mux = <0x204 19 1 1>;
  44. };
  45. pinctrl_dwssi: dwssi {
  46. ark,pins =
  47. <ARK_PBANK_3 2 ARK_PVAL_1 /*clk*/
  48. ARK_PBANK_3 3 ARK_PVAL_1 /*rxd*/
  49. ARK_PBANK_3 4 ARK_PVAL_1 /*txd*/
  50. /* ARK_PBANK_3 5 ARK_PVAL_1 [>cs<] */
  51. ARK_PBANK_4 18 ARK_PVAL_1 /*d2*/
  52. ARK_PBANK_4 19 ARK_PVAL_1>; /*d3*/
  53. };
  54. };
  55. uart {
  56. pinctrl_uart0: uart0-0 {
  57. ark,pins =
  58. <ARK_PBANK_3 6 ARK_PVAL_1 /* uart0 rx */
  59. ARK_PBANK_3 7 ARK_PVAL_1>; /* uart0 tx */
  60. };
  61. pinctrl_uart1: uart1-0 {
  62. ark,pins =
  63. <ARK_PBANK_3 8 ARK_PVAL_1 /* uart1 rx */
  64. ARK_PBANK_3 9 ARK_PVAL_1>; /* uart1 tx */
  65. };
  66. pinctrl_uart2: uart2-0 {
  67. ark,pins =
  68. <ARK_PBANK_3 14 ARK_PVAL_1 /* uart2 rx */
  69. ARK_PBANK_3 15 ARK_PVAL_1>; /* uart2 tx */
  70. };
  71. pinctrl_uart3: uart3-0 {
  72. ark,pins =
  73. <ARK_PBANK_3 18 ARK_PVAL_1 /* uart3 rx */
  74. ARK_PBANK_3 19 ARK_PVAL_1>; /* uart3 tx */
  75. };
  76. pinctrl_hsuart0: hsuart0-0 {
  77. ark,pins =
  78. <ARK_PBANK_3 10 ARK_PVAL_1 /* hsuart0 rx */
  79. ARK_PBANK_3 11 ARK_PVAL_1 /* hsuart0 tx */
  80. ARK_PBANK_3 16 ARK_PVAL_1 /* hsuart0 rts */
  81. ARK_PBANK_3 17 ARK_PVAL_1>; /* hsuart0 cts */
  82. };
  83. pinctrl_hsuart1: hsuart1-0 {
  84. ark,pins =
  85. <ARK_PBANK_3 12 ARK_PVAL_1 /* hsuart1 rx */
  86. ARK_PBANK_3 13 ARK_PVAL_1 /* hsuart1 tx */
  87. ARK_PBANK_3 20 ARK_PVAL_1 /* hsuart1 rts */
  88. ARK_PBANK_3 21 ARK_PVAL_1>; /* hsuart1 cts */
  89. };
  90. };
  91. lcd {
  92. pinctrl_lcd_hi_impedance: lcd-hi-impedance {
  93. ark,pins =
  94. <ARK_PBANK_1 22 ARK_PVAL_7 /* r0 */
  95. ARK_PBANK_1 23 ARK_PVAL_7 /* r1 */
  96. ARK_PBANK_1 24 ARK_PVAL_5 /* r2 */
  97. ARK_PBANK_1 25 ARK_PVAL_5 /* r3 */
  98. ARK_PBANK_1 26 ARK_PVAL_5 /* r4 */
  99. ARK_PBANK_1 27 ARK_PVAL_5 /* r5 */
  100. ARK_PBANK_1 28 ARK_PVAL_5 /* r6 */
  101. ARK_PBANK_1 29 ARK_PVAL_5 /* r7 */
  102. ARK_PBANK_1 30 ARK_PVAL_0 /* g0 */
  103. ARK_PBANK_1 31 ARK_PVAL_0 /* g1 */
  104. ARK_PBANK_2 0 ARK_PVAL_0 /* g2 */
  105. ARK_PBANK_2 1 ARK_PVAL_0 /* g3 */
  106. ARK_PBANK_2 2 ARK_PVAL_0 /* g4 */
  107. ARK_PBANK_2 3 ARK_PVAL_0 /* g5 */
  108. ARK_PBANK_2 4 ARK_PVAL_0 /* g6 */
  109. ARK_PBANK_2 5 ARK_PVAL_0 /* g7 */
  110. ARK_PBANK_2 6 ARK_PVAL_0 /* b0 */
  111. ARK_PBANK_2 7 ARK_PVAL_0 /* b1 */
  112. ARK_PBANK_2 8 ARK_PVAL_0 /* b2 */
  113. ARK_PBANK_2 9 ARK_PVAL_0 /* b3 */
  114. ARK_PBANK_2 10 ARK_PVAL_0 /* b4 */
  115. ARK_PBANK_2 11 ARK_PVAL_0 /* b5 */
  116. ARK_PBANK_2 12 ARK_PVAL_0 /* b6 */
  117. ARK_PBANK_2 13 ARK_PVAL_0 /* b7 */
  118. ARK_PBANK_2 14 ARK_PVAL_0 /* de */
  119. ARK_PBANK_2 15 ARK_PVAL_0 /* clk */
  120. ARK_PBANK_2 16 ARK_PVAL_0 /* vsync */
  121. ARK_PBANK_2 17 ARK_PVAL_0>; /* hsync */
  122. };
  123. pinctrl_lcd_rgb888: lcd-rgb-0 {
  124. ark,pins =
  125. <ARK_PBANK_1 22 ARK_PVAL_1 /* r0 */
  126. ARK_PBANK_1 23 ARK_PVAL_1 /* r1 */
  127. ARK_PBANK_1 24 ARK_PVAL_1 /* r2 */
  128. ARK_PBANK_1 25 ARK_PVAL_1 /* r3 */
  129. ARK_PBANK_1 26 ARK_PVAL_1 /* r4 */
  130. ARK_PBANK_1 27 ARK_PVAL_1 /* r5 */
  131. ARK_PBANK_1 28 ARK_PVAL_1 /* r6 */
  132. ARK_PBANK_1 29 ARK_PVAL_1 /* r7 */
  133. ARK_PBANK_1 30 ARK_PVAL_1 /* g0 */
  134. ARK_PBANK_1 31 ARK_PVAL_1 /* g1 */
  135. ARK_PBANK_2 0 ARK_PVAL_1 /* g2 */
  136. ARK_PBANK_2 1 ARK_PVAL_1 /* g3 */
  137. ARK_PBANK_2 2 ARK_PVAL_1 /* g4 */
  138. ARK_PBANK_2 3 ARK_PVAL_1 /* g5 */
  139. ARK_PBANK_2 4 ARK_PVAL_1 /* g6 */
  140. ARK_PBANK_2 5 ARK_PVAL_1 /* g7 */
  141. ARK_PBANK_2 6 ARK_PVAL_1 /* b0 */
  142. ARK_PBANK_2 7 ARK_PVAL_1 /* b1 */
  143. ARK_PBANK_2 8 ARK_PVAL_1 /* b2 */
  144. ARK_PBANK_2 9 ARK_PVAL_1 /* b3 */
  145. ARK_PBANK_2 10 ARK_PVAL_1 /* b4 */
  146. ARK_PBANK_2 11 ARK_PVAL_1 /* b5 */
  147. ARK_PBANK_2 12 ARK_PVAL_1 /* b6 */
  148. ARK_PBANK_2 13 ARK_PVAL_1 /* b7 */
  149. ARK_PBANK_2 14 ARK_PVAL_1 /* de */
  150. ARK_PBANK_2 15 ARK_PVAL_1 /* clk */
  151. ARK_PBANK_2 16 ARK_PVAL_1 /* vsync */
  152. ARK_PBANK_2 17 ARK_PVAL_1>; /* hsync */
  153. };
  154. pinctrl_lcd_dlvds: lcd-dlvds-0 {
  155. ark,pins =
  156. <ARK_PBANK_1 30 ARK_PVAL_1 /* odd_TA_OUTP */
  157. ARK_PBANK_1 31 ARK_PVAL_1 /* odd_TA_OUTN */
  158. ARK_PBANK_2 0 ARK_PVAL_1 /* odd_TB_OUTP */
  159. ARK_PBANK_2 1 ARK_PVAL_1 /* odd_TB_OUTN */
  160. ARK_PBANK_2 2 ARK_PVAL_1 /* odd_TC_OUTP */
  161. ARK_PBANK_2 3 ARK_PVAL_1 /* odd_TC_OUTN */
  162. ARK_PBANK_2 4 ARK_PVAL_1 /* odd_TD_OUTP */
  163. ARK_PBANK_2 5 ARK_PVAL_1 /* odd_TD_OUTN */
  164. ARK_PBANK_2 6 ARK_PVAL_1 /* even_TA_OUTP */
  165. ARK_PBANK_2 7 ARK_PVAL_1 /* even_TA_OUTN */
  166. ARK_PBANK_2 8 ARK_PVAL_1 /* even_TB_OUTP */
  167. ARK_PBANK_2 9 ARK_PVAL_1 /* even_TB_OUTN */
  168. ARK_PBANK_2 10 ARK_PVAL_1 /* even_TC_OUTP */
  169. ARK_PBANK_2 11 ARK_PVAL_1 /* even_TC_OUTN */
  170. ARK_PBANK_2 12 ARK_PVAL_1 /* even_TD_OUTP */
  171. ARK_PBANK_2 13 ARK_PVAL_1 /* even_TD_OUTN */
  172. ARK_PBANK_2 14 ARK_PVAL_1 /* odd_TCLK_OUTP */
  173. ARK_PBANK_2 15 ARK_PVAL_1 /* odd_TCLK_OUTN */
  174. ARK_PBANK_2 16 ARK_PVAL_1 /* even_TCLK_OUTP */
  175. ARK_PBANK_2 17 ARK_PVAL_1>; /* even_TCLK_OUTN */
  176. };
  177. };
  178. i2s {
  179. pinctrl_i2sadc_sync: i2s0-sync {
  180. ark,pins =
  181. <ARK_PBANK_1 7 ARK_PVAL_2>; /* i2s0 sync */
  182. group-mux = <0x204 10 1 1>;
  183. };
  184. pinctrl_i2sadc_sadata: i2s0-sadata {
  185. ark,pins =
  186. <ARK_PBANK_1 8 ARK_PVAL_2>; /* i2s0 sadata */
  187. group-mux = <0x204 8 1 1
  188. 0x204 28 1 0>; /* sadata in */
  189. };
  190. pinctrl_i2sadc_mclk: i2s0-mclk {
  191. ark,pins =
  192. <ARK_PBANK_1 9 ARK_PVAL_2>; /* i2s0 mclk */
  193. group-mux = <0x14c 16 1 0>;
  194. };
  195. pinctrl_i2sadc_bclk: i2s0-bclk {
  196. ark,pins =
  197. <ARK_PBANK_1 10 ARK_PVAL_2>; /* i2s0 bclk */
  198. //<ARK_PBANK_1 10 ARK_PVAL_4>; /* i2s1 bclk out (use for fpga i2s1 playback master mode) */
  199. group-mux = <0x204 9 1 1
  200. 0x204 4 1 0>;
  201. };
  202. pinctrl_i2sdac_sync: i2s1-sync {
  203. ark,pins =
  204. <ARK_PBANK_1 11 ARK_PVAL_2>; /* i2s1 sync */
  205. group-mux = <0x204 14 1 1>;
  206. };
  207. pinctrl_i2sdac_sadata: i2s1-sadata {
  208. ark,pins =
  209. <ARK_PBANK_1 12 ARK_PVAL_2>; /* i2s1 sadata */
  210. group-mux = <0x204 29 1 1>; /* sadata in/out */
  211. };
  212. pinctrl_i2sdac_sadata_in: i2s1-sadata-in {
  213. ark,pins =
  214. <ARK_PBANK_1 12 ARK_PVAL_2>; /* i2s1 sadata */
  215. group-mux = <0x204 29 1 0>; /* sadata in/out */
  216. };
  217. pinctrl_i2sdac_mclk: i2s1-mclk {
  218. ark,pins =
  219. <ARK_PBANK_1 13 ARK_PVAL_2>; /* i2s1 mclk */
  220. group-mux = <0x14c 17 1 1>;
  221. };
  222. pinctrl_i2sdac_bclk: i2s1-bclk {
  223. ark,pins =
  224. <ARK_PBANK_1 14 ARK_PVAL_2>; /* i2s1 bclk */
  225. group-mux = <0x204 13 1 1
  226. 0x204 5 1 1>;
  227. };
  228. pinctrl_i2sdac_sadata_out: i2s1-sadata-out {
  229. ark,pins =
  230. <ARK_PBANK_1 15 ARK_PVAL_2>; /* i2s1 sadata out */
  231. group-mux = <0x204 12 1 0>; /*i2s1 sadata out*/
  232. };
  233. pinctrl_i2s2dac_sync: i2s2-sync {
  234. ark,pins =
  235. <ARK_PBANK_4 14 ARK_PVAL_1>; /* i2s2 sync */
  236. };
  237. pinctrl_i2s2dac_sadata_out: i2s2-sadata {
  238. ark,pins =
  239. <ARK_PBANK_4 15 ARK_PVAL_1>; /* i2s2 sadata */
  240. group-mux = <0x204 30 1 1>; /* sadata out */
  241. };
  242. pinctrl_i2s2dac_mclk: i2s2-mclk {
  243. ark,pins =
  244. <ARK_PBANK_4 16 ARK_PVAL_1>; /* i2s2 mclk */
  245. };
  246. pinctrl_i2s2dac_bclk: i2s2-bclk {
  247. ark,pins =
  248. <ARK_PBANK_4 17 ARK_PVAL_1>; /* i2s2 bclk */
  249. };
  250. };
  251. itu {
  252. pinctrl_hvsync: hvsync {
  253. ark,pins =
  254. <ARK_PBANK_1 16 ARK_PVAL_1 /* hsync */
  255. ARK_PBANK_1 17 ARK_PVAL_1>; /* vsync */
  256. };
  257. pinctrl_itu0: itu0 {
  258. ark,pins =
  259. <ARK_PBANK_0 21 ARK_PVAL_1 /* d0 */
  260. ARK_PBANK_0 22 ARK_PVAL_1 /* d1 */
  261. ARK_PBANK_0 23 ARK_PVAL_1 /* d2 */
  262. ARK_PBANK_0 24 ARK_PVAL_1 /* d3 */
  263. ARK_PBANK_0 25 ARK_PVAL_1 /* d4 */
  264. ARK_PBANK_0 26 ARK_PVAL_1 /* d5 */
  265. ARK_PBANK_0 27 ARK_PVAL_1 /* d6 */
  266. ARK_PBANK_0 28 ARK_PVAL_1 /* d7 */
  267. ARK_PBANK_0 29 ARK_PVAL_1>; /* clk */
  268. group-mux = <0x204 24 0xf 0>;
  269. };
  270. pinctrl_itu1: itu1 {
  271. ark,pins =
  272. <ARK_PBANK_0 30 ARK_PVAL_1 /* d0 */
  273. ARK_PBANK_0 31 ARK_PVAL_1 /* d1 */
  274. ARK_PBANK_1 0 ARK_PVAL_1 /* d2 */
  275. ARK_PBANK_1 1 ARK_PVAL_1 /* d3 */
  276. ARK_PBANK_1 2 ARK_PVAL_1 /* d4 */
  277. ARK_PBANK_1 3 ARK_PVAL_1 /* d5 */
  278. ARK_PBANK_1 4 ARK_PVAL_1 /* d6 */
  279. ARK_PBANK_1 5 ARK_PVAL_1 /* d7 */
  280. ARK_PBANK_1 6 ARK_PVAL_1>; /* clk */
  281. group-mux = <0x204 24 0xf 5>;
  282. };
  283. pinctrl_itu2: itu2 {
  284. ark,pins =
  285. <ARK_PBANK_1 7 ARK_PVAL_1 /* d0 */
  286. ARK_PBANK_1 8 ARK_PVAL_1 /* d1 */
  287. ARK_PBANK_1 9 ARK_PVAL_1 /* d2 */
  288. ARK_PBANK_1 10 ARK_PVAL_1 /* d3 */
  289. ARK_PBANK_1 11 ARK_PVAL_1 /* d4 */
  290. ARK_PBANK_1 12 ARK_PVAL_1 /* d5 */
  291. ARK_PBANK_1 13 ARK_PVAL_1 /* d6 */
  292. ARK_PBANK_1 14 ARK_PVAL_1 /* d7 */
  293. ARK_PBANK_1 15 ARK_PVAL_1>; /* clk */
  294. group-mux = <0x204 24 0xf 0xa>;
  295. };
  296. };
  297. can {
  298. pinctrl_can0: can0{
  299. ark,pins =
  300. <ARK_PBANK_4 26 ARK_PVAL_1 /* can0 tx */
  301. ARK_PBANK_4 27 ARK_PVAL_1>; /* can0 rx */
  302. };
  303. pinctrl_can1: can1{
  304. ark,pins =
  305. <ARK_PBANK_4 28 ARK_PVAL_1 /* can1 tx */
  306. ARK_PBANK_4 29 ARK_PVAL_1>; /* can1 rx */
  307. };
  308. };
  309. };