pinctrl-moore.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * MediaTek Pinctrl Moore Driver, which implement the generic dt-binding
  4. * pinctrl-bindings.txt for MediaTek SoC.
  5. *
  6. * Copyright (C) 2017-2018 MediaTek Inc.
  7. * Author: Sean Wang <[email protected]>
  8. *
  9. */
  10. #include <linux/gpio/driver.h>
  11. #include "pinctrl-moore.h"
  12. #define PINCTRL_PINCTRL_DEV KBUILD_MODNAME
  13. /* Custom pinconf parameters */
  14. #define MTK_PIN_CONFIG_TDSEL (PIN_CONFIG_END + 1)
  15. #define MTK_PIN_CONFIG_RDSEL (PIN_CONFIG_END + 2)
  16. #define MTK_PIN_CONFIG_PU_ADV (PIN_CONFIG_END + 3)
  17. #define MTK_PIN_CONFIG_PD_ADV (PIN_CONFIG_END + 4)
  18. static const struct pinconf_generic_params mtk_custom_bindings[] = {
  19. {"mediatek,tdsel", MTK_PIN_CONFIG_TDSEL, 0},
  20. {"mediatek,rdsel", MTK_PIN_CONFIG_RDSEL, 0},
  21. {"mediatek,pull-up-adv", MTK_PIN_CONFIG_PU_ADV, 1},
  22. {"mediatek,pull-down-adv", MTK_PIN_CONFIG_PD_ADV, 1},
  23. };
  24. #ifdef CONFIG_DEBUG_FS
  25. static const struct pin_config_item mtk_conf_items[] = {
  26. PCONFDUMP(MTK_PIN_CONFIG_TDSEL, "tdsel", NULL, true),
  27. PCONFDUMP(MTK_PIN_CONFIG_RDSEL, "rdsel", NULL, true),
  28. PCONFDUMP(MTK_PIN_CONFIG_PU_ADV, "pu-adv", NULL, true),
  29. PCONFDUMP(MTK_PIN_CONFIG_PD_ADV, "pd-adv", NULL, true),
  30. };
  31. #endif
  32. static int mtk_pinmux_set_mux(struct pinctrl_dev *pctldev,
  33. unsigned int selector, unsigned int group)
  34. {
  35. struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
  36. struct function_desc *func;
  37. struct group_desc *grp;
  38. int i;
  39. func = pinmux_generic_get_function(pctldev, selector);
  40. if (!func)
  41. return -EINVAL;
  42. grp = pinctrl_generic_get_group(pctldev, group);
  43. if (!grp)
  44. return -EINVAL;
  45. dev_dbg(pctldev->dev, "enable function %s group %s\n",
  46. func->name, grp->name);
  47. for (i = 0; i < grp->num_pins; i++) {
  48. const struct mtk_pin_desc *desc;
  49. int *pin_modes = grp->data;
  50. int pin = grp->pins[i];
  51. desc = (const struct mtk_pin_desc *)&hw->soc->pins[pin];
  52. if (!desc->name)
  53. return -ENOTSUPP;
  54. mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_MODE,
  55. pin_modes[i]);
  56. }
  57. return 0;
  58. }
  59. static int mtk_pinmux_gpio_request_enable(struct pinctrl_dev *pctldev,
  60. struct pinctrl_gpio_range *range,
  61. unsigned int pin)
  62. {
  63. struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
  64. const struct mtk_pin_desc *desc;
  65. desc = (const struct mtk_pin_desc *)&hw->soc->pins[pin];
  66. if (!desc->name)
  67. return -ENOTSUPP;
  68. return mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_MODE,
  69. hw->soc->gpio_m);
  70. }
  71. static int mtk_pinmux_gpio_set_direction(struct pinctrl_dev *pctldev,
  72. struct pinctrl_gpio_range *range,
  73. unsigned int pin, bool input)
  74. {
  75. struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
  76. const struct mtk_pin_desc *desc;
  77. desc = (const struct mtk_pin_desc *)&hw->soc->pins[pin];
  78. if (!desc->name)
  79. return -ENOTSUPP;
  80. /* hardware would take 0 as input direction */
  81. return mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DIR, !input);
  82. }
  83. static int mtk_pinconf_get(struct pinctrl_dev *pctldev,
  84. unsigned int pin, unsigned long *config)
  85. {
  86. struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
  87. u32 param = pinconf_to_config_param(*config);
  88. int val, val2, err, reg, ret = 1;
  89. const struct mtk_pin_desc *desc;
  90. desc = (const struct mtk_pin_desc *)&hw->soc->pins[pin];
  91. if (!desc->name)
  92. return -ENOTSUPP;
  93. switch (param) {
  94. case PIN_CONFIG_BIAS_DISABLE:
  95. if (hw->soc->bias_disable_get) {
  96. err = hw->soc->bias_disable_get(hw, desc, &ret);
  97. if (err)
  98. return err;
  99. } else {
  100. return -ENOTSUPP;
  101. }
  102. break;
  103. case PIN_CONFIG_BIAS_PULL_UP:
  104. if (hw->soc->bias_get) {
  105. err = hw->soc->bias_get(hw, desc, 1, &ret);
  106. if (err)
  107. return err;
  108. } else {
  109. return -ENOTSUPP;
  110. }
  111. break;
  112. case PIN_CONFIG_BIAS_PULL_DOWN:
  113. if (hw->soc->bias_get) {
  114. err = hw->soc->bias_get(hw, desc, 0, &ret);
  115. if (err)
  116. return err;
  117. } else {
  118. return -ENOTSUPP;
  119. }
  120. break;
  121. case PIN_CONFIG_SLEW_RATE:
  122. err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SR, &val);
  123. if (err)
  124. return err;
  125. if (!val)
  126. return -EINVAL;
  127. break;
  128. case PIN_CONFIG_INPUT_ENABLE:
  129. case PIN_CONFIG_OUTPUT_ENABLE:
  130. err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &val);
  131. if (err)
  132. return err;
  133. /* HW takes input mode as zero; output mode as non-zero */
  134. if ((val && param == PIN_CONFIG_INPUT_ENABLE) ||
  135. (!val && param == PIN_CONFIG_OUTPUT_ENABLE))
  136. return -EINVAL;
  137. break;
  138. case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
  139. err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &val);
  140. if (err)
  141. return err;
  142. err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SMT, &val2);
  143. if (err)
  144. return err;
  145. if (val || !val2)
  146. return -EINVAL;
  147. break;
  148. case PIN_CONFIG_DRIVE_STRENGTH:
  149. if (hw->soc->drive_get) {
  150. err = hw->soc->drive_get(hw, desc, &ret);
  151. if (err)
  152. return err;
  153. } else {
  154. err = -ENOTSUPP;
  155. }
  156. break;
  157. case MTK_PIN_CONFIG_TDSEL:
  158. case MTK_PIN_CONFIG_RDSEL:
  159. reg = (param == MTK_PIN_CONFIG_TDSEL) ?
  160. PINCTRL_PIN_REG_TDSEL : PINCTRL_PIN_REG_RDSEL;
  161. err = mtk_hw_get_value(hw, desc, reg, &val);
  162. if (err)
  163. return err;
  164. ret = val;
  165. break;
  166. case MTK_PIN_CONFIG_PU_ADV:
  167. case MTK_PIN_CONFIG_PD_ADV:
  168. if (hw->soc->adv_pull_get) {
  169. bool pullup;
  170. pullup = param == MTK_PIN_CONFIG_PU_ADV;
  171. err = hw->soc->adv_pull_get(hw, desc, pullup, &ret);
  172. if (err)
  173. return err;
  174. } else {
  175. return -ENOTSUPP;
  176. }
  177. break;
  178. default:
  179. return -ENOTSUPP;
  180. }
  181. *config = pinconf_to_config_packed(param, ret);
  182. return 0;
  183. }
  184. static int mtk_pinconf_set(struct pinctrl_dev *pctldev, unsigned int pin,
  185. unsigned long *configs, unsigned int num_configs)
  186. {
  187. struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
  188. const struct mtk_pin_desc *desc;
  189. u32 reg, param, arg;
  190. int cfg, err = 0;
  191. desc = (const struct mtk_pin_desc *)&hw->soc->pins[pin];
  192. if (!desc->name)
  193. return -ENOTSUPP;
  194. for (cfg = 0; cfg < num_configs; cfg++) {
  195. param = pinconf_to_config_param(configs[cfg]);
  196. arg = pinconf_to_config_argument(configs[cfg]);
  197. switch (param) {
  198. case PIN_CONFIG_BIAS_DISABLE:
  199. if (hw->soc->bias_disable_set) {
  200. err = hw->soc->bias_disable_set(hw, desc);
  201. if (err)
  202. return err;
  203. } else {
  204. return -ENOTSUPP;
  205. }
  206. break;
  207. case PIN_CONFIG_BIAS_PULL_UP:
  208. if (hw->soc->bias_set) {
  209. err = hw->soc->bias_set(hw, desc, 1);
  210. if (err)
  211. return err;
  212. } else {
  213. return -ENOTSUPP;
  214. }
  215. break;
  216. case PIN_CONFIG_BIAS_PULL_DOWN:
  217. if (hw->soc->bias_set) {
  218. err = hw->soc->bias_set(hw, desc, 0);
  219. if (err)
  220. return err;
  221. } else {
  222. return -ENOTSUPP;
  223. }
  224. break;
  225. case PIN_CONFIG_OUTPUT_ENABLE:
  226. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_SMT,
  227. MTK_DISABLE);
  228. if (err)
  229. goto err;
  230. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DIR,
  231. MTK_OUTPUT);
  232. if (err)
  233. goto err;
  234. break;
  235. case PIN_CONFIG_INPUT_ENABLE:
  236. if (hw->soc->ies_present) {
  237. mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_IES,
  238. MTK_ENABLE);
  239. }
  240. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DIR,
  241. MTK_INPUT);
  242. if (err)
  243. goto err;
  244. break;
  245. case PIN_CONFIG_SLEW_RATE:
  246. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_SR,
  247. arg);
  248. if (err)
  249. goto err;
  250. break;
  251. case PIN_CONFIG_OUTPUT:
  252. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DIR,
  253. MTK_OUTPUT);
  254. if (err)
  255. goto err;
  256. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DO,
  257. arg);
  258. if (err)
  259. goto err;
  260. break;
  261. case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
  262. /* arg = 1: Input mode & SMT enable ;
  263. * arg = 0: Output mode & SMT disable
  264. */
  265. arg = arg ? 2 : 1;
  266. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DIR,
  267. arg & 1);
  268. if (err)
  269. goto err;
  270. err = mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_SMT,
  271. !!(arg & 2));
  272. if (err)
  273. goto err;
  274. break;
  275. case PIN_CONFIG_DRIVE_STRENGTH:
  276. if (hw->soc->drive_set) {
  277. err = hw->soc->drive_set(hw, desc, arg);
  278. if (err)
  279. return err;
  280. } else {
  281. err = -ENOTSUPP;
  282. }
  283. break;
  284. case MTK_PIN_CONFIG_TDSEL:
  285. case MTK_PIN_CONFIG_RDSEL:
  286. reg = (param == MTK_PIN_CONFIG_TDSEL) ?
  287. PINCTRL_PIN_REG_TDSEL : PINCTRL_PIN_REG_RDSEL;
  288. err = mtk_hw_set_value(hw, desc, reg, arg);
  289. if (err)
  290. goto err;
  291. break;
  292. case MTK_PIN_CONFIG_PU_ADV:
  293. case MTK_PIN_CONFIG_PD_ADV:
  294. if (hw->soc->adv_pull_set) {
  295. bool pullup;
  296. pullup = param == MTK_PIN_CONFIG_PU_ADV;
  297. err = hw->soc->adv_pull_set(hw, desc, pullup,
  298. arg);
  299. if (err)
  300. return err;
  301. } else {
  302. return -ENOTSUPP;
  303. }
  304. break;
  305. default:
  306. err = -ENOTSUPP;
  307. }
  308. }
  309. err:
  310. return err;
  311. }
  312. static int mtk_pinconf_group_get(struct pinctrl_dev *pctldev,
  313. unsigned int group, unsigned long *config)
  314. {
  315. const unsigned int *pins;
  316. unsigned int i, npins, old = 0;
  317. int ret;
  318. ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
  319. if (ret)
  320. return ret;
  321. for (i = 0; i < npins; i++) {
  322. if (mtk_pinconf_get(pctldev, pins[i], config))
  323. return -ENOTSUPP;
  324. /* configs do not match between two pins */
  325. if (i && old != *config)
  326. return -ENOTSUPP;
  327. old = *config;
  328. }
  329. return 0;
  330. }
  331. static int mtk_pinconf_group_set(struct pinctrl_dev *pctldev,
  332. unsigned int group, unsigned long *configs,
  333. unsigned int num_configs)
  334. {
  335. const unsigned int *pins;
  336. unsigned int i, npins;
  337. int ret;
  338. ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
  339. if (ret)
  340. return ret;
  341. for (i = 0; i < npins; i++) {
  342. ret = mtk_pinconf_set(pctldev, pins[i], configs, num_configs);
  343. if (ret)
  344. return ret;
  345. }
  346. return 0;
  347. }
  348. static const struct pinctrl_ops mtk_pctlops = {
  349. .get_groups_count = pinctrl_generic_get_group_count,
  350. .get_group_name = pinctrl_generic_get_group_name,
  351. .get_group_pins = pinctrl_generic_get_group_pins,
  352. .dt_node_to_map = pinconf_generic_dt_node_to_map_all,
  353. .dt_free_map = pinconf_generic_dt_free_map,
  354. };
  355. static const struct pinmux_ops mtk_pmxops = {
  356. .get_functions_count = pinmux_generic_get_function_count,
  357. .get_function_name = pinmux_generic_get_function_name,
  358. .get_function_groups = pinmux_generic_get_function_groups,
  359. .set_mux = mtk_pinmux_set_mux,
  360. .gpio_request_enable = mtk_pinmux_gpio_request_enable,
  361. .gpio_set_direction = mtk_pinmux_gpio_set_direction,
  362. .strict = true,
  363. };
  364. static const struct pinconf_ops mtk_confops = {
  365. .is_generic = true,
  366. .pin_config_get = mtk_pinconf_get,
  367. .pin_config_set = mtk_pinconf_set,
  368. .pin_config_group_get = mtk_pinconf_group_get,
  369. .pin_config_group_set = mtk_pinconf_group_set,
  370. .pin_config_config_dbg_show = pinconf_generic_dump_config,
  371. };
  372. static struct pinctrl_desc mtk_desc = {
  373. .name = PINCTRL_PINCTRL_DEV,
  374. .pctlops = &mtk_pctlops,
  375. .pmxops = &mtk_pmxops,
  376. .confops = &mtk_confops,
  377. .owner = THIS_MODULE,
  378. };
  379. static int mtk_gpio_get(struct gpio_chip *chip, unsigned int gpio)
  380. {
  381. struct mtk_pinctrl *hw = gpiochip_get_data(chip);
  382. const struct mtk_pin_desc *desc;
  383. int value, err;
  384. desc = (const struct mtk_pin_desc *)&hw->soc->pins[gpio];
  385. if (!desc->name)
  386. return -ENOTSUPP;
  387. err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DI, &value);
  388. if (err)
  389. return err;
  390. return !!value;
  391. }
  392. static void mtk_gpio_set(struct gpio_chip *chip, unsigned int gpio, int value)
  393. {
  394. struct mtk_pinctrl *hw = gpiochip_get_data(chip);
  395. const struct mtk_pin_desc *desc;
  396. desc = (const struct mtk_pin_desc *)&hw->soc->pins[gpio];
  397. if (!desc->name) {
  398. dev_err(hw->dev, "Failed to set gpio %d\n", gpio);
  399. return;
  400. }
  401. mtk_hw_set_value(hw, desc, PINCTRL_PIN_REG_DO, !!value);
  402. }
  403. static int mtk_gpio_direction_input(struct gpio_chip *chip, unsigned int gpio)
  404. {
  405. return pinctrl_gpio_direction_input(chip->base + gpio);
  406. }
  407. static int mtk_gpio_direction_output(struct gpio_chip *chip, unsigned int gpio,
  408. int value)
  409. {
  410. mtk_gpio_set(chip, gpio, value);
  411. return pinctrl_gpio_direction_output(chip->base + gpio);
  412. }
  413. static int mtk_gpio_to_irq(struct gpio_chip *chip, unsigned int offset)
  414. {
  415. struct mtk_pinctrl *hw = gpiochip_get_data(chip);
  416. const struct mtk_pin_desc *desc;
  417. if (!hw->eint)
  418. return -ENOTSUPP;
  419. desc = (const struct mtk_pin_desc *)&hw->soc->pins[offset];
  420. if (desc->eint.eint_n == (u16)EINT_NA)
  421. return -ENOTSUPP;
  422. return mtk_eint_find_irq(hw->eint, desc->eint.eint_n);
  423. }
  424. static int mtk_gpio_set_config(struct gpio_chip *chip, unsigned int offset,
  425. unsigned long config)
  426. {
  427. struct mtk_pinctrl *hw = gpiochip_get_data(chip);
  428. const struct mtk_pin_desc *desc;
  429. u32 debounce;
  430. desc = (const struct mtk_pin_desc *)&hw->soc->pins[offset];
  431. if (!desc->name)
  432. return -ENOTSUPP;
  433. if (!hw->eint ||
  434. pinconf_to_config_param(config) != PIN_CONFIG_INPUT_DEBOUNCE ||
  435. desc->eint.eint_n == (u16)EINT_NA)
  436. return -ENOTSUPP;
  437. debounce = pinconf_to_config_argument(config);
  438. return mtk_eint_set_debounce(hw->eint, desc->eint.eint_n, debounce);
  439. }
  440. static int mtk_build_gpiochip(struct mtk_pinctrl *hw)
  441. {
  442. struct gpio_chip *chip = &hw->chip;
  443. int ret;
  444. chip->label = PINCTRL_PINCTRL_DEV;
  445. chip->parent = hw->dev;
  446. chip->request = gpiochip_generic_request;
  447. chip->free = gpiochip_generic_free;
  448. chip->direction_input = mtk_gpio_direction_input;
  449. chip->direction_output = mtk_gpio_direction_output;
  450. chip->get = mtk_gpio_get;
  451. chip->set = mtk_gpio_set;
  452. chip->to_irq = mtk_gpio_to_irq;
  453. chip->set_config = mtk_gpio_set_config;
  454. chip->base = -1;
  455. chip->ngpio = hw->soc->npins;
  456. chip->of_gpio_n_cells = 2;
  457. ret = gpiochip_add_data(chip, hw);
  458. if (ret < 0)
  459. return ret;
  460. /* Just for backward compatible for these old pinctrl nodes without
  461. * "gpio-ranges" property. Otherwise, called directly from a
  462. * DeviceTree-supported pinctrl driver is DEPRECATED.
  463. * Please see Section 2.1 of
  464. * Documentation/devicetree/bindings/gpio/gpio.txt on how to
  465. * bind pinctrl and gpio drivers via the "gpio-ranges" property.
  466. */
  467. if (!of_find_property(hw->dev->of_node, "gpio-ranges", NULL)) {
  468. ret = gpiochip_add_pin_range(chip, dev_name(hw->dev), 0, 0,
  469. chip->ngpio);
  470. if (ret < 0) {
  471. gpiochip_remove(chip);
  472. return ret;
  473. }
  474. }
  475. return 0;
  476. }
  477. static int mtk_build_groups(struct mtk_pinctrl *hw)
  478. {
  479. int err, i;
  480. for (i = 0; i < hw->soc->ngrps; i++) {
  481. const struct group_desc *group = hw->soc->grps + i;
  482. err = pinctrl_generic_add_group(hw->pctrl, group->name,
  483. group->pins, group->num_pins,
  484. group->data);
  485. if (err < 0) {
  486. dev_err(hw->dev, "Failed to register group %s\n",
  487. group->name);
  488. return err;
  489. }
  490. }
  491. return 0;
  492. }
  493. static int mtk_build_functions(struct mtk_pinctrl *hw)
  494. {
  495. int i, err;
  496. for (i = 0; i < hw->soc->nfuncs ; i++) {
  497. const struct function_desc *func = hw->soc->funcs + i;
  498. err = pinmux_generic_add_function(hw->pctrl, func->name,
  499. func->group_names,
  500. func->num_group_names,
  501. func->data);
  502. if (err < 0) {
  503. dev_err(hw->dev, "Failed to register function %s\n",
  504. func->name);
  505. return err;
  506. }
  507. }
  508. return 0;
  509. }
  510. int mtk_moore_pinctrl_probe(struct platform_device *pdev,
  511. const struct mtk_pin_soc *soc)
  512. {
  513. struct device *dev = &pdev->dev;
  514. struct pinctrl_pin_desc *pins;
  515. struct mtk_pinctrl *hw;
  516. int err, i;
  517. hw = devm_kzalloc(&pdev->dev, sizeof(*hw), GFP_KERNEL);
  518. if (!hw)
  519. return -ENOMEM;
  520. hw->soc = soc;
  521. hw->dev = &pdev->dev;
  522. if (!hw->soc->nbase_names)
  523. return dev_err_probe(dev, -EINVAL,
  524. "SoC should be assigned at least one register base\n");
  525. hw->base = devm_kmalloc_array(&pdev->dev, hw->soc->nbase_names,
  526. sizeof(*hw->base), GFP_KERNEL);
  527. if (!hw->base)
  528. return -ENOMEM;
  529. for (i = 0; i < hw->soc->nbase_names; i++) {
  530. hw->base[i] = devm_platform_ioremap_resource_byname(pdev,
  531. hw->soc->base_names[i]);
  532. if (IS_ERR(hw->base[i]))
  533. return PTR_ERR(hw->base[i]);
  534. }
  535. hw->nbase = hw->soc->nbase_names;
  536. spin_lock_init(&hw->lock);
  537. /* Copy from internal struct mtk_pin_desc to register to the core */
  538. pins = devm_kmalloc_array(&pdev->dev, hw->soc->npins, sizeof(*pins),
  539. GFP_KERNEL);
  540. if (!pins)
  541. return -ENOMEM;
  542. for (i = 0; i < hw->soc->npins; i++) {
  543. pins[i].number = hw->soc->pins[i].number;
  544. pins[i].name = hw->soc->pins[i].name;
  545. }
  546. /* Setup pins descriptions per SoC types */
  547. mtk_desc.pins = (const struct pinctrl_pin_desc *)pins;
  548. mtk_desc.npins = hw->soc->npins;
  549. mtk_desc.num_custom_params = ARRAY_SIZE(mtk_custom_bindings);
  550. mtk_desc.custom_params = mtk_custom_bindings;
  551. #ifdef CONFIG_DEBUG_FS
  552. mtk_desc.custom_conf_items = mtk_conf_items;
  553. #endif
  554. err = devm_pinctrl_register_and_init(&pdev->dev, &mtk_desc, hw,
  555. &hw->pctrl);
  556. if (err)
  557. return err;
  558. /* Setup groups descriptions per SoC types */
  559. err = mtk_build_groups(hw);
  560. if (err)
  561. return dev_err_probe(dev, err, "Failed to build groups\n");
  562. /* Setup functions descriptions per SoC types */
  563. err = mtk_build_functions(hw);
  564. if (err)
  565. return dev_err_probe(dev, err, "Failed to build functions\n");
  566. /* For able to make pinctrl_claim_hogs, we must not enable pinctrl
  567. * until all groups and functions are being added one.
  568. */
  569. err = pinctrl_enable(hw->pctrl);
  570. if (err)
  571. return err;
  572. err = mtk_build_eint(hw, pdev);
  573. if (err)
  574. dev_warn(&pdev->dev,
  575. "Failed to add EINT, but pinctrl still can work\n");
  576. /* Build gpiochip should be after pinctrl_enable is done */
  577. err = mtk_build_gpiochip(hw);
  578. if (err)
  579. return dev_err_probe(dev, err, "Failed to add gpio_chip\n");
  580. platform_set_drvdata(pdev, hw);
  581. return 0;
  582. }