berlin-bg2q.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Marvell Berlin BG2Q pinctrl driver
  4. *
  5. * Copyright (C) 2014 Marvell Technology Group Ltd.
  6. *
  7. * Antoine Ténart <[email protected]>
  8. */
  9. #include <linux/init.h>
  10. #include <linux/of_device.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/regmap.h>
  13. #include "berlin.h"
  14. static const struct berlin_desc_group berlin2q_soc_pinctrl_groups[] = {
  15. /* G */
  16. BERLIN_PINCTRL_GROUP("G0", 0x18, 0x3, 0x00,
  17. BERLIN_PINCTRL_FUNCTION(0x0, "nand"),
  18. BERLIN_PINCTRL_FUNCTION(0x1, "mmc"),
  19. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  20. BERLIN_PINCTRL_GROUP("G1", 0x18, 0x3, 0x03,
  21. BERLIN_PINCTRL_FUNCTION(0x0, "nand"),
  22. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  23. BERLIN_PINCTRL_GROUP("G2", 0x18, 0x3, 0x06,
  24. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  25. BERLIN_PINCTRL_FUNCTION(0x2, "arc"),
  26. BERLIN_PINCTRL_FUNCTION(0x3, "lvds")),
  27. BERLIN_PINCTRL_GROUP("G3", 0x18, 0x3, 0x09,
  28. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  29. BERLIN_PINCTRL_FUNCTION(0x2, "i2s2"),
  30. BERLIN_PINCTRL_FUNCTION(0x3, "lvds")),
  31. BERLIN_PINCTRL_GROUP("G4", 0x18, 0x3, 0x0c,
  32. BERLIN_PINCTRL_FUNCTION(0x0, "pll"),
  33. BERLIN_PINCTRL_FUNCTION(0x1, "sd0"),
  34. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  35. BERLIN_PINCTRL_FUNCTION(0x3, "gpio"),
  36. BERLIN_PINCTRL_FUNCTION(0x5, "sata_dbg"),
  37. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  38. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  39. BERLIN_PINCTRL_GROUP("G5", 0x18, 0x3, 0x0f,
  40. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  41. BERLIN_PINCTRL_FUNCTION(0x1, "sd0"),
  42. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  43. BERLIN_PINCTRL_FUNCTION(0x5, "sata_dbg"),
  44. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  45. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  46. BERLIN_PINCTRL_GROUP("G6", 0x18, 0x3, 0x12,
  47. BERLIN_PINCTRL_FUNCTION(0x0, "jtag"),
  48. BERLIN_PINCTRL_FUNCTION(0x1, "twsi0"),
  49. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  50. BERLIN_PINCTRL_GROUP("G7", 0x18, 0x3, 0x15,
  51. BERLIN_PINCTRL_FUNCTION(0x0, "jtag"),
  52. BERLIN_PINCTRL_FUNCTION(0x1, "twsi1"),
  53. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  54. BERLIN_PINCTRL_FUNCTION(0x3, "eddc")),
  55. BERLIN_PINCTRL_GROUP("G8", 0x18, 0x3, 0x18,
  56. BERLIN_PINCTRL_FUNCTION(0x0, "spi1"), /* CLK/SDI/SDO */
  57. BERLIN_PINCTRL_FUNCTION(0x1, "gpio")),
  58. BERLIN_PINCTRL_GROUP("G9", 0x18, 0x3, 0x1b,
  59. BERLIN_PINCTRL_FUNCTION(0x0, "spi1"), /* SS0n/SS1n */
  60. BERLIN_PINCTRL_FUNCTION(0x1, "gpio"),
  61. BERLIN_PINCTRL_FUNCTION(0x5, "sata")),
  62. BERLIN_PINCTRL_GROUP("G10", 0x1c, 0x3, 0x00,
  63. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  64. BERLIN_PINCTRL_FUNCTION(0x1, "spi1"), /* SS2n */
  65. BERLIN_PINCTRL_FUNCTION(0x3, "i2s0"),
  66. BERLIN_PINCTRL_FUNCTION(0x4, "pwm"),
  67. BERLIN_PINCTRL_FUNCTION(0x5, "sata")),
  68. BERLIN_PINCTRL_GROUP("G11", 0x1c, 0x3, 0x03,
  69. BERLIN_PINCTRL_FUNCTION(0x0, "jtag"),
  70. BERLIN_PINCTRL_FUNCTION(0x1, "spi1"), /* SS3n */
  71. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  72. BERLIN_PINCTRL_FUNCTION(0x3, "i2s1"),
  73. BERLIN_PINCTRL_FUNCTION(0x4, "pwm"),
  74. BERLIN_PINCTRL_FUNCTION(0x5, "sata")),
  75. BERLIN_PINCTRL_GROUP("G12", 0x1c, 0x3, 0x06,
  76. BERLIN_PINCTRL_FUNCTION(0x0, "agc"),
  77. BERLIN_PINCTRL_FUNCTION(0x1, "gpio")),
  78. BERLIN_PINCTRL_GROUP("G13", 0x1c, 0x3, 0x09,
  79. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  80. BERLIN_PINCTRL_FUNCTION(0x1, "sts1"),
  81. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  82. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  83. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  84. BERLIN_PINCTRL_GROUP("G14", 0x1c, 0x3, 0x0c,
  85. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  86. BERLIN_PINCTRL_FUNCTION(0x1, "sts0"),
  87. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  88. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  89. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  90. BERLIN_PINCTRL_GROUP("G15", 0x1c, 0x3, 0x0f,
  91. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  92. BERLIN_PINCTRL_FUNCTION(0x1, "sts0"),
  93. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  94. BERLIN_PINCTRL_FUNCTION(0x5, "vdac"),
  95. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  96. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  97. BERLIN_PINCTRL_GROUP("G16", 0x1c, 0x3, 0x12,
  98. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  99. BERLIN_PINCTRL_FUNCTION(0x1, "sts0"),
  100. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  101. BERLIN_PINCTRL_FUNCTION(0x5, "osco"),
  102. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  103. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  104. BERLIN_PINCTRL_GROUP("G17", 0x1c, 0x3, 0x15,
  105. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  106. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  107. BERLIN_PINCTRL_FUNCTION(0x3, "spdif"),
  108. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  109. BERLIN_PINCTRL_FUNCTION(0x6, "usb0_dbg"),
  110. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  111. BERLIN_PINCTRL_GROUP("G18", 0x1c, 0x3, 0x18,
  112. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  113. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  114. BERLIN_PINCTRL_FUNCTION(0x3, "i2s2"),
  115. BERLIN_PINCTRL_FUNCTION(0x4, "sts1")),
  116. BERLIN_PINCTRL_GROUP("G19", 0x1c, 0x3, 0x1b,
  117. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  118. BERLIN_PINCTRL_FUNCTION(0x2, "rgmii"),
  119. BERLIN_PINCTRL_FUNCTION(0x3, "i2s3"),
  120. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  121. BERLIN_PINCTRL_FUNCTION(0x5, "osco")),
  122. BERLIN_PINCTRL_GROUP("G20", 0x20, 0x3, 0x00,
  123. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  124. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  125. BERLIN_PINCTRL_FUNCTION(0x3, "demod"),
  126. /*
  127. * Mode 0x4 mux usb2_dbg *and* usb3_dbg:
  128. * add two functions so it can be used with other groups
  129. * within the same subnode in the device tree
  130. */
  131. BERLIN_PINCTRL_FUNCTION(0x4, "usb2_dbg"),
  132. BERLIN_PINCTRL_FUNCTION(0x4, "usb3_dbg")),
  133. BERLIN_PINCTRL_GROUP("G21", 0x20, 0x3, 0x03,
  134. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  135. BERLIN_PINCTRL_FUNCTION(0x1, "sts2"),
  136. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  137. BERLIN_PINCTRL_FUNCTION(0x3, "demod")),
  138. BERLIN_PINCTRL_GROUP("G22", 0x20, 0x3, 0x06,
  139. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  140. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  141. BERLIN_PINCTRL_GROUP("G23", 0x20, 0x3, 0x09,
  142. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  143. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  144. BERLIN_PINCTRL_FUNCTION(0x3, "avif"),
  145. BERLIN_PINCTRL_FUNCTION(0x4, "usb2_dbg")),
  146. BERLIN_PINCTRL_GROUP("G24", 0x20, 0x3, 0x0c,
  147. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  148. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  149. BERLIN_PINCTRL_FUNCTION(0x3, "demod"),
  150. BERLIN_PINCTRL_FUNCTION(0x4, "usb2_dbg")),
  151. BERLIN_PINCTRL_GROUP("G25", 0x20, 0x3, 0x0f,
  152. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  153. BERLIN_PINCTRL_FUNCTION(0x1, "vga"),
  154. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  155. BERLIN_PINCTRL_FUNCTION(0x3, "avif"),
  156. BERLIN_PINCTRL_FUNCTION(0x4, "usb2_dbg")),
  157. BERLIN_PINCTRL_GROUP("G26", 0x20, 0x3, 0x12,
  158. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  159. BERLIN_PINCTRL_FUNCTION(0x1, "lvds"),
  160. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  161. BERLIN_PINCTRL_GROUP("G27", 0x20, 0x3, 0x15,
  162. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  163. BERLIN_PINCTRL_FUNCTION(0x1, "agc"),
  164. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  165. BERLIN_PINCTRL_GROUP("G28", 0x20, 0x3, 0x18,
  166. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  167. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  168. BERLIN_PINCTRL_FUNCTION(0x3, "avif"),
  169. BERLIN_PINCTRL_FUNCTION(0x4, "usb2_dbg")),
  170. BERLIN_PINCTRL_GROUP("G29", 0x20, 0x3, 0x1b,
  171. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  172. BERLIN_PINCTRL_FUNCTION(0x1, "scrd0"),
  173. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  174. BERLIN_PINCTRL_GROUP("G30", 0x24, 0x3, 0x00,
  175. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  176. BERLIN_PINCTRL_FUNCTION(0x1, "scrd1"),
  177. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  178. BERLIN_PINCTRL_GROUP("G31", 0x24, 0x3, 0x03,
  179. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  180. BERLIN_PINCTRL_FUNCTION(0x1, "sd1"),
  181. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  182. BERLIN_PINCTRL_GROUP("G32", 0x24, 0x3, 0x06,
  183. BERLIN_PINCTRL_FUNCTION(0x0, "cam"),
  184. BERLIN_PINCTRL_FUNCTION(0x1, "sd1"),
  185. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  186. /* GAV */
  187. BERLIN_PINCTRL_GROUP("GAV0", 0x24, 0x3, 0x09,
  188. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  189. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  190. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  191. BERLIN_PINCTRL_FUNCTION(0x4, "lvds")),
  192. BERLIN_PINCTRL_GROUP("GAV1", 0x24, 0x3, 0x0c,
  193. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  194. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  195. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  196. BERLIN_PINCTRL_FUNCTION(0x4, "vga")),
  197. BERLIN_PINCTRL_GROUP("GAV2", 0x24, 0x3, 0x0f,
  198. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  199. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  200. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  201. BERLIN_PINCTRL_FUNCTION(0x3, "i2s3"),
  202. BERLIN_PINCTRL_FUNCTION(0x4, "pdm"),
  203. BERLIN_PINCTRL_FUNCTION(0x6, "adac")),
  204. BERLIN_PINCTRL_GROUP("GAV3", 0x24, 0x3, 0x12,
  205. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  206. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  207. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  208. BERLIN_PINCTRL_FUNCTION(0x3, "i2s3"),
  209. BERLIN_PINCTRL_FUNCTION(0x6, "adac")),
  210. BERLIN_PINCTRL_GROUP("GAV4", 0x24, 0x3, 0x15,
  211. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  212. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  213. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  214. BERLIN_PINCTRL_FUNCTION(0x4, "i2s1"),
  215. BERLIN_PINCTRL_FUNCTION(0x6, "adac")),
  216. BERLIN_PINCTRL_GROUP("GAV5", 0x24, 0x3, 0x18,
  217. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  218. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  219. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  220. BERLIN_PINCTRL_FUNCTION(0x4, "spdif")),
  221. BERLIN_PINCTRL_GROUP("GAV6", 0x24, 0x3, 0x1b,
  222. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  223. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  224. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  225. BERLIN_PINCTRL_FUNCTION(0x4, "i2s2")),
  226. BERLIN_PINCTRL_GROUP("GAV7", 0x28, 0x3, 0x00,
  227. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  228. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  229. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  230. BERLIN_PINCTRL_FUNCTION(0x4, "i2s3")),
  231. BERLIN_PINCTRL_GROUP("GAV8", 0x28, 0x3, 0x03,
  232. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  233. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  234. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  235. BERLIN_PINCTRL_FUNCTION(0x4, "pwm")),
  236. BERLIN_PINCTRL_GROUP("GAV9", 0x28, 0x3, 0x06,
  237. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  238. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  239. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  240. BERLIN_PINCTRL_FUNCTION(0x4, "pwm")),
  241. BERLIN_PINCTRL_GROUP("GAV10", 0x28, 0x3, 0x09,
  242. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  243. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  244. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  245. BERLIN_PINCTRL_FUNCTION(0x4, "agc")),
  246. BERLIN_PINCTRL_GROUP("GAV11", 0x28, 0x3, 0x0c,
  247. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  248. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  249. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  250. BERLIN_PINCTRL_FUNCTION(0x3, "i2s0"),
  251. BERLIN_PINCTRL_FUNCTION(0x4, "pwm"),
  252. BERLIN_PINCTRL_FUNCTION(0x5, "vclki")),
  253. BERLIN_PINCTRL_GROUP("GAV12", 0x28, 0x3, 0x0f,
  254. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  255. BERLIN_PINCTRL_FUNCTION(0x1, "i2s2"),
  256. BERLIN_PINCTRL_FUNCTION(0x2, "i2s1")),
  257. BERLIN_PINCTRL_GROUP("GAV13", 0x28, 0x3, 0x12,
  258. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  259. BERLIN_PINCTRL_FUNCTION(0x1, "i2s2")),
  260. BERLIN_PINCTRL_GROUP("GAV14", 0x28, 0x3, 0x15,
  261. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  262. BERLIN_PINCTRL_FUNCTION(0x1, "i2s2"),
  263. BERLIN_PINCTRL_FUNCTION(0x2, "i2s1")),
  264. BERLIN_PINCTRL_GROUP("GAV15", 0x28, 0x3, 0x18,
  265. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  266. BERLIN_PINCTRL_FUNCTION(0x1, "i2s1"),
  267. BERLIN_PINCTRL_FUNCTION(0x6, "dac_dbg")),
  268. BERLIN_PINCTRL_GROUP("GAV16", 0x28, 0x3, 0x1b,
  269. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  270. BERLIN_PINCTRL_FUNCTION(0x1, "i2s0"),
  271. BERLIN_PINCTRL_FUNCTION(0x2, "i2s1"),
  272. BERLIN_PINCTRL_FUNCTION(0x4, "i2s3"),
  273. BERLIN_PINCTRL_FUNCTION(0x5, "pdm"),
  274. BERLIN_PINCTRL_FUNCTION(0x6, "dac_dbg")),
  275. BERLIN_PINCTRL_GROUP("GAV17", 0x2c, 0x3, 0x00,
  276. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  277. BERLIN_PINCTRL_FUNCTION(0x1, "i2s0"),
  278. BERLIN_PINCTRL_FUNCTION(0x2, "i2s1"),
  279. BERLIN_PINCTRL_FUNCTION(0x3, "pwm"),
  280. BERLIN_PINCTRL_FUNCTION(0x4, "i2s3"),
  281. BERLIN_PINCTRL_FUNCTION(0x5, "pdm"),
  282. BERLIN_PINCTRL_FUNCTION(0x6, "dac_dbg")),
  283. BERLIN_PINCTRL_GROUP("GAV18", 0x2c, 0x3, 0x03,
  284. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  285. BERLIN_PINCTRL_FUNCTION(0x1, "spdif"),
  286. BERLIN_PINCTRL_FUNCTION(0x2, "arc")),
  287. BERLIN_PINCTRL_GROUP("GAV19", 0x2c, 0x3, 0x06,
  288. BERLIN_PINCTRL_FUNCTION(0x0, "avio"),
  289. BERLIN_PINCTRL_FUNCTION(0x1, "spdif"),
  290. BERLIN_PINCTRL_FUNCTION(0x4, "i2s3"),
  291. BERLIN_PINCTRL_FUNCTION(0x5, "pdm")),
  292. };
  293. static const struct berlin_desc_group berlin2q_sysmgr_pinctrl_groups[] = {
  294. /* GSM */
  295. BERLIN_PINCTRL_GROUP("GSM0", 0x40, 0x2, 0x00,
  296. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  297. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* SS0n */
  298. BERLIN_PINCTRL_FUNCTION(0x2, "eth1")),
  299. BERLIN_PINCTRL_GROUP("GSM1", 0x40, 0x2, 0x02,
  300. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  301. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* SS1n */
  302. BERLIN_PINCTRL_FUNCTION(0x2, "eth1")),
  303. BERLIN_PINCTRL_GROUP("GSM2", 0x40, 0x2, 0x04,
  304. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  305. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* SS2n/SS3n */
  306. BERLIN_PINCTRL_FUNCTION(0x2, "eddc")),
  307. BERLIN_PINCTRL_GROUP("GSM3", 0x40, 0x2, 0x06,
  308. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  309. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* CLK/SDO */
  310. BERLIN_PINCTRL_FUNCTION(0x2, "eddc")),
  311. BERLIN_PINCTRL_GROUP("GSM4", 0x40, 0x1, 0x08,
  312. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  313. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  314. BERLIN_PINCTRL_GROUP("GSM5", 0x40, 0x1, 0x09,
  315. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  316. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  317. BERLIN_PINCTRL_GROUP("GSM6", 0x40, 0x1, 0x0a,
  318. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  319. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  320. BERLIN_PINCTRL_GROUP("GSM7", 0x40, 0x1, 0x0b,
  321. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  322. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  323. BERLIN_PINCTRL_GROUP("GSM8", 0x40, 0x1, 0x0c,
  324. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  325. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  326. BERLIN_PINCTRL_GROUP("GSM9", 0x40, 0x1, 0x0d,
  327. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  328. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  329. BERLIN_PINCTRL_GROUP("GSM10", 0x40, 0x1, 0x0e,
  330. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  331. BERLIN_PINCTRL_FUNCTION(0x1, "led")),
  332. BERLIN_PINCTRL_GROUP("GSM11", 0x40, 0x1, 0x0f,
  333. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  334. BERLIN_PINCTRL_FUNCTION(0x1, "led")),
  335. BERLIN_PINCTRL_GROUP("GSM12", 0x40, 0x2, 0x10,
  336. BERLIN_PINCTRL_FUNCTION(0x0, "uart0"), /* RX/TX */
  337. BERLIN_PINCTRL_FUNCTION(0x1, "irda0"),
  338. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  339. BERLIN_PINCTRL_GROUP("GSM13", 0x40, 0x2, 0x12,
  340. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  341. BERLIN_PINCTRL_FUNCTION(0x1, "uart0"), /* CTS/RTS */
  342. BERLIN_PINCTRL_FUNCTION(0x2, "uart1"), /* RX/TX */
  343. BERLIN_PINCTRL_FUNCTION(0x3, "twsi2")),
  344. BERLIN_PINCTRL_GROUP("GSM14", 0x40, 0x2, 0x14,
  345. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  346. BERLIN_PINCTRL_FUNCTION(0x1, "uart1"), /* RX/TX */
  347. BERLIN_PINCTRL_FUNCTION(0x2, "irda1"),
  348. BERLIN_PINCTRL_FUNCTION(0x3, "twsi3")),
  349. BERLIN_PINCTRL_GROUP("GSM15", 0x40, 0x2, 0x16,
  350. BERLIN_PINCTRL_FUNCTION(0x0, "pwr"),
  351. BERLIN_PINCTRL_FUNCTION(0x1, "led"),
  352. BERLIN_PINCTRL_FUNCTION(0x2, "gpio")),
  353. BERLIN_PINCTRL_GROUP("GSM16", 0x40, 0x1, 0x18,
  354. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  355. BERLIN_PINCTRL_FUNCTION(0x1, "eddc")),
  356. BERLIN_PINCTRL_GROUP("GSM17", 0x40, 0x1, 0x19,
  357. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  358. BERLIN_PINCTRL_FUNCTION(0x1, "eddc")),
  359. BERLIN_PINCTRL_GROUP("GSM18", 0x40, 0x1, 0x1a,
  360. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  361. BERLIN_PINCTRL_FUNCTION(0x1, "eddc")),
  362. };
  363. static const struct berlin_pinctrl_desc berlin2q_soc_pinctrl_data = {
  364. .groups = berlin2q_soc_pinctrl_groups,
  365. .ngroups = ARRAY_SIZE(berlin2q_soc_pinctrl_groups),
  366. };
  367. static const struct berlin_pinctrl_desc berlin2q_sysmgr_pinctrl_data = {
  368. .groups = berlin2q_sysmgr_pinctrl_groups,
  369. .ngroups = ARRAY_SIZE(berlin2q_sysmgr_pinctrl_groups),
  370. };
  371. static const struct of_device_id berlin2q_pinctrl_match[] = {
  372. {
  373. .compatible = "marvell,berlin2q-soc-pinctrl",
  374. .data = &berlin2q_soc_pinctrl_data,
  375. },
  376. {
  377. .compatible = "marvell,berlin2q-system-pinctrl",
  378. .data = &berlin2q_sysmgr_pinctrl_data,
  379. },
  380. {}
  381. };
  382. static int berlin2q_pinctrl_probe(struct platform_device *pdev)
  383. {
  384. const struct of_device_id *match =
  385. of_match_device(berlin2q_pinctrl_match, &pdev->dev);
  386. return berlin_pinctrl_probe(pdev, match->data);
  387. }
  388. static struct platform_driver berlin2q_pinctrl_driver = {
  389. .probe = berlin2q_pinctrl_probe,
  390. .driver = {
  391. .name = "berlin-bg2q-pinctrl",
  392. .of_match_table = berlin2q_pinctrl_match,
  393. },
  394. };
  395. builtin_platform_driver(berlin2q_pinctrl_driver);