berlin-bg2.c 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Marvell Berlin BG2 pinctrl driver.
  4. *
  5. * Copyright (C) 2014 Marvell Technology Group Ltd.
  6. *
  7. * Antoine Ténart <antoine.tenart@free-electrons.com>
  8. */
  9. #include <linux/init.h>
  10. #include <linux/of.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/property.h>
  13. #include <linux/regmap.h>
  14. #include "berlin.h"
  15. static const struct berlin_desc_group berlin2_soc_pinctrl_groups[] = {
  16. /* G */
  17. BERLIN_PINCTRL_GROUP("G0", 0x00, 0x1, 0x00,
  18. BERLIN_PINCTRL_FUNCTION(0x0, "spi1"), /* SS0n */
  19. BERLIN_PINCTRL_FUNCTION(0x1, "gpio")),
  20. BERLIN_PINCTRL_GROUP("G1", 0x00, 0x2, 0x01,
  21. BERLIN_PINCTRL_FUNCTION(0x0, "spi1"), /* SS1n */
  22. BERLIN_PINCTRL_FUNCTION(0x1, "gpio"),
  23. BERLIN_PINCTRL_FUNCTION(0x2, "usb1")),
  24. BERLIN_PINCTRL_GROUP("G2", 0x00, 0x2, 0x02,
  25. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  26. BERLIN_PINCTRL_FUNCTION(0x1, "spi1"), /* SS2n */
  27. BERLIN_PINCTRL_FUNCTION(0x2, "pwm"),
  28. BERLIN_PINCTRL_FUNCTION(0x3, "i2s0")),
  29. BERLIN_PINCTRL_GROUP("G3", 0x00, 0x2, 0x04,
  30. BERLIN_PINCTRL_FUNCTION(0x0, "soc"),
  31. BERLIN_PINCTRL_FUNCTION(0x1, "spi1"), /* SS3n */
  32. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  33. BERLIN_PINCTRL_FUNCTION(0x3, "i2s1")),
  34. BERLIN_PINCTRL_GROUP("G4", 0x00, 0x2, 0x06,
  35. BERLIN_PINCTRL_FUNCTION(0x0, "spi1"), /* CLK/SDI/SDO */
  36. BERLIN_PINCTRL_FUNCTION(0x1, "gpio"),
  37. BERLIN_PINCTRL_FUNCTION(0x2, "pwm")),
  38. BERLIN_PINCTRL_GROUP("G5", 0x00, 0x3, 0x08,
  39. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  40. BERLIN_PINCTRL_FUNCTION(0x1, "sts1"),
  41. BERLIN_PINCTRL_FUNCTION(0x2, "et"),
  42. /*
  43. * Mode 0x3 mux i2s2 mclk *and* i2s3 mclk:
  44. * add two functions so it can be used with other groups
  45. * within the same subnode in the device tree
  46. */
  47. BERLIN_PINCTRL_FUNCTION(0x3, "i2s2"),
  48. BERLIN_PINCTRL_FUNCTION(0x3, "i2s3")),
  49. BERLIN_PINCTRL_GROUP("G6", 0x00, 0x2, 0x0b,
  50. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  51. BERLIN_PINCTRL_FUNCTION(0x1, "sts0"),
  52. BERLIN_PINCTRL_FUNCTION(0x2, "et")),
  53. BERLIN_PINCTRL_GROUP("G7", 0x00, 0x3, 0x0d,
  54. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  55. BERLIN_PINCTRL_FUNCTION(0x1, "sts0"),
  56. BERLIN_PINCTRL_FUNCTION(0x2, "et"),
  57. BERLIN_PINCTRL_FUNCTION(0x3, "vdac")),
  58. BERLIN_PINCTRL_GROUP("G8", 0x00, 0x3, 0x10,
  59. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  60. BERLIN_PINCTRL_FUNCTION(0x1, "sd0"),
  61. BERLIN_PINCTRL_FUNCTION(0x2, "et"),
  62. BERLIN_PINCTRL_FUNCTION(0x3, "usb0_dbg"),
  63. BERLIN_PINCTRL_FUNCTION(0x4, "sata_dbg"),
  64. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  65. BERLIN_PINCTRL_GROUP("G9", 0x00, 0x3, 0x13,
  66. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  67. BERLIN_PINCTRL_FUNCTION(0x1, "sd0"),
  68. BERLIN_PINCTRL_FUNCTION(0x2, "et"),
  69. BERLIN_PINCTRL_FUNCTION(0x3, "usb0_dbg"),
  70. BERLIN_PINCTRL_FUNCTION(0x4, "sata_dbg"),
  71. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  72. BERLIN_PINCTRL_GROUP("G10", 0x00, 0x2, 0x16,
  73. BERLIN_PINCTRL_FUNCTION(0x0, "soc"),
  74. BERLIN_PINCTRL_FUNCTION(0x1, "twsi0"),
  75. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  76. BERLIN_PINCTRL_FUNCTION(0x3, "ptp")),
  77. BERLIN_PINCTRL_GROUP("G11", 0x00, 0x2, 0x18,
  78. BERLIN_PINCTRL_FUNCTION(0x0, "soc"),
  79. BERLIN_PINCTRL_FUNCTION(0x1, "twsi1"),
  80. BERLIN_PINCTRL_FUNCTION(0x2, "gpio"),
  81. BERLIN_PINCTRL_FUNCTION(0x3, "eddc")),
  82. BERLIN_PINCTRL_GROUP("G12", 0x00, 0x3, 0x1a,
  83. BERLIN_PINCTRL_FUNCTION(0x0, "sts2"),
  84. BERLIN_PINCTRL_FUNCTION(0x1, "sata"),
  85. BERLIN_PINCTRL_FUNCTION(0x2, "sd1"),
  86. BERLIN_PINCTRL_FUNCTION(0x3, "usb0_dbg"),
  87. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  88. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  89. BERLIN_PINCTRL_GROUP("G13", 0x04, 0x3, 0x00,
  90. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  91. BERLIN_PINCTRL_FUNCTION(0x1, "sata"),
  92. BERLIN_PINCTRL_FUNCTION(0x2, "sd1"),
  93. BERLIN_PINCTRL_FUNCTION(0x3, "usb0_dbg"),
  94. BERLIN_PINCTRL_FUNCTION(0x4, "sts1"),
  95. BERLIN_PINCTRL_FUNCTION(0x7, "usb1_dbg")),
  96. BERLIN_PINCTRL_GROUP("G14", 0x04, 0x1, 0x03,
  97. BERLIN_PINCTRL_FUNCTION_UNKNOWN),
  98. BERLIN_PINCTRL_GROUP("G15", 0x04, 0x2, 0x04,
  99. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  100. BERLIN_PINCTRL_FUNCTION(0x2, "et"),
  101. BERLIN_PINCTRL_FUNCTION(0x3, "osco")),
  102. BERLIN_PINCTRL_GROUP("G16", 0x04, 0x3, 0x06,
  103. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  104. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  105. BERLIN_PINCTRL_FUNCTION(0x2, "fp")),
  106. BERLIN_PINCTRL_GROUP("G17", 0x04, 0x3, 0x09,
  107. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  108. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  109. BERLIN_PINCTRL_FUNCTION(0x2, "fp")),
  110. BERLIN_PINCTRL_GROUP("G18", 0x04, 0x1, 0x0c,
  111. BERLIN_PINCTRL_FUNCTION(0x0, "pll"),
  112. BERLIN_PINCTRL_FUNCTION(0x1, "i2s0")),
  113. BERLIN_PINCTRL_GROUP("G19", 0x04, 0x1, 0x0d,
  114. BERLIN_PINCTRL_FUNCTION(0x0, "i2s0"),
  115. BERLIN_PINCTRL_FUNCTION(0x1, "pwm")),
  116. BERLIN_PINCTRL_GROUP("G20", 0x04, 0x1, 0x0e,
  117. BERLIN_PINCTRL_FUNCTION(0x0, "spdif"),
  118. BERLIN_PINCTRL_FUNCTION(0x1, "arc")),
  119. BERLIN_PINCTRL_GROUP("G21", 0x04, 0x3, 0x0f,
  120. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  121. BERLIN_PINCTRL_FUNCTION(0x1, "dvio"),
  122. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  123. BERLIN_PINCTRL_FUNCTION(0x3, "adac_dbg"),
  124. BERLIN_PINCTRL_FUNCTION(0x4, "pdm_a"), /* gpio17..19,pdm */
  125. BERLIN_PINCTRL_FUNCTION(0x7, "pdm_b")), /* gpio12..14,pdm */
  126. BERLIN_PINCTRL_GROUP("G22", 0x04, 0x3, 0x12,
  127. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  128. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  129. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  130. BERLIN_PINCTRL_FUNCTION(0x3, "twsi0"),
  131. BERLIN_PINCTRL_FUNCTION(0x4, "pwm")),
  132. BERLIN_PINCTRL_GROUP("G23", 0x04, 0x3, 0x15,
  133. BERLIN_PINCTRL_FUNCTION(0x0, "vclki"),
  134. BERLIN_PINCTRL_FUNCTION(0x1, "dv0"),
  135. BERLIN_PINCTRL_FUNCTION(0x2, "fp"),
  136. BERLIN_PINCTRL_FUNCTION(0x3, "i2s0"),
  137. BERLIN_PINCTRL_FUNCTION(0x4, "pwm"),
  138. BERLIN_PINCTRL_FUNCTION(0x7, "pdm")),
  139. BERLIN_PINCTRL_GROUP("G24", 0x04, 0x2, 0x18,
  140. BERLIN_PINCTRL_FUNCTION(0x0, "i2s2"),
  141. BERLIN_PINCTRL_FUNCTION(0x1, "i2s1")),
  142. BERLIN_PINCTRL_GROUP("G25", 0x04, 0x2, 0x1a,
  143. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  144. BERLIN_PINCTRL_FUNCTION(0x1, "nand"),
  145. BERLIN_PINCTRL_FUNCTION(0x2, "i2s2")),
  146. BERLIN_PINCTRL_GROUP("G26", 0x04, 0x1, 0x1c,
  147. BERLIN_PINCTRL_FUNCTION(0x0, "nand"),
  148. BERLIN_PINCTRL_FUNCTION(0x1, "emmc")),
  149. BERLIN_PINCTRL_GROUP("G27", 0x04, 0x1, 0x1d,
  150. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  151. BERLIN_PINCTRL_FUNCTION(0x1, "nand")),
  152. BERLIN_PINCTRL_GROUP("G28", 0x04, 0x2, 0x1e,
  153. BERLIN_PINCTRL_FUNCTION(0x0, "dvo"),
  154. BERLIN_PINCTRL_FUNCTION(0x2, "sp")),
  155. };
  156. static const struct berlin_desc_group berlin2_sysmgr_pinctrl_groups[] = {
  157. /* GSM */
  158. BERLIN_PINCTRL_GROUP("GSM0", 0x40, 0x2, 0x00,
  159. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  160. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* SS0n */
  161. BERLIN_PINCTRL_FUNCTION(0x2, "eth1")),
  162. BERLIN_PINCTRL_GROUP("GSM1", 0x40, 0x2, 0x02,
  163. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  164. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* SS1n */
  165. BERLIN_PINCTRL_FUNCTION(0x2, "eth1")),
  166. BERLIN_PINCTRL_GROUP("GSM2", 0x40, 0x2, 0x04,
  167. BERLIN_PINCTRL_FUNCTION(0x0, "twsi2"),
  168. BERLIN_PINCTRL_FUNCTION(0x1, "spi2")), /* SS2n/SS3n */
  169. BERLIN_PINCTRL_GROUP("GSM3", 0x40, 0x2, 0x06,
  170. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  171. BERLIN_PINCTRL_FUNCTION(0x1, "uart0"), /* CTS/RTS */
  172. BERLIN_PINCTRL_FUNCTION(0x2, "uart2"), /* RX/TX */
  173. BERLIN_PINCTRL_FUNCTION(0x3, "twsi2")),
  174. BERLIN_PINCTRL_GROUP("GSM4", 0x40, 0x2, 0x08,
  175. BERLIN_PINCTRL_FUNCTION(0x0, "uart0"), /* RX/TX */
  176. BERLIN_PINCTRL_FUNCTION(0x1, "irda0")),
  177. BERLIN_PINCTRL_GROUP("GSM5", 0x40, 0x2, 0x0a,
  178. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  179. BERLIN_PINCTRL_FUNCTION(0x1, "uart1"), /* RX/TX */
  180. BERLIN_PINCTRL_FUNCTION(0x2, "irda1"),
  181. BERLIN_PINCTRL_FUNCTION(0x3, "twsi3")),
  182. BERLIN_PINCTRL_GROUP("GSM6", 0x40, 0x2, 0x0c,
  183. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  184. BERLIN_PINCTRL_FUNCTION(0x1, "spi2"), /* CLK/SDO */
  185. BERLIN_PINCTRL_FUNCTION(0x1, "clki")),
  186. BERLIN_PINCTRL_GROUP("GSM7", 0x40, 0x1, 0x0e,
  187. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  188. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  189. BERLIN_PINCTRL_GROUP("GSM8", 0x40, 0x1, 0x0f,
  190. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  191. BERLIN_PINCTRL_FUNCTION(0x1, "hdmi")),
  192. BERLIN_PINCTRL_GROUP("GSM9", 0x40, 0x1, 0x10,
  193. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  194. BERLIN_PINCTRL_FUNCTION(0x1, "led")),
  195. BERLIN_PINCTRL_GROUP("GSM10", 0x40, 0x1, 0x11,
  196. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  197. BERLIN_PINCTRL_FUNCTION(0x1, "led")),
  198. BERLIN_PINCTRL_GROUP("GSM11", 0x40, 0x1, 0x12,
  199. BERLIN_PINCTRL_FUNCTION(0x0, "gpio"),
  200. BERLIN_PINCTRL_FUNCTION(0x1, "led")),
  201. };
  202. static const struct berlin_pinctrl_desc berlin2_soc_pinctrl_data = {
  203. .groups = berlin2_soc_pinctrl_groups,
  204. .ngroups = ARRAY_SIZE(berlin2_soc_pinctrl_groups),
  205. };
  206. static const struct berlin_pinctrl_desc berlin2_sysmgr_pinctrl_data = {
  207. .groups = berlin2_sysmgr_pinctrl_groups,
  208. .ngroups = ARRAY_SIZE(berlin2_sysmgr_pinctrl_groups),
  209. };
  210. static const struct of_device_id berlin2_pinctrl_match[] = {
  211. {
  212. .compatible = "marvell,berlin2-soc-pinctrl",
  213. .data = &berlin2_soc_pinctrl_data
  214. },
  215. {
  216. .compatible = "marvell,berlin2-system-pinctrl",
  217. .data = &berlin2_sysmgr_pinctrl_data
  218. },
  219. {}
  220. };
  221. static int berlin2_pinctrl_probe(struct platform_device *pdev)
  222. {
  223. return berlin_pinctrl_probe(pdev, device_get_match_data(&pdev->dev));
  224. }
  225. static struct platform_driver berlin2_pinctrl_driver = {
  226. .probe = berlin2_pinctrl_probe,
  227. .driver = {
  228. .name = "berlin-bg2-pinctrl",
  229. .of_match_table = berlin2_pinctrl_match,
  230. },
  231. };
  232. builtin_platform_driver(berlin2_pinctrl_driver);