berlin-bg2.c 9.4 KB

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