pinctrl-falcon.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501
  1. /*
  2. * linux/drivers/pinctrl/pinmux-falcon.c
  3. * based on linux/drivers/pinctrl/pinmux-pxa910.c
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License version 2 as published
  7. * by the Free Software Foundation.
  8. *
  9. * Copyright (C) 2012 Thomas Langer <thomas.langer@lantiq.com>
  10. * Copyright (C) 2012 John Crispin <blogic@openwrt.org>
  11. */
  12. #include <linux/gpio.h>
  13. #include <linux/interrupt.h>
  14. #include <linux/slab.h>
  15. #include <linux/export.h>
  16. #include <linux/err.h>
  17. #include <linux/module.h>
  18. #include <linux/of.h>
  19. #include <linux/of_platform.h>
  20. #include <linux/of_address.h>
  21. #include <linux/of_gpio.h>
  22. #include <linux/platform_device.h>
  23. #include "pinctrl-lantiq.h"
  24. #include <lantiq_soc.h>
  25. /* Multiplexer Control Register */
  26. #define LTQ_PADC_MUX(x) (x * 0x4)
  27. /* Pull Up Enable Register */
  28. #define LTQ_PADC_PUEN 0x80
  29. /* Pull Down Enable Register */
  30. #define LTQ_PADC_PDEN 0x84
  31. /* Slew Rate Control Register */
  32. #define LTQ_PADC_SRC 0x88
  33. /* Drive Current Control Register */
  34. #define LTQ_PADC_DCC 0x8C
  35. /* Pad Control Availability Register */
  36. #define LTQ_PADC_AVAIL 0xF0
  37. #define pad_r32(p, reg) ltq_r32(p + reg)
  38. #define pad_w32(p, val, reg) ltq_w32(val, p + reg)
  39. #define pad_w32_mask(c, clear, set, reg) \
  40. pad_w32(c, (pad_r32(c, reg) & ~(clear)) | (set), reg)
  41. #define pad_getbit(m, r, p) (!!(ltq_r32(m + r) & (1 << p)))
  42. #define PORTS 5
  43. #define PINS 32
  44. #define PORT(x) (x / PINS)
  45. #define PORT_PIN(x) (x % PINS)
  46. #define MFP_FALCON(a, f0, f1, f2, f3) \
  47. { \
  48. .name = #a, \
  49. .pin = a, \
  50. .func = { \
  51. FALCON_MUX_##f0, \
  52. FALCON_MUX_##f1, \
  53. FALCON_MUX_##f2, \
  54. FALCON_MUX_##f3, \
  55. }, \
  56. }
  57. #define GRP_MUX(a, m, p) \
  58. { \
  59. .name = a, \
  60. .mux = FALCON_MUX_##m, \
  61. .pins = p, \
  62. .npins = ARRAY_SIZE(p), \
  63. }
  64. enum falcon_mux {
  65. FALCON_MUX_GPIO = 0,
  66. FALCON_MUX_RST,
  67. FALCON_MUX_NTR,
  68. FALCON_MUX_MDIO,
  69. FALCON_MUX_LED,
  70. FALCON_MUX_SPI,
  71. FALCON_MUX_ASC,
  72. FALCON_MUX_I2C,
  73. FALCON_MUX_HOSTIF,
  74. FALCON_MUX_SLIC,
  75. FALCON_MUX_JTAG,
  76. FALCON_MUX_PCM,
  77. FALCON_MUX_MII,
  78. FALCON_MUX_PHY,
  79. FALCON_MUX_NONE = 0xffff,
  80. };
  81. static struct pinctrl_pin_desc falcon_pads[PORTS * PINS];
  82. static int pad_count[PORTS];
  83. static void lantiq_load_pin_desc(struct pinctrl_pin_desc *d, int bank, int len)
  84. {
  85. int base = bank * PINS;
  86. int i;
  87. for (i = 0; i < len; i++) {
  88. /* strlen("ioXYZ") + 1 = 6 */
  89. char *name = kzalloc(6, GFP_KERNEL);
  90. snprintf(name, 6, "io%d", base + i);
  91. d[i].number = base + i;
  92. d[i].name = name;
  93. }
  94. pad_count[bank] = len;
  95. }
  96. static struct ltq_mfp_pin falcon_mfp[] = {
  97. /* pin f0 f1 f2 f3 */
  98. MFP_FALCON(GPIO0, RST, GPIO, NONE, NONE),
  99. MFP_FALCON(GPIO1, GPIO, GPIO, NONE, NONE),
  100. MFP_FALCON(GPIO2, GPIO, GPIO, NONE, NONE),
  101. MFP_FALCON(GPIO3, GPIO, GPIO, NONE, NONE),
  102. MFP_FALCON(GPIO4, NTR, GPIO, NONE, NONE),
  103. MFP_FALCON(GPIO5, NTR, GPIO, NONE, NONE),
  104. MFP_FALCON(GPIO6, RST, GPIO, NONE, NONE),
  105. MFP_FALCON(GPIO7, MDIO, GPIO, NONE, NONE),
  106. MFP_FALCON(GPIO8, MDIO, GPIO, NONE, NONE),
  107. MFP_FALCON(GPIO9, LED, GPIO, NONE, NONE),
  108. MFP_FALCON(GPIO10, LED, GPIO, NONE, NONE),
  109. MFP_FALCON(GPIO11, LED, GPIO, NONE, NONE),
  110. MFP_FALCON(GPIO12, LED, GPIO, NONE, NONE),
  111. MFP_FALCON(GPIO13, LED, GPIO, NONE, NONE),
  112. MFP_FALCON(GPIO14, LED, GPIO, NONE, NONE),
  113. MFP_FALCON(GPIO32, ASC, GPIO, NONE, NONE),
  114. MFP_FALCON(GPIO33, ASC, GPIO, NONE, NONE),
  115. MFP_FALCON(GPIO34, SPI, GPIO, NONE, NONE),
  116. MFP_FALCON(GPIO35, SPI, GPIO, NONE, NONE),
  117. MFP_FALCON(GPIO36, SPI, GPIO, NONE, NONE),
  118. MFP_FALCON(GPIO37, SPI, GPIO, NONE, NONE),
  119. MFP_FALCON(GPIO38, SPI, GPIO, NONE, NONE),
  120. MFP_FALCON(GPIO39, I2C, GPIO, NONE, NONE),
  121. MFP_FALCON(GPIO40, I2C, GPIO, NONE, NONE),
  122. MFP_FALCON(GPIO41, HOSTIF, GPIO, HOSTIF, JTAG),
  123. MFP_FALCON(GPIO42, HOSTIF, GPIO, HOSTIF, NONE),
  124. MFP_FALCON(GPIO43, SLIC, GPIO, NONE, NONE),
  125. MFP_FALCON(GPIO44, SLIC, GPIO, PCM, ASC),
  126. MFP_FALCON(GPIO45, SLIC, GPIO, PCM, ASC),
  127. MFP_FALCON(GPIO64, MII, GPIO, NONE, NONE),
  128. MFP_FALCON(GPIO65, MII, GPIO, NONE, NONE),
  129. MFP_FALCON(GPIO66, MII, GPIO, NONE, NONE),
  130. MFP_FALCON(GPIO67, MII, GPIO, NONE, NONE),
  131. MFP_FALCON(GPIO68, MII, GPIO, NONE, NONE),
  132. MFP_FALCON(GPIO69, MII, GPIO, NONE, NONE),
  133. MFP_FALCON(GPIO70, MII, GPIO, NONE, NONE),
  134. MFP_FALCON(GPIO71, MII, GPIO, NONE, NONE),
  135. MFP_FALCON(GPIO72, MII, GPIO, NONE, NONE),
  136. MFP_FALCON(GPIO73, MII, GPIO, NONE, NONE),
  137. MFP_FALCON(GPIO74, MII, GPIO, NONE, NONE),
  138. MFP_FALCON(GPIO75, MII, GPIO, NONE, NONE),
  139. MFP_FALCON(GPIO76, MII, GPIO, NONE, NONE),
  140. MFP_FALCON(GPIO77, MII, GPIO, NONE, NONE),
  141. MFP_FALCON(GPIO78, MII, GPIO, NONE, NONE),
  142. MFP_FALCON(GPIO79, MII, GPIO, NONE, NONE),
  143. MFP_FALCON(GPIO80, MII, GPIO, NONE, NONE),
  144. MFP_FALCON(GPIO81, MII, GPIO, NONE, NONE),
  145. MFP_FALCON(GPIO82, MII, GPIO, NONE, NONE),
  146. MFP_FALCON(GPIO83, MII, GPIO, NONE, NONE),
  147. MFP_FALCON(GPIO84, MII, GPIO, NONE, NONE),
  148. MFP_FALCON(GPIO85, MII, GPIO, NONE, NONE),
  149. MFP_FALCON(GPIO86, MII, GPIO, NONE, NONE),
  150. MFP_FALCON(GPIO87, MII, GPIO, NONE, NONE),
  151. MFP_FALCON(GPIO88, PHY, GPIO, NONE, NONE),
  152. };
  153. static const unsigned pins_por[] = {GPIO0};
  154. static const unsigned pins_ntr[] = {GPIO4};
  155. static const unsigned pins_ntr8k[] = {GPIO5};
  156. static const unsigned pins_hrst[] = {GPIO6};
  157. static const unsigned pins_mdio[] = {GPIO7, GPIO8};
  158. static const unsigned pins_bled[] = {GPIO9, GPIO10, GPIO11,
  159. GPIO12, GPIO13, GPIO14};
  160. static const unsigned pins_asc0[] = {GPIO32, GPIO33};
  161. static const unsigned pins_spi[] = {GPIO34, GPIO35, GPIO36};
  162. static const unsigned pins_spi_cs0[] = {GPIO37};
  163. static const unsigned pins_spi_cs1[] = {GPIO38};
  164. static const unsigned pins_i2c[] = {GPIO39, GPIO40};
  165. static const unsigned pins_jtag[] = {GPIO41};
  166. static const unsigned pins_slic[] = {GPIO43, GPIO44, GPIO45};
  167. static const unsigned pins_pcm[] = {GPIO44, GPIO45};
  168. static const unsigned pins_asc1[] = {GPIO44, GPIO45};
  169. static struct ltq_pin_group falcon_grps[] = {
  170. GRP_MUX("por", RST, pins_por),
  171. GRP_MUX("ntr", NTR, pins_ntr),
  172. GRP_MUX("ntr8k", NTR, pins_ntr8k),
  173. GRP_MUX("hrst", RST, pins_hrst),
  174. GRP_MUX("mdio", MDIO, pins_mdio),
  175. GRP_MUX("bootled", LED, pins_bled),
  176. GRP_MUX("asc0", ASC, pins_asc0),
  177. GRP_MUX("spi", SPI, pins_spi),
  178. GRP_MUX("spi cs0", SPI, pins_spi_cs0),
  179. GRP_MUX("spi cs1", SPI, pins_spi_cs1),
  180. GRP_MUX("i2c", I2C, pins_i2c),
  181. GRP_MUX("jtag", JTAG, pins_jtag),
  182. GRP_MUX("slic", SLIC, pins_slic),
  183. GRP_MUX("pcm", PCM, pins_pcm),
  184. GRP_MUX("asc1", ASC, pins_asc1),
  185. };
  186. static const char * const ltq_rst_grps[] = {"por", "hrst"};
  187. static const char * const ltq_ntr_grps[] = {"ntr", "ntr8k"};
  188. static const char * const ltq_mdio_grps[] = {"mdio"};
  189. static const char * const ltq_bled_grps[] = {"bootled"};
  190. static const char * const ltq_asc_grps[] = {"asc0", "asc1"};
  191. static const char * const ltq_spi_grps[] = {"spi", "spi cs0", "spi cs1"};
  192. static const char * const ltq_i2c_grps[] = {"i2c"};
  193. static const char * const ltq_jtag_grps[] = {"jtag"};
  194. static const char * const ltq_slic_grps[] = {"slic"};
  195. static const char * const ltq_pcm_grps[] = {"pcm"};
  196. static struct ltq_pmx_func falcon_funcs[] = {
  197. {"rst", ARRAY_AND_SIZE(ltq_rst_grps)},
  198. {"ntr", ARRAY_AND_SIZE(ltq_ntr_grps)},
  199. {"mdio", ARRAY_AND_SIZE(ltq_mdio_grps)},
  200. {"led", ARRAY_AND_SIZE(ltq_bled_grps)},
  201. {"asc", ARRAY_AND_SIZE(ltq_asc_grps)},
  202. {"spi", ARRAY_AND_SIZE(ltq_spi_grps)},
  203. {"i2c", ARRAY_AND_SIZE(ltq_i2c_grps)},
  204. {"jtag", ARRAY_AND_SIZE(ltq_jtag_grps)},
  205. {"slic", ARRAY_AND_SIZE(ltq_slic_grps)},
  206. {"pcm", ARRAY_AND_SIZE(ltq_pcm_grps)},
  207. };
  208. /* --------- pinconf related code --------- */
  209. static int falcon_pinconf_group_get(struct pinctrl_dev *pctrldev,
  210. unsigned group, unsigned long *config)
  211. {
  212. return -ENOTSUPP;
  213. }
  214. static int falcon_pinconf_group_set(struct pinctrl_dev *pctrldev,
  215. unsigned group, unsigned long config)
  216. {
  217. return -ENOTSUPP;
  218. }
  219. static int falcon_pinconf_get(struct pinctrl_dev *pctrldev,
  220. unsigned pin, unsigned long *config)
  221. {
  222. struct ltq_pinmux_info *info = pinctrl_dev_get_drvdata(pctrldev);
  223. enum ltq_pinconf_param param = LTQ_PINCONF_UNPACK_PARAM(*config);
  224. void __iomem *mem = info->membase[PORT(pin)];
  225. switch (param) {
  226. case LTQ_PINCONF_PARAM_DRIVE_CURRENT:
  227. *config = LTQ_PINCONF_PACK(param,
  228. !!pad_getbit(mem, LTQ_PADC_DCC, PORT_PIN(pin)));
  229. break;
  230. case LTQ_PINCONF_PARAM_SLEW_RATE:
  231. *config = LTQ_PINCONF_PACK(param,
  232. !!pad_getbit(mem, LTQ_PADC_SRC, PORT_PIN(pin)));
  233. break;
  234. case LTQ_PINCONF_PARAM_PULL:
  235. if (pad_getbit(mem, LTQ_PADC_PDEN, PORT_PIN(pin)))
  236. *config = LTQ_PINCONF_PACK(param, 1);
  237. else if (pad_getbit(mem, LTQ_PADC_PUEN, PORT_PIN(pin)))
  238. *config = LTQ_PINCONF_PACK(param, 2);
  239. else
  240. *config = LTQ_PINCONF_PACK(param, 0);
  241. break;
  242. default:
  243. return -ENOTSUPP;
  244. }
  245. return 0;
  246. }
  247. static int falcon_pinconf_set(struct pinctrl_dev *pctrldev,
  248. unsigned pin, unsigned long config)
  249. {
  250. enum ltq_pinconf_param param = LTQ_PINCONF_UNPACK_PARAM(config);
  251. int arg = LTQ_PINCONF_UNPACK_ARG(config);
  252. struct ltq_pinmux_info *info = pinctrl_dev_get_drvdata(pctrldev);
  253. void __iomem *mem = info->membase[PORT(pin)];
  254. u32 reg;
  255. switch (param) {
  256. case LTQ_PINCONF_PARAM_DRIVE_CURRENT:
  257. reg = LTQ_PADC_DCC;
  258. break;
  259. case LTQ_PINCONF_PARAM_SLEW_RATE:
  260. reg = LTQ_PADC_SRC;
  261. break;
  262. case LTQ_PINCONF_PARAM_PULL:
  263. if (arg == 1)
  264. reg = LTQ_PADC_PDEN;
  265. else
  266. reg = LTQ_PADC_PUEN;
  267. break;
  268. default:
  269. pr_err("%s: Invalid config param %04x\n",
  270. pinctrl_dev_get_name(pctrldev), param);
  271. return -ENOTSUPP;
  272. }
  273. pad_w32(mem, BIT(PORT_PIN(pin)), reg);
  274. if (!(pad_r32(mem, reg) & BIT(PORT_PIN(pin))))
  275. return -ENOTSUPP;
  276. return 0;
  277. }
  278. static void falcon_pinconf_dbg_show(struct pinctrl_dev *pctrldev,
  279. struct seq_file *s, unsigned offset)
  280. {
  281. unsigned long config;
  282. struct pin_desc *desc;
  283. struct ltq_pinmux_info *info = pinctrl_dev_get_drvdata(pctrldev);
  284. int port = PORT(offset);
  285. seq_printf(s, " (port %d) mux %d -- ", port,
  286. pad_r32(info->membase[port], LTQ_PADC_MUX(PORT_PIN(offset))));
  287. config = LTQ_PINCONF_PACK(LTQ_PINCONF_PARAM_PULL, 0);
  288. if (!falcon_pinconf_get(pctrldev, offset, &config))
  289. seq_printf(s, "pull %d ",
  290. (int)LTQ_PINCONF_UNPACK_ARG(config));
  291. config = LTQ_PINCONF_PACK(LTQ_PINCONF_PARAM_DRIVE_CURRENT, 0);
  292. if (!falcon_pinconf_get(pctrldev, offset, &config))
  293. seq_printf(s, "drive-current %d ",
  294. (int)LTQ_PINCONF_UNPACK_ARG(config));
  295. config = LTQ_PINCONF_PACK(LTQ_PINCONF_PARAM_SLEW_RATE, 0);
  296. if (!falcon_pinconf_get(pctrldev, offset, &config))
  297. seq_printf(s, "slew-rate %d ",
  298. (int)LTQ_PINCONF_UNPACK_ARG(config));
  299. desc = pin_desc_get(pctrldev, offset);
  300. if (desc) {
  301. if (desc->gpio_owner)
  302. seq_printf(s, " owner: %s", desc->gpio_owner);
  303. } else {
  304. seq_printf(s, " not registered");
  305. }
  306. }
  307. static void falcon_pinconf_group_dbg_show(struct pinctrl_dev *pctrldev,
  308. struct seq_file *s, unsigned selector)
  309. {
  310. }
  311. static struct pinconf_ops falcon_pinconf_ops = {
  312. .pin_config_get = falcon_pinconf_get,
  313. .pin_config_set = falcon_pinconf_set,
  314. .pin_config_group_get = falcon_pinconf_group_get,
  315. .pin_config_group_set = falcon_pinconf_group_set,
  316. .pin_config_dbg_show = falcon_pinconf_dbg_show,
  317. .pin_config_group_dbg_show = falcon_pinconf_group_dbg_show,
  318. };
  319. static struct pinctrl_desc falcon_pctrl_desc = {
  320. .owner = THIS_MODULE,
  321. .pins = falcon_pads,
  322. .confops = &falcon_pinconf_ops,
  323. };
  324. static inline int falcon_mux_apply(struct pinctrl_dev *pctrldev,
  325. int mfp, int mux)
  326. {
  327. struct ltq_pinmux_info *info = pinctrl_dev_get_drvdata(pctrldev);
  328. int port = PORT(info->mfp[mfp].pin);
  329. if ((port >= PORTS) || (!info->membase[port]))
  330. return -ENODEV;
  331. pad_w32(info->membase[port], mux,
  332. LTQ_PADC_MUX(PORT_PIN(info->mfp[mfp].pin)));
  333. return 0;
  334. }
  335. static const struct ltq_cfg_param falcon_cfg_params[] = {
  336. {"lantiq,pull", LTQ_PINCONF_PARAM_PULL},
  337. {"lantiq,drive-current", LTQ_PINCONF_PARAM_DRIVE_CURRENT},
  338. {"lantiq,slew-rate", LTQ_PINCONF_PARAM_SLEW_RATE},
  339. };
  340. static struct ltq_pinmux_info falcon_info = {
  341. .desc = &falcon_pctrl_desc,
  342. .apply_mux = falcon_mux_apply,
  343. .params = falcon_cfg_params,
  344. .num_params = ARRAY_SIZE(falcon_cfg_params),
  345. };
  346. /* --------- register the pinctrl layer --------- */
  347. int pinctrl_falcon_get_range_size(int id)
  348. {
  349. u32 avail;
  350. if ((id >= PORTS) || (!falcon_info.membase[id]))
  351. return -EINVAL;
  352. avail = pad_r32(falcon_info.membase[id], LTQ_PADC_AVAIL);
  353. return fls(avail);
  354. }
  355. void pinctrl_falcon_add_gpio_range(struct pinctrl_gpio_range *range)
  356. {
  357. pinctrl_add_gpio_range(falcon_info.pctrl, range);
  358. }
  359. static int pinctrl_falcon_probe(struct platform_device *pdev)
  360. {
  361. struct device_node *np;
  362. int pad_count = 0;
  363. int ret = 0;
  364. /* load and remap the pad resources of the different banks */
  365. for_each_compatible_node(np, NULL, "lantiq,pad-falcon") {
  366. struct platform_device *ppdev = of_find_device_by_node(np);
  367. const __be32 *bank = of_get_property(np, "lantiq,bank", NULL);
  368. struct resource res;
  369. u32 avail;
  370. int pins;
  371. if (!of_device_is_available(np))
  372. continue;
  373. if (!ppdev) {
  374. dev_err(&pdev->dev, "failed to find pad pdev\n");
  375. continue;
  376. }
  377. if (!bank || *bank >= PORTS)
  378. continue;
  379. if (of_address_to_resource(np, 0, &res))
  380. continue;
  381. falcon_info.clk[*bank] = clk_get(&ppdev->dev, NULL);
  382. if (IS_ERR(falcon_info.clk[*bank])) {
  383. dev_err(&ppdev->dev, "failed to get clock\n");
  384. return PTR_ERR(falcon_info.clk[*bank]);
  385. }
  386. falcon_info.membase[*bank] = devm_ioremap_resource(&pdev->dev,
  387. &res);
  388. if (IS_ERR(falcon_info.membase[*bank]))
  389. return PTR_ERR(falcon_info.membase[*bank]);
  390. avail = pad_r32(falcon_info.membase[*bank],
  391. LTQ_PADC_AVAIL);
  392. pins = fls(avail);
  393. lantiq_load_pin_desc(&falcon_pads[pad_count], *bank, pins);
  394. pad_count += pins;
  395. clk_enable(falcon_info.clk[*bank]);
  396. dev_dbg(&pdev->dev, "found %s with %d pads\n",
  397. res.name, pins);
  398. }
  399. dev_dbg(&pdev->dev, "found a total of %d pads\n", pad_count);
  400. falcon_pctrl_desc.name = dev_name(&pdev->dev);
  401. falcon_pctrl_desc.npins = pad_count;
  402. falcon_info.mfp = falcon_mfp;
  403. falcon_info.num_mfp = ARRAY_SIZE(falcon_mfp);
  404. falcon_info.grps = falcon_grps;
  405. falcon_info.num_grps = ARRAY_SIZE(falcon_grps);
  406. falcon_info.funcs = falcon_funcs;
  407. falcon_info.num_funcs = ARRAY_SIZE(falcon_funcs);
  408. ret = ltq_pinctrl_register(pdev, &falcon_info);
  409. if (!ret)
  410. dev_info(&pdev->dev, "Init done\n");
  411. return ret;
  412. }
  413. static const struct of_device_id falcon_match[] = {
  414. { .compatible = "lantiq,pinctrl-falcon" },
  415. {},
  416. };
  417. MODULE_DEVICE_TABLE(of, falcon_match);
  418. static struct platform_driver pinctrl_falcon_driver = {
  419. .probe = pinctrl_falcon_probe,
  420. .driver = {
  421. .name = "pinctrl-falcon",
  422. .owner = THIS_MODULE,
  423. .of_match_table = falcon_match,
  424. },
  425. };
  426. int __init pinctrl_falcon_init(void)
  427. {
  428. return platform_driver_register(&pinctrl_falcon_driver);
  429. }
  430. core_initcall_sync(pinctrl_falcon_init);