pinctrl-owl.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * OWL SoC's Pinctrl driver
  4. *
  5. * Copyright (c) 2014 Actions Semi Inc.
  6. * Author: David Liu <[email protected]>
  7. *
  8. * Copyright (c) 2018 Linaro Ltd.
  9. * Author: Manivannan Sadhasivam <[email protected]>
  10. */
  11. #include <linux/clk.h>
  12. #include <linux/err.h>
  13. #include <linux/gpio/driver.h>
  14. #include <linux/io.h>
  15. #include <linux/irq.h>
  16. #include <linux/module.h>
  17. #include <linux/of.h>
  18. #include <linux/platform_device.h>
  19. #include <linux/pinctrl/machine.h>
  20. #include <linux/pinctrl/pinctrl.h>
  21. #include <linux/pinctrl/pinmux.h>
  22. #include <linux/pinctrl/pinconf.h>
  23. #include <linux/pinctrl/pinconf-generic.h>
  24. #include <linux/slab.h>
  25. #include <linux/spinlock.h>
  26. #include "../core.h"
  27. #include "../pinctrl-utils.h"
  28. #include "pinctrl-owl.h"
  29. /**
  30. * struct owl_pinctrl - pinctrl state of the device
  31. * @dev: device handle
  32. * @pctrldev: pinctrl handle
  33. * @chip: gpio chip
  34. * @lock: spinlock to protect registers
  35. * @clk: clock control
  36. * @soc: reference to soc_data
  37. * @base: pinctrl register base address
  38. * @irq_chip: IRQ chip information
  39. * @num_irq: number of possible interrupts
  40. * @irq: interrupt numbers
  41. */
  42. struct owl_pinctrl {
  43. struct device *dev;
  44. struct pinctrl_dev *pctrldev;
  45. struct gpio_chip chip;
  46. raw_spinlock_t lock;
  47. struct clk *clk;
  48. const struct owl_pinctrl_soc_data *soc;
  49. void __iomem *base;
  50. struct irq_chip irq_chip;
  51. unsigned int num_irq;
  52. unsigned int *irq;
  53. };
  54. static void owl_update_bits(void __iomem *base, u32 mask, u32 val)
  55. {
  56. u32 reg_val;
  57. reg_val = readl_relaxed(base);
  58. reg_val = (reg_val & ~mask) | (val & mask);
  59. writel_relaxed(reg_val, base);
  60. }
  61. static u32 owl_read_field(struct owl_pinctrl *pctrl, u32 reg,
  62. u32 bit, u32 width)
  63. {
  64. u32 tmp, mask;
  65. tmp = readl_relaxed(pctrl->base + reg);
  66. mask = (1 << width) - 1;
  67. return (tmp >> bit) & mask;
  68. }
  69. static void owl_write_field(struct owl_pinctrl *pctrl, u32 reg, u32 arg,
  70. u32 bit, u32 width)
  71. {
  72. u32 mask;
  73. mask = (1 << width) - 1;
  74. mask = mask << bit;
  75. owl_update_bits(pctrl->base + reg, mask, (arg << bit));
  76. }
  77. static int owl_get_groups_count(struct pinctrl_dev *pctrldev)
  78. {
  79. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  80. return pctrl->soc->ngroups;
  81. }
  82. static const char *owl_get_group_name(struct pinctrl_dev *pctrldev,
  83. unsigned int group)
  84. {
  85. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  86. return pctrl->soc->groups[group].name;
  87. }
  88. static int owl_get_group_pins(struct pinctrl_dev *pctrldev,
  89. unsigned int group,
  90. const unsigned int **pins,
  91. unsigned int *num_pins)
  92. {
  93. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  94. *pins = pctrl->soc->groups[group].pads;
  95. *num_pins = pctrl->soc->groups[group].npads;
  96. return 0;
  97. }
  98. static void owl_pin_dbg_show(struct pinctrl_dev *pctrldev,
  99. struct seq_file *s,
  100. unsigned int offset)
  101. {
  102. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  103. seq_printf(s, "%s", dev_name(pctrl->dev));
  104. }
  105. static const struct pinctrl_ops owl_pinctrl_ops = {
  106. .get_groups_count = owl_get_groups_count,
  107. .get_group_name = owl_get_group_name,
  108. .get_group_pins = owl_get_group_pins,
  109. .pin_dbg_show = owl_pin_dbg_show,
  110. .dt_node_to_map = pinconf_generic_dt_node_to_map_all,
  111. .dt_free_map = pinctrl_utils_free_map,
  112. };
  113. static int owl_get_funcs_count(struct pinctrl_dev *pctrldev)
  114. {
  115. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  116. return pctrl->soc->nfunctions;
  117. }
  118. static const char *owl_get_func_name(struct pinctrl_dev *pctrldev,
  119. unsigned int function)
  120. {
  121. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  122. return pctrl->soc->functions[function].name;
  123. }
  124. static int owl_get_func_groups(struct pinctrl_dev *pctrldev,
  125. unsigned int function,
  126. const char * const **groups,
  127. unsigned int * const num_groups)
  128. {
  129. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  130. *groups = pctrl->soc->functions[function].groups;
  131. *num_groups = pctrl->soc->functions[function].ngroups;
  132. return 0;
  133. }
  134. static inline int get_group_mfp_mask_val(const struct owl_pingroup *g,
  135. int function,
  136. u32 *mask,
  137. u32 *val)
  138. {
  139. int id;
  140. u32 option_num;
  141. u32 option_mask;
  142. for (id = 0; id < g->nfuncs; id++) {
  143. if (g->funcs[id] == function)
  144. break;
  145. }
  146. if (WARN_ON(id == g->nfuncs))
  147. return -EINVAL;
  148. option_num = (1 << g->mfpctl_width);
  149. if (id > option_num)
  150. id -= option_num;
  151. option_mask = option_num - 1;
  152. *mask = (option_mask << g->mfpctl_shift);
  153. *val = (id << g->mfpctl_shift);
  154. return 0;
  155. }
  156. static int owl_set_mux(struct pinctrl_dev *pctrldev,
  157. unsigned int function,
  158. unsigned int group)
  159. {
  160. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  161. const struct owl_pingroup *g;
  162. unsigned long flags;
  163. u32 val, mask;
  164. g = &pctrl->soc->groups[group];
  165. if (get_group_mfp_mask_val(g, function, &mask, &val))
  166. return -EINVAL;
  167. raw_spin_lock_irqsave(&pctrl->lock, flags);
  168. owl_update_bits(pctrl->base + g->mfpctl_reg, mask, val);
  169. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  170. return 0;
  171. }
  172. static const struct pinmux_ops owl_pinmux_ops = {
  173. .get_functions_count = owl_get_funcs_count,
  174. .get_function_name = owl_get_func_name,
  175. .get_function_groups = owl_get_func_groups,
  176. .set_mux = owl_set_mux,
  177. };
  178. static int owl_pad_pinconf_reg(const struct owl_padinfo *info,
  179. unsigned int param,
  180. u32 *reg,
  181. u32 *bit,
  182. u32 *width)
  183. {
  184. switch (param) {
  185. case PIN_CONFIG_BIAS_BUS_HOLD:
  186. case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
  187. case PIN_CONFIG_BIAS_PULL_DOWN:
  188. case PIN_CONFIG_BIAS_PULL_UP:
  189. if (!info->pullctl)
  190. return -EINVAL;
  191. *reg = info->pullctl->reg;
  192. *bit = info->pullctl->shift;
  193. *width = info->pullctl->width;
  194. break;
  195. case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
  196. if (!info->st)
  197. return -EINVAL;
  198. *reg = info->st->reg;
  199. *bit = info->st->shift;
  200. *width = info->st->width;
  201. break;
  202. default:
  203. return -ENOTSUPP;
  204. }
  205. return 0;
  206. }
  207. static int owl_pin_config_get(struct pinctrl_dev *pctrldev,
  208. unsigned int pin,
  209. unsigned long *config)
  210. {
  211. int ret = 0;
  212. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  213. const struct owl_padinfo *info;
  214. unsigned int param = pinconf_to_config_param(*config);
  215. u32 reg, bit, width, arg;
  216. info = &pctrl->soc->padinfo[pin];
  217. ret = owl_pad_pinconf_reg(info, param, &reg, &bit, &width);
  218. if (ret)
  219. return ret;
  220. arg = owl_read_field(pctrl, reg, bit, width);
  221. if (!pctrl->soc->padctl_val2arg)
  222. return -ENOTSUPP;
  223. ret = pctrl->soc->padctl_val2arg(info, param, &arg);
  224. if (ret)
  225. return ret;
  226. *config = pinconf_to_config_packed(param, arg);
  227. return ret;
  228. }
  229. static int owl_pin_config_set(struct pinctrl_dev *pctrldev,
  230. unsigned int pin,
  231. unsigned long *configs,
  232. unsigned int num_configs)
  233. {
  234. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  235. const struct owl_padinfo *info;
  236. unsigned long flags;
  237. unsigned int param;
  238. u32 reg, bit, width, arg;
  239. int ret = 0, i;
  240. info = &pctrl->soc->padinfo[pin];
  241. for (i = 0; i < num_configs; i++) {
  242. param = pinconf_to_config_param(configs[i]);
  243. arg = pinconf_to_config_argument(configs[i]);
  244. ret = owl_pad_pinconf_reg(info, param, &reg, &bit, &width);
  245. if (ret)
  246. return ret;
  247. if (!pctrl->soc->padctl_arg2val)
  248. return -ENOTSUPP;
  249. ret = pctrl->soc->padctl_arg2val(info, param, &arg);
  250. if (ret)
  251. return ret;
  252. raw_spin_lock_irqsave(&pctrl->lock, flags);
  253. owl_write_field(pctrl, reg, arg, bit, width);
  254. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  255. }
  256. return ret;
  257. }
  258. static int owl_group_pinconf_reg(const struct owl_pingroup *g,
  259. unsigned int param,
  260. u32 *reg,
  261. u32 *bit,
  262. u32 *width)
  263. {
  264. switch (param) {
  265. case PIN_CONFIG_DRIVE_STRENGTH:
  266. if (g->drv_reg < 0)
  267. return -EINVAL;
  268. *reg = g->drv_reg;
  269. *bit = g->drv_shift;
  270. *width = g->drv_width;
  271. break;
  272. case PIN_CONFIG_SLEW_RATE:
  273. if (g->sr_reg < 0)
  274. return -EINVAL;
  275. *reg = g->sr_reg;
  276. *bit = g->sr_shift;
  277. *width = g->sr_width;
  278. break;
  279. default:
  280. return -ENOTSUPP;
  281. }
  282. return 0;
  283. }
  284. static int owl_group_pinconf_arg2val(const struct owl_pingroup *g,
  285. unsigned int param,
  286. u32 *arg)
  287. {
  288. switch (param) {
  289. case PIN_CONFIG_DRIVE_STRENGTH:
  290. switch (*arg) {
  291. case 2:
  292. *arg = OWL_PINCONF_DRV_2MA;
  293. break;
  294. case 4:
  295. *arg = OWL_PINCONF_DRV_4MA;
  296. break;
  297. case 8:
  298. *arg = OWL_PINCONF_DRV_8MA;
  299. break;
  300. case 12:
  301. *arg = OWL_PINCONF_DRV_12MA;
  302. break;
  303. default:
  304. return -EINVAL;
  305. }
  306. break;
  307. case PIN_CONFIG_SLEW_RATE:
  308. if (*arg)
  309. *arg = OWL_PINCONF_SLEW_FAST;
  310. else
  311. *arg = OWL_PINCONF_SLEW_SLOW;
  312. break;
  313. default:
  314. return -ENOTSUPP;
  315. }
  316. return 0;
  317. }
  318. static int owl_group_pinconf_val2arg(const struct owl_pingroup *g,
  319. unsigned int param,
  320. u32 *arg)
  321. {
  322. switch (param) {
  323. case PIN_CONFIG_DRIVE_STRENGTH:
  324. switch (*arg) {
  325. case OWL_PINCONF_DRV_2MA:
  326. *arg = 2;
  327. break;
  328. case OWL_PINCONF_DRV_4MA:
  329. *arg = 4;
  330. break;
  331. case OWL_PINCONF_DRV_8MA:
  332. *arg = 8;
  333. break;
  334. case OWL_PINCONF_DRV_12MA:
  335. *arg = 12;
  336. break;
  337. default:
  338. return -EINVAL;
  339. }
  340. break;
  341. case PIN_CONFIG_SLEW_RATE:
  342. if (*arg)
  343. *arg = 1;
  344. else
  345. *arg = 0;
  346. break;
  347. default:
  348. return -ENOTSUPP;
  349. }
  350. return 0;
  351. }
  352. static int owl_group_config_get(struct pinctrl_dev *pctrldev,
  353. unsigned int group,
  354. unsigned long *config)
  355. {
  356. const struct owl_pingroup *g;
  357. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  358. unsigned int param = pinconf_to_config_param(*config);
  359. u32 reg, bit, width, arg;
  360. int ret;
  361. g = &pctrl->soc->groups[group];
  362. ret = owl_group_pinconf_reg(g, param, &reg, &bit, &width);
  363. if (ret)
  364. return ret;
  365. arg = owl_read_field(pctrl, reg, bit, width);
  366. ret = owl_group_pinconf_val2arg(g, param, &arg);
  367. if (ret)
  368. return ret;
  369. *config = pinconf_to_config_packed(param, arg);
  370. return ret;
  371. }
  372. static int owl_group_config_set(struct pinctrl_dev *pctrldev,
  373. unsigned int group,
  374. unsigned long *configs,
  375. unsigned int num_configs)
  376. {
  377. const struct owl_pingroup *g;
  378. struct owl_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctrldev);
  379. unsigned long flags;
  380. unsigned int param;
  381. u32 reg, bit, width, arg;
  382. int ret, i;
  383. g = &pctrl->soc->groups[group];
  384. for (i = 0; i < num_configs; i++) {
  385. param = pinconf_to_config_param(configs[i]);
  386. arg = pinconf_to_config_argument(configs[i]);
  387. ret = owl_group_pinconf_reg(g, param, &reg, &bit, &width);
  388. if (ret)
  389. return ret;
  390. ret = owl_group_pinconf_arg2val(g, param, &arg);
  391. if (ret)
  392. return ret;
  393. /* Update register */
  394. raw_spin_lock_irqsave(&pctrl->lock, flags);
  395. owl_write_field(pctrl, reg, arg, bit, width);
  396. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  397. }
  398. return 0;
  399. }
  400. static const struct pinconf_ops owl_pinconf_ops = {
  401. .is_generic = true,
  402. .pin_config_get = owl_pin_config_get,
  403. .pin_config_set = owl_pin_config_set,
  404. .pin_config_group_get = owl_group_config_get,
  405. .pin_config_group_set = owl_group_config_set,
  406. };
  407. static struct pinctrl_desc owl_pinctrl_desc = {
  408. .pctlops = &owl_pinctrl_ops,
  409. .pmxops = &owl_pinmux_ops,
  410. .confops = &owl_pinconf_ops,
  411. .owner = THIS_MODULE,
  412. };
  413. static const struct owl_gpio_port *
  414. owl_gpio_get_port(struct owl_pinctrl *pctrl, unsigned int *pin)
  415. {
  416. unsigned int start = 0, i;
  417. for (i = 0; i < pctrl->soc->nports; i++) {
  418. const struct owl_gpio_port *port = &pctrl->soc->ports[i];
  419. if (*pin >= start && *pin < start + port->pins) {
  420. *pin -= start;
  421. return port;
  422. }
  423. start += port->pins;
  424. }
  425. return NULL;
  426. }
  427. static void owl_gpio_update_reg(void __iomem *base, unsigned int pin, int flag)
  428. {
  429. u32 val;
  430. val = readl_relaxed(base);
  431. if (flag)
  432. val |= BIT(pin);
  433. else
  434. val &= ~BIT(pin);
  435. writel_relaxed(val, base);
  436. }
  437. static int owl_gpio_request(struct gpio_chip *chip, unsigned int offset)
  438. {
  439. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  440. const struct owl_gpio_port *port;
  441. void __iomem *gpio_base;
  442. unsigned long flags;
  443. port = owl_gpio_get_port(pctrl, &offset);
  444. if (WARN_ON(port == NULL))
  445. return -ENODEV;
  446. gpio_base = pctrl->base + port->offset;
  447. /*
  448. * GPIOs have higher priority over other modules, so either setting
  449. * them as OUT or IN is sufficient
  450. */
  451. raw_spin_lock_irqsave(&pctrl->lock, flags);
  452. owl_gpio_update_reg(gpio_base + port->outen, offset, true);
  453. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  454. return 0;
  455. }
  456. static void owl_gpio_free(struct gpio_chip *chip, unsigned int offset)
  457. {
  458. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  459. const struct owl_gpio_port *port;
  460. void __iomem *gpio_base;
  461. unsigned long flags;
  462. port = owl_gpio_get_port(pctrl, &offset);
  463. if (WARN_ON(port == NULL))
  464. return;
  465. gpio_base = pctrl->base + port->offset;
  466. raw_spin_lock_irqsave(&pctrl->lock, flags);
  467. /* disable gpio output */
  468. owl_gpio_update_reg(gpio_base + port->outen, offset, false);
  469. /* disable gpio input */
  470. owl_gpio_update_reg(gpio_base + port->inen, offset, false);
  471. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  472. }
  473. static int owl_gpio_get(struct gpio_chip *chip, unsigned int offset)
  474. {
  475. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  476. const struct owl_gpio_port *port;
  477. void __iomem *gpio_base;
  478. unsigned long flags;
  479. u32 val;
  480. port = owl_gpio_get_port(pctrl, &offset);
  481. if (WARN_ON(port == NULL))
  482. return -ENODEV;
  483. gpio_base = pctrl->base + port->offset;
  484. raw_spin_lock_irqsave(&pctrl->lock, flags);
  485. val = readl_relaxed(gpio_base + port->dat);
  486. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  487. return !!(val & BIT(offset));
  488. }
  489. static void owl_gpio_set(struct gpio_chip *chip, unsigned int offset, int value)
  490. {
  491. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  492. const struct owl_gpio_port *port;
  493. void __iomem *gpio_base;
  494. unsigned long flags;
  495. port = owl_gpio_get_port(pctrl, &offset);
  496. if (WARN_ON(port == NULL))
  497. return;
  498. gpio_base = pctrl->base + port->offset;
  499. raw_spin_lock_irqsave(&pctrl->lock, flags);
  500. owl_gpio_update_reg(gpio_base + port->dat, offset, value);
  501. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  502. }
  503. static int owl_gpio_direction_input(struct gpio_chip *chip, unsigned int offset)
  504. {
  505. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  506. const struct owl_gpio_port *port;
  507. void __iomem *gpio_base;
  508. unsigned long flags;
  509. port = owl_gpio_get_port(pctrl, &offset);
  510. if (WARN_ON(port == NULL))
  511. return -ENODEV;
  512. gpio_base = pctrl->base + port->offset;
  513. raw_spin_lock_irqsave(&pctrl->lock, flags);
  514. owl_gpio_update_reg(gpio_base + port->outen, offset, false);
  515. owl_gpio_update_reg(gpio_base + port->inen, offset, true);
  516. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  517. return 0;
  518. }
  519. static int owl_gpio_direction_output(struct gpio_chip *chip,
  520. unsigned int offset, int value)
  521. {
  522. struct owl_pinctrl *pctrl = gpiochip_get_data(chip);
  523. const struct owl_gpio_port *port;
  524. void __iomem *gpio_base;
  525. unsigned long flags;
  526. port = owl_gpio_get_port(pctrl, &offset);
  527. if (WARN_ON(port == NULL))
  528. return -ENODEV;
  529. gpio_base = pctrl->base + port->offset;
  530. raw_spin_lock_irqsave(&pctrl->lock, flags);
  531. owl_gpio_update_reg(gpio_base + port->inen, offset, false);
  532. owl_gpio_update_reg(gpio_base + port->outen, offset, true);
  533. owl_gpio_update_reg(gpio_base + port->dat, offset, value);
  534. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  535. return 0;
  536. }
  537. static void irq_set_type(struct owl_pinctrl *pctrl, int gpio, unsigned int type)
  538. {
  539. const struct owl_gpio_port *port;
  540. void __iomem *gpio_base;
  541. unsigned long flags;
  542. unsigned int offset, value, irq_type = 0;
  543. switch (type) {
  544. case IRQ_TYPE_EDGE_BOTH:
  545. /*
  546. * Since the hardware doesn't support interrupts on both edges,
  547. * emulate it in the software by setting the single edge
  548. * interrupt and switching to the opposite edge while ACKing
  549. * the interrupt
  550. */
  551. if (owl_gpio_get(&pctrl->chip, gpio))
  552. irq_type = OWL_GPIO_INT_EDGE_FALLING;
  553. else
  554. irq_type = OWL_GPIO_INT_EDGE_RISING;
  555. break;
  556. case IRQ_TYPE_EDGE_RISING:
  557. irq_type = OWL_GPIO_INT_EDGE_RISING;
  558. break;
  559. case IRQ_TYPE_EDGE_FALLING:
  560. irq_type = OWL_GPIO_INT_EDGE_FALLING;
  561. break;
  562. case IRQ_TYPE_LEVEL_HIGH:
  563. irq_type = OWL_GPIO_INT_LEVEL_HIGH;
  564. break;
  565. case IRQ_TYPE_LEVEL_LOW:
  566. irq_type = OWL_GPIO_INT_LEVEL_LOW;
  567. break;
  568. default:
  569. break;
  570. }
  571. port = owl_gpio_get_port(pctrl, &gpio);
  572. if (WARN_ON(port == NULL))
  573. return;
  574. gpio_base = pctrl->base + port->offset;
  575. raw_spin_lock_irqsave(&pctrl->lock, flags);
  576. offset = (gpio < 16) ? 4 : 0;
  577. value = readl_relaxed(gpio_base + port->intc_type + offset);
  578. value &= ~(OWL_GPIO_INT_MASK << ((gpio % 16) * 2));
  579. value |= irq_type << ((gpio % 16) * 2);
  580. writel_relaxed(value, gpio_base + port->intc_type + offset);
  581. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  582. }
  583. static void owl_gpio_irq_mask(struct irq_data *data)
  584. {
  585. struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
  586. struct owl_pinctrl *pctrl = gpiochip_get_data(gc);
  587. const struct owl_gpio_port *port;
  588. void __iomem *gpio_base;
  589. unsigned long flags;
  590. unsigned int gpio = data->hwirq;
  591. u32 val;
  592. port = owl_gpio_get_port(pctrl, &gpio);
  593. if (WARN_ON(port == NULL))
  594. return;
  595. gpio_base = pctrl->base + port->offset;
  596. raw_spin_lock_irqsave(&pctrl->lock, flags);
  597. owl_gpio_update_reg(gpio_base + port->intc_msk, gpio, false);
  598. /* disable port interrupt if no interrupt pending bit is active */
  599. val = readl_relaxed(gpio_base + port->intc_msk);
  600. if (val == 0)
  601. owl_gpio_update_reg(gpio_base + port->intc_ctl,
  602. OWL_GPIO_CTLR_ENABLE + port->shared_ctl_offset * 5, false);
  603. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  604. }
  605. static void owl_gpio_irq_unmask(struct irq_data *data)
  606. {
  607. struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
  608. struct owl_pinctrl *pctrl = gpiochip_get_data(gc);
  609. const struct owl_gpio_port *port;
  610. void __iomem *gpio_base;
  611. unsigned long flags;
  612. unsigned int gpio = data->hwirq;
  613. u32 value;
  614. port = owl_gpio_get_port(pctrl, &gpio);
  615. if (WARN_ON(port == NULL))
  616. return;
  617. gpio_base = pctrl->base + port->offset;
  618. raw_spin_lock_irqsave(&pctrl->lock, flags);
  619. /* enable port interrupt */
  620. value = readl_relaxed(gpio_base + port->intc_ctl);
  621. value |= ((BIT(OWL_GPIO_CTLR_ENABLE) | BIT(OWL_GPIO_CTLR_SAMPLE_CLK_24M))
  622. << port->shared_ctl_offset * 5);
  623. writel_relaxed(value, gpio_base + port->intc_ctl);
  624. /* enable GPIO interrupt */
  625. owl_gpio_update_reg(gpio_base + port->intc_msk, gpio, true);
  626. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  627. }
  628. static void owl_gpio_irq_ack(struct irq_data *data)
  629. {
  630. struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
  631. struct owl_pinctrl *pctrl = gpiochip_get_data(gc);
  632. const struct owl_gpio_port *port;
  633. void __iomem *gpio_base;
  634. unsigned long flags;
  635. unsigned int gpio = data->hwirq;
  636. /*
  637. * Switch the interrupt edge to the opposite edge of the interrupt
  638. * which got triggered for the case of emulating both edges
  639. */
  640. if (irqd_get_trigger_type(data) == IRQ_TYPE_EDGE_BOTH) {
  641. if (owl_gpio_get(gc, gpio))
  642. irq_set_type(pctrl, gpio, IRQ_TYPE_EDGE_FALLING);
  643. else
  644. irq_set_type(pctrl, gpio, IRQ_TYPE_EDGE_RISING);
  645. }
  646. port = owl_gpio_get_port(pctrl, &gpio);
  647. if (WARN_ON(port == NULL))
  648. return;
  649. gpio_base = pctrl->base + port->offset;
  650. raw_spin_lock_irqsave(&pctrl->lock, flags);
  651. owl_gpio_update_reg(gpio_base + port->intc_ctl,
  652. OWL_GPIO_CTLR_PENDING + port->shared_ctl_offset * 5, true);
  653. raw_spin_unlock_irqrestore(&pctrl->lock, flags);
  654. }
  655. static int owl_gpio_irq_set_type(struct irq_data *data, unsigned int type)
  656. {
  657. struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
  658. struct owl_pinctrl *pctrl = gpiochip_get_data(gc);
  659. if (type & (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH))
  660. irq_set_handler_locked(data, handle_level_irq);
  661. else
  662. irq_set_handler_locked(data, handle_edge_irq);
  663. irq_set_type(pctrl, data->hwirq, type);
  664. return 0;
  665. }
  666. static void owl_gpio_irq_handler(struct irq_desc *desc)
  667. {
  668. struct owl_pinctrl *pctrl = irq_desc_get_handler_data(desc);
  669. struct irq_chip *chip = irq_desc_get_chip(desc);
  670. struct irq_domain *domain = pctrl->chip.irq.domain;
  671. unsigned int parent = irq_desc_get_irq(desc);
  672. const struct owl_gpio_port *port;
  673. void __iomem *base;
  674. unsigned int pin, offset = 0, i;
  675. unsigned long pending_irq;
  676. chained_irq_enter(chip, desc);
  677. for (i = 0; i < pctrl->soc->nports; i++) {
  678. port = &pctrl->soc->ports[i];
  679. base = pctrl->base + port->offset;
  680. /* skip ports that are not associated with this irq */
  681. if (parent != pctrl->irq[i])
  682. goto skip;
  683. pending_irq = readl_relaxed(base + port->intc_pd);
  684. for_each_set_bit(pin, &pending_irq, port->pins) {
  685. generic_handle_domain_irq(domain, offset + pin);
  686. /* clear pending interrupt */
  687. owl_gpio_update_reg(base + port->intc_pd, pin, true);
  688. }
  689. skip:
  690. offset += port->pins;
  691. }
  692. chained_irq_exit(chip, desc);
  693. }
  694. static int owl_gpio_init(struct owl_pinctrl *pctrl)
  695. {
  696. struct gpio_chip *chip;
  697. struct gpio_irq_chip *gpio_irq;
  698. int ret, i, j, offset;
  699. chip = &pctrl->chip;
  700. chip->base = -1;
  701. chip->ngpio = pctrl->soc->ngpios;
  702. chip->label = dev_name(pctrl->dev);
  703. chip->parent = pctrl->dev;
  704. chip->owner = THIS_MODULE;
  705. pctrl->irq_chip.name = chip->of_node->name;
  706. pctrl->irq_chip.irq_ack = owl_gpio_irq_ack;
  707. pctrl->irq_chip.irq_mask = owl_gpio_irq_mask;
  708. pctrl->irq_chip.irq_unmask = owl_gpio_irq_unmask;
  709. pctrl->irq_chip.irq_set_type = owl_gpio_irq_set_type;
  710. gpio_irq = &chip->irq;
  711. gpio_irq->chip = &pctrl->irq_chip;
  712. gpio_irq->handler = handle_simple_irq;
  713. gpio_irq->default_type = IRQ_TYPE_NONE;
  714. gpio_irq->parent_handler = owl_gpio_irq_handler;
  715. gpio_irq->parent_handler_data = pctrl;
  716. gpio_irq->num_parents = pctrl->num_irq;
  717. gpio_irq->parents = pctrl->irq;
  718. gpio_irq->map = devm_kcalloc(pctrl->dev, chip->ngpio,
  719. sizeof(*gpio_irq->map), GFP_KERNEL);
  720. if (!gpio_irq->map)
  721. return -ENOMEM;
  722. for (i = 0, offset = 0; i < pctrl->soc->nports; i++) {
  723. const struct owl_gpio_port *port = &pctrl->soc->ports[i];
  724. for (j = 0; j < port->pins; j++)
  725. gpio_irq->map[offset + j] = gpio_irq->parents[i];
  726. offset += port->pins;
  727. }
  728. ret = gpiochip_add_data(&pctrl->chip, pctrl);
  729. if (ret) {
  730. dev_err(pctrl->dev, "failed to register gpiochip\n");
  731. return ret;
  732. }
  733. return 0;
  734. }
  735. int owl_pinctrl_probe(struct platform_device *pdev,
  736. struct owl_pinctrl_soc_data *soc_data)
  737. {
  738. struct owl_pinctrl *pctrl;
  739. int ret, i;
  740. pctrl = devm_kzalloc(&pdev->dev, sizeof(*pctrl), GFP_KERNEL);
  741. if (!pctrl)
  742. return -ENOMEM;
  743. pctrl->base = devm_platform_ioremap_resource(pdev, 0);
  744. if (IS_ERR(pctrl->base))
  745. return PTR_ERR(pctrl->base);
  746. /* enable GPIO/MFP clock */
  747. pctrl->clk = devm_clk_get(&pdev->dev, NULL);
  748. if (IS_ERR(pctrl->clk)) {
  749. dev_err(&pdev->dev, "no clock defined\n");
  750. return PTR_ERR(pctrl->clk);
  751. }
  752. ret = clk_prepare_enable(pctrl->clk);
  753. if (ret) {
  754. dev_err(&pdev->dev, "clk enable failed\n");
  755. return ret;
  756. }
  757. raw_spin_lock_init(&pctrl->lock);
  758. owl_pinctrl_desc.name = dev_name(&pdev->dev);
  759. owl_pinctrl_desc.pins = soc_data->pins;
  760. owl_pinctrl_desc.npins = soc_data->npins;
  761. pctrl->chip.direction_input = owl_gpio_direction_input;
  762. pctrl->chip.direction_output = owl_gpio_direction_output;
  763. pctrl->chip.get = owl_gpio_get;
  764. pctrl->chip.set = owl_gpio_set;
  765. pctrl->chip.request = owl_gpio_request;
  766. pctrl->chip.free = owl_gpio_free;
  767. pctrl->soc = soc_data;
  768. pctrl->dev = &pdev->dev;
  769. pctrl->pctrldev = devm_pinctrl_register(&pdev->dev,
  770. &owl_pinctrl_desc, pctrl);
  771. if (IS_ERR(pctrl->pctrldev)) {
  772. dev_err(&pdev->dev, "could not register Actions OWL pinmux driver\n");
  773. ret = PTR_ERR(pctrl->pctrldev);
  774. goto err_exit;
  775. }
  776. ret = platform_irq_count(pdev);
  777. if (ret < 0)
  778. goto err_exit;
  779. pctrl->num_irq = ret;
  780. pctrl->irq = devm_kcalloc(&pdev->dev, pctrl->num_irq,
  781. sizeof(*pctrl->irq), GFP_KERNEL);
  782. if (!pctrl->irq) {
  783. ret = -ENOMEM;
  784. goto err_exit;
  785. }
  786. for (i = 0; i < pctrl->num_irq ; i++) {
  787. ret = platform_get_irq(pdev, i);
  788. if (ret < 0)
  789. goto err_exit;
  790. pctrl->irq[i] = ret;
  791. }
  792. ret = owl_gpio_init(pctrl);
  793. if (ret)
  794. goto err_exit;
  795. platform_set_drvdata(pdev, pctrl);
  796. return 0;
  797. err_exit:
  798. clk_disable_unprepare(pctrl->clk);
  799. return ret;
  800. }