gro: Allow tunnel stacking in the case of FOU/GUE
[linux/fpc-iii.git] / drivers / pinctrl / intel / pinctrl-intel.c
blob00768e53deec0061d42e467fa42690879459015c
1 /*
2 * Intel pinctrl/GPIO core driver.
4 * Copyright (C) 2015, Intel Corporation
5 * Authors: Mathias Nyman <mathias.nyman@linux.intel.com>
6 * Mika Westerberg <mika.westerberg@linux.intel.com>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 as
10 * published by the Free Software Foundation.
13 #include <linux/module.h>
14 #include <linux/init.h>
15 #include <linux/acpi.h>
16 #include <linux/gpio.h>
17 #include <linux/gpio/driver.h>
18 #include <linux/platform_device.h>
19 #include <linux/pm.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>
25 #include "pinctrl-intel.h"
27 /* Maximum number of pads in each group */
28 #define NPADS_IN_GPP 24
30 /* Offset from regs */
31 #define PADBAR 0x00c
32 #define GPI_IS 0x100
33 #define GPI_GPE_STS 0x140
34 #define GPI_GPE_EN 0x160
36 #define PADOWN_BITS 4
37 #define PADOWN_SHIFT(p) ((p) % 8 * PADOWN_BITS)
38 #define PADOWN_MASK(p) (0xf << PADOWN_SHIFT(p))
40 /* Offset from pad_regs */
41 #define PADCFG0 0x000
42 #define PADCFG0_RXEVCFG_SHIFT 25
43 #define PADCFG0_RXEVCFG_MASK (3 << PADCFG0_RXEVCFG_SHIFT)
44 #define PADCFG0_RXEVCFG_LEVEL 0
45 #define PADCFG0_RXEVCFG_EDGE 1
46 #define PADCFG0_RXEVCFG_DISABLED 2
47 #define PADCFG0_RXEVCFG_EDGE_BOTH 3
48 #define PADCFG0_RXINV BIT(23)
49 #define PADCFG0_GPIROUTIOXAPIC BIT(20)
50 #define PADCFG0_GPIROUTSCI BIT(19)
51 #define PADCFG0_GPIROUTSMI BIT(18)
52 #define PADCFG0_GPIROUTNMI BIT(17)
53 #define PADCFG0_PMODE_SHIFT 10
54 #define PADCFG0_PMODE_MASK (0xf << PADCFG0_PMODE_SHIFT)
55 #define PADCFG0_GPIORXDIS BIT(9)
56 #define PADCFG0_GPIOTXDIS BIT(8)
57 #define PADCFG0_GPIORXSTATE BIT(1)
58 #define PADCFG0_GPIOTXSTATE BIT(0)
60 #define PADCFG1 0x004
61 #define PADCFG1_TERM_UP BIT(13)
62 #define PADCFG1_TERM_SHIFT 10
63 #define PADCFG1_TERM_MASK (7 << PADCFG1_TERM_SHIFT)
64 #define PADCFG1_TERM_20K 4
65 #define PADCFG1_TERM_2K 3
66 #define PADCFG1_TERM_5K 2
67 #define PADCFG1_TERM_1K 1
69 struct intel_pad_context {
70 u32 padcfg0;
71 u32 padcfg1;
74 struct intel_community_context {
75 u32 *intmask;
78 struct intel_pinctrl_context {
79 struct intel_pad_context *pads;
80 struct intel_community_context *communities;
83 /**
84 * struct intel_pinctrl - Intel pinctrl private structure
85 * @dev: Pointer to the device structure
86 * @lock: Lock to serialize register access
87 * @pctldesc: Pin controller description
88 * @pctldev: Pointer to the pin controller device
89 * @chip: GPIO chip in this pin controller
90 * @soc: SoC/PCH specific pin configuration data
91 * @communities: All communities in this pin controller
92 * @ncommunities: Number of communities in this pin controller
93 * @context: Configuration saved over system sleep
95 struct intel_pinctrl {
96 struct device *dev;
97 spinlock_t lock;
98 struct pinctrl_desc pctldesc;
99 struct pinctrl_dev *pctldev;
100 struct gpio_chip chip;
101 const struct intel_pinctrl_soc_data *soc;
102 struct intel_community *communities;
103 size_t ncommunities;
104 struct intel_pinctrl_context context;
107 #define gpiochip_to_pinctrl(c) container_of(c, struct intel_pinctrl, chip)
108 #define pin_to_padno(c, p) ((p) - (c)->pin_base)
110 static struct intel_community *intel_get_community(struct intel_pinctrl *pctrl,
111 unsigned pin)
113 struct intel_community *community;
114 int i;
116 for (i = 0; i < pctrl->ncommunities; i++) {
117 community = &pctrl->communities[i];
118 if (pin >= community->pin_base &&
119 pin < community->pin_base + community->npins)
120 return community;
123 dev_warn(pctrl->dev, "failed to find community for pin %u\n", pin);
124 return NULL;
127 static void __iomem *intel_get_padcfg(struct intel_pinctrl *pctrl, unsigned pin,
128 unsigned reg)
130 const struct intel_community *community;
131 unsigned padno;
133 community = intel_get_community(pctrl, pin);
134 if (!community)
135 return NULL;
137 padno = pin_to_padno(community, pin);
138 return community->pad_regs + reg + padno * 8;
141 static bool intel_pad_owned_by_host(struct intel_pinctrl *pctrl, unsigned pin)
143 const struct intel_community *community;
144 unsigned padno, gpp, gpp_offset, offset;
145 void __iomem *padown;
147 community = intel_get_community(pctrl, pin);
148 if (!community)
149 return false;
150 if (!community->padown_offset)
151 return true;
153 padno = pin_to_padno(community, pin);
154 gpp = padno / NPADS_IN_GPP;
155 gpp_offset = padno % NPADS_IN_GPP;
156 offset = community->padown_offset + gpp * 16 + (gpp_offset / 8) * 4;
157 padown = community->regs + offset;
159 return !(readl(padown) & PADOWN_MASK(padno));
162 static bool intel_pad_reserved_for_acpi(struct intel_pinctrl *pctrl,
163 unsigned pin)
165 const struct intel_community *community;
166 unsigned padno, gpp, offset;
167 void __iomem *hostown;
169 community = intel_get_community(pctrl, pin);
170 if (!community)
171 return true;
172 if (!community->hostown_offset)
173 return false;
175 padno = pin_to_padno(community, pin);
176 gpp = padno / NPADS_IN_GPP;
177 offset = community->hostown_offset + gpp * 4;
178 hostown = community->regs + offset;
180 return !(readl(hostown) & BIT(padno % NPADS_IN_GPP));
183 static bool intel_pad_locked(struct intel_pinctrl *pctrl, unsigned pin)
185 struct intel_community *community;
186 unsigned padno, gpp, offset;
187 u32 value;
189 community = intel_get_community(pctrl, pin);
190 if (!community)
191 return true;
192 if (!community->padcfglock_offset)
193 return false;
195 padno = pin_to_padno(community, pin);
196 gpp = padno / NPADS_IN_GPP;
199 * If PADCFGLOCK and PADCFGLOCKTX bits are both clear for this pad,
200 * the pad is considered unlocked. Any other case means that it is
201 * either fully or partially locked and we don't touch it.
203 offset = community->padcfglock_offset + gpp * 8;
204 value = readl(community->regs + offset);
205 if (value & BIT(pin % NPADS_IN_GPP))
206 return true;
208 offset = community->padcfglock_offset + 4 + gpp * 8;
209 value = readl(community->regs + offset);
210 if (value & BIT(pin % NPADS_IN_GPP))
211 return true;
213 return false;
216 static bool intel_pad_usable(struct intel_pinctrl *pctrl, unsigned pin)
218 return intel_pad_owned_by_host(pctrl, pin) &&
219 !intel_pad_reserved_for_acpi(pctrl, pin) &&
220 !intel_pad_locked(pctrl, pin);
223 static int intel_get_groups_count(struct pinctrl_dev *pctldev)
225 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
227 return pctrl->soc->ngroups;
230 static const char *intel_get_group_name(struct pinctrl_dev *pctldev,
231 unsigned group)
233 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
235 return pctrl->soc->groups[group].name;
238 static int intel_get_group_pins(struct pinctrl_dev *pctldev, unsigned group,
239 const unsigned **pins, unsigned *npins)
241 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
243 *pins = pctrl->soc->groups[group].pins;
244 *npins = pctrl->soc->groups[group].npins;
245 return 0;
248 static void intel_pin_dbg_show(struct pinctrl_dev *pctldev, struct seq_file *s,
249 unsigned pin)
251 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
252 u32 cfg0, cfg1, mode;
253 bool locked, acpi;
255 if (!intel_pad_owned_by_host(pctrl, pin)) {
256 seq_puts(s, "not available");
257 return;
260 cfg0 = readl(intel_get_padcfg(pctrl, pin, PADCFG0));
261 cfg1 = readl(intel_get_padcfg(pctrl, pin, PADCFG1));
263 mode = (cfg0 & PADCFG0_PMODE_MASK) >> PADCFG0_PMODE_SHIFT;
264 if (!mode)
265 seq_puts(s, "GPIO ");
266 else
267 seq_printf(s, "mode %d ", mode);
269 seq_printf(s, "0x%08x 0x%08x", cfg0, cfg1);
271 locked = intel_pad_locked(pctrl, pin);
272 acpi = intel_pad_reserved_for_acpi(pctrl, pin);
274 if (locked || acpi) {
275 seq_puts(s, " [");
276 if (locked) {
277 seq_puts(s, "LOCKED");
278 if (acpi)
279 seq_puts(s, ", ");
281 if (acpi)
282 seq_puts(s, "ACPI");
283 seq_puts(s, "]");
287 static const struct pinctrl_ops intel_pinctrl_ops = {
288 .get_groups_count = intel_get_groups_count,
289 .get_group_name = intel_get_group_name,
290 .get_group_pins = intel_get_group_pins,
291 .pin_dbg_show = intel_pin_dbg_show,
294 static int intel_get_functions_count(struct pinctrl_dev *pctldev)
296 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
298 return pctrl->soc->nfunctions;
301 static const char *intel_get_function_name(struct pinctrl_dev *pctldev,
302 unsigned function)
304 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
306 return pctrl->soc->functions[function].name;
309 static int intel_get_function_groups(struct pinctrl_dev *pctldev,
310 unsigned function,
311 const char * const **groups,
312 unsigned * const ngroups)
314 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
316 *groups = pctrl->soc->functions[function].groups;
317 *ngroups = pctrl->soc->functions[function].ngroups;
318 return 0;
321 static int intel_pinmux_set_mux(struct pinctrl_dev *pctldev, unsigned function,
322 unsigned group)
324 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
325 const struct intel_pingroup *grp = &pctrl->soc->groups[group];
326 unsigned long flags;
327 int i;
329 spin_lock_irqsave(&pctrl->lock, flags);
332 * All pins in the groups needs to be accessible and writable
333 * before we can enable the mux for this group.
335 for (i = 0; i < grp->npins; i++) {
336 if (!intel_pad_usable(pctrl, grp->pins[i])) {
337 spin_unlock_irqrestore(&pctrl->lock, flags);
338 return -EBUSY;
342 /* Now enable the mux setting for each pin in the group */
343 for (i = 0; i < grp->npins; i++) {
344 void __iomem *padcfg0;
345 u32 value;
347 padcfg0 = intel_get_padcfg(pctrl, grp->pins[i], PADCFG0);
348 value = readl(padcfg0);
350 value &= ~PADCFG0_PMODE_MASK;
351 value |= grp->mode << PADCFG0_PMODE_SHIFT;
353 writel(value, padcfg0);
356 spin_unlock_irqrestore(&pctrl->lock, flags);
358 return 0;
361 static int intel_gpio_request_enable(struct pinctrl_dev *pctldev,
362 struct pinctrl_gpio_range *range,
363 unsigned pin)
365 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
366 void __iomem *padcfg0;
367 unsigned long flags;
368 u32 value;
370 spin_lock_irqsave(&pctrl->lock, flags);
372 if (!intel_pad_usable(pctrl, pin)) {
373 spin_unlock_irqrestore(&pctrl->lock, flags);
374 return -EBUSY;
377 padcfg0 = intel_get_padcfg(pctrl, pin, PADCFG0);
378 /* Put the pad into GPIO mode */
379 value = readl(padcfg0) & ~PADCFG0_PMODE_MASK;
380 /* Disable SCI/SMI/NMI generation */
381 value &= ~(PADCFG0_GPIROUTIOXAPIC | PADCFG0_GPIROUTSCI);
382 value &= ~(PADCFG0_GPIROUTSMI | PADCFG0_GPIROUTNMI);
383 /* Disable TX buffer and enable RX (this will be input) */
384 value &= ~PADCFG0_GPIORXDIS;
385 value |= PADCFG0_GPIOTXDIS;
386 writel(value, padcfg0);
388 spin_unlock_irqrestore(&pctrl->lock, flags);
390 return 0;
393 static int intel_gpio_set_direction(struct pinctrl_dev *pctldev,
394 struct pinctrl_gpio_range *range,
395 unsigned pin, bool input)
397 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
398 void __iomem *padcfg0;
399 unsigned long flags;
400 u32 value;
402 spin_lock_irqsave(&pctrl->lock, flags);
404 padcfg0 = intel_get_padcfg(pctrl, pin, PADCFG0);
406 value = readl(padcfg0);
407 if (input)
408 value |= PADCFG0_GPIOTXDIS;
409 else
410 value &= ~PADCFG0_GPIOTXDIS;
411 writel(value, padcfg0);
413 spin_unlock_irqrestore(&pctrl->lock, flags);
415 return 0;
418 static const struct pinmux_ops intel_pinmux_ops = {
419 .get_functions_count = intel_get_functions_count,
420 .get_function_name = intel_get_function_name,
421 .get_function_groups = intel_get_function_groups,
422 .set_mux = intel_pinmux_set_mux,
423 .gpio_request_enable = intel_gpio_request_enable,
424 .gpio_set_direction = intel_gpio_set_direction,
427 static int intel_config_get(struct pinctrl_dev *pctldev, unsigned pin,
428 unsigned long *config)
430 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
431 enum pin_config_param param = pinconf_to_config_param(*config);
432 u32 value, term;
433 u16 arg = 0;
435 if (!intel_pad_owned_by_host(pctrl, pin))
436 return -ENOTSUPP;
438 value = readl(intel_get_padcfg(pctrl, pin, PADCFG1));
439 term = (value & PADCFG1_TERM_MASK) >> PADCFG1_TERM_SHIFT;
441 switch (param) {
442 case PIN_CONFIG_BIAS_DISABLE:
443 if (term)
444 return -EINVAL;
445 break;
447 case PIN_CONFIG_BIAS_PULL_UP:
448 if (!term || !(value & PADCFG1_TERM_UP))
449 return -EINVAL;
451 switch (term) {
452 case PADCFG1_TERM_1K:
453 arg = 1000;
454 break;
455 case PADCFG1_TERM_2K:
456 arg = 2000;
457 break;
458 case PADCFG1_TERM_5K:
459 arg = 5000;
460 break;
461 case PADCFG1_TERM_20K:
462 arg = 20000;
463 break;
466 break;
468 case PIN_CONFIG_BIAS_PULL_DOWN:
469 if (!term || value & PADCFG1_TERM_UP)
470 return -EINVAL;
472 switch (term) {
473 case PADCFG1_TERM_5K:
474 arg = 5000;
475 break;
476 case PADCFG1_TERM_20K:
477 arg = 20000;
478 break;
481 break;
483 default:
484 return -ENOTSUPP;
487 *config = pinconf_to_config_packed(param, arg);
488 return 0;
491 static int intel_config_set_pull(struct intel_pinctrl *pctrl, unsigned pin,
492 unsigned long config)
494 unsigned param = pinconf_to_config_param(config);
495 unsigned arg = pinconf_to_config_argument(config);
496 void __iomem *padcfg1;
497 unsigned long flags;
498 int ret = 0;
499 u32 value;
501 spin_lock_irqsave(&pctrl->lock, flags);
503 padcfg1 = intel_get_padcfg(pctrl, pin, PADCFG1);
504 value = readl(padcfg1);
506 switch (param) {
507 case PIN_CONFIG_BIAS_DISABLE:
508 value &= ~(PADCFG1_TERM_MASK | PADCFG1_TERM_UP);
509 break;
511 case PIN_CONFIG_BIAS_PULL_UP:
512 value &= ~PADCFG1_TERM_MASK;
514 value |= PADCFG1_TERM_UP;
516 switch (arg) {
517 case 20000:
518 value |= PADCFG1_TERM_20K << PADCFG1_TERM_SHIFT;
519 break;
520 case 5000:
521 value |= PADCFG1_TERM_5K << PADCFG1_TERM_SHIFT;
522 break;
523 case 2000:
524 value |= PADCFG1_TERM_2K << PADCFG1_TERM_SHIFT;
525 break;
526 case 1000:
527 value |= PADCFG1_TERM_1K << PADCFG1_TERM_SHIFT;
528 break;
529 default:
530 ret = -EINVAL;
533 break;
535 case PIN_CONFIG_BIAS_PULL_DOWN:
536 value &= ~(PADCFG1_TERM_UP | PADCFG1_TERM_MASK);
538 switch (arg) {
539 case 20000:
540 value |= PADCFG1_TERM_20K << PADCFG1_TERM_SHIFT;
541 break;
542 case 5000:
543 value |= PADCFG1_TERM_5K << PADCFG1_TERM_SHIFT;
544 break;
545 default:
546 ret = -EINVAL;
549 break;
552 if (!ret)
553 writel(value, padcfg1);
555 spin_unlock_irqrestore(&pctrl->lock, flags);
557 return ret;
560 static int intel_config_set(struct pinctrl_dev *pctldev, unsigned pin,
561 unsigned long *configs, unsigned nconfigs)
563 struct intel_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
564 int i, ret;
566 if (!intel_pad_usable(pctrl, pin))
567 return -ENOTSUPP;
569 for (i = 0; i < nconfigs; i++) {
570 switch (pinconf_to_config_param(configs[i])) {
571 case PIN_CONFIG_BIAS_DISABLE:
572 case PIN_CONFIG_BIAS_PULL_UP:
573 case PIN_CONFIG_BIAS_PULL_DOWN:
574 ret = intel_config_set_pull(pctrl, pin, configs[i]);
575 if (ret)
576 return ret;
577 break;
579 default:
580 return -ENOTSUPP;
584 return 0;
587 static const struct pinconf_ops intel_pinconf_ops = {
588 .is_generic = true,
589 .pin_config_get = intel_config_get,
590 .pin_config_set = intel_config_set,
593 static const struct pinctrl_desc intel_pinctrl_desc = {
594 .pctlops = &intel_pinctrl_ops,
595 .pmxops = &intel_pinmux_ops,
596 .confops = &intel_pinconf_ops,
597 .owner = THIS_MODULE,
600 static int intel_gpio_request(struct gpio_chip *chip, unsigned offset)
602 return pinctrl_request_gpio(chip->base + offset);
605 static void intel_gpio_free(struct gpio_chip *chip, unsigned offset)
607 pinctrl_free_gpio(chip->base + offset);
610 static int intel_gpio_get(struct gpio_chip *chip, unsigned offset)
612 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(chip);
613 void __iomem *reg;
615 reg = intel_get_padcfg(pctrl, offset, PADCFG0);
616 if (!reg)
617 return -EINVAL;
619 return !!(readl(reg) & PADCFG0_GPIORXSTATE);
622 static void intel_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
624 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(chip);
625 void __iomem *reg;
627 reg = intel_get_padcfg(pctrl, offset, PADCFG0);
628 if (reg) {
629 unsigned long flags;
630 u32 padcfg0;
632 spin_lock_irqsave(&pctrl->lock, flags);
633 padcfg0 = readl(reg);
634 if (value)
635 padcfg0 |= PADCFG0_GPIOTXSTATE;
636 else
637 padcfg0 &= ~PADCFG0_GPIOTXSTATE;
638 writel(padcfg0, reg);
639 spin_unlock_irqrestore(&pctrl->lock, flags);
643 static int intel_gpio_direction_input(struct gpio_chip *chip, unsigned offset)
645 return pinctrl_gpio_direction_input(chip->base + offset);
648 static int intel_gpio_direction_output(struct gpio_chip *chip, unsigned offset,
649 int value)
651 intel_gpio_set(chip, offset, value);
652 return pinctrl_gpio_direction_output(chip->base + offset);
655 static const struct gpio_chip intel_gpio_chip = {
656 .owner = THIS_MODULE,
657 .request = intel_gpio_request,
658 .free = intel_gpio_free,
659 .direction_input = intel_gpio_direction_input,
660 .direction_output = intel_gpio_direction_output,
661 .get = intel_gpio_get,
662 .set = intel_gpio_set,
665 static void intel_gpio_irq_ack(struct irq_data *d)
667 struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
668 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(gc);
669 const struct intel_community *community;
670 unsigned pin = irqd_to_hwirq(d);
672 spin_lock(&pctrl->lock);
674 community = intel_get_community(pctrl, pin);
675 if (community) {
676 unsigned padno = pin_to_padno(community, pin);
677 unsigned gpp_offset = padno % NPADS_IN_GPP;
678 unsigned gpp = padno / NPADS_IN_GPP;
680 writel(BIT(gpp_offset), community->regs + GPI_IS + gpp * 4);
683 spin_unlock(&pctrl->lock);
686 static void intel_gpio_irq_mask_unmask(struct irq_data *d, bool mask)
688 struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
689 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(gc);
690 const struct intel_community *community;
691 unsigned pin = irqd_to_hwirq(d);
692 unsigned long flags;
694 spin_lock_irqsave(&pctrl->lock, flags);
696 community = intel_get_community(pctrl, pin);
697 if (community) {
698 unsigned padno = pin_to_padno(community, pin);
699 unsigned gpp_offset = padno % NPADS_IN_GPP;
700 unsigned gpp = padno / NPADS_IN_GPP;
701 void __iomem *reg;
702 u32 value;
704 reg = community->regs + community->ie_offset + gpp * 4;
705 value = readl(reg);
706 if (mask)
707 value &= ~BIT(gpp_offset);
708 else
709 value |= BIT(gpp_offset);
710 writel(value, reg);
713 spin_unlock_irqrestore(&pctrl->lock, flags);
716 static void intel_gpio_irq_mask(struct irq_data *d)
718 intel_gpio_irq_mask_unmask(d, true);
721 static void intel_gpio_irq_unmask(struct irq_data *d)
723 intel_gpio_irq_mask_unmask(d, false);
726 static int intel_gpio_irq_type(struct irq_data *d, unsigned type)
728 struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
729 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(gc);
730 unsigned pin = irqd_to_hwirq(d);
731 unsigned long flags;
732 void __iomem *reg;
733 u32 value;
735 reg = intel_get_padcfg(pctrl, pin, PADCFG0);
736 if (!reg)
737 return -EINVAL;
739 spin_lock_irqsave(&pctrl->lock, flags);
741 value = readl(reg);
743 value &= ~(PADCFG0_RXEVCFG_MASK | PADCFG0_RXINV);
745 if ((type & IRQ_TYPE_EDGE_BOTH) == IRQ_TYPE_EDGE_BOTH) {
746 value |= PADCFG0_RXEVCFG_EDGE_BOTH << PADCFG0_RXEVCFG_SHIFT;
747 } else if (type & IRQ_TYPE_EDGE_FALLING) {
748 value |= PADCFG0_RXEVCFG_EDGE << PADCFG0_RXEVCFG_SHIFT;
749 value |= PADCFG0_RXINV;
750 } else if (type & IRQ_TYPE_EDGE_RISING) {
751 value |= PADCFG0_RXEVCFG_EDGE << PADCFG0_RXEVCFG_SHIFT;
752 } else if (type & IRQ_TYPE_LEVEL_LOW) {
753 value |= PADCFG0_RXINV;
754 } else {
755 value |= PADCFG0_RXEVCFG_DISABLED << PADCFG0_RXEVCFG_SHIFT;
758 writel(value, reg);
760 if (type & IRQ_TYPE_EDGE_BOTH)
761 __irq_set_handler_locked(d->irq, handle_edge_irq);
762 else if (type & IRQ_TYPE_LEVEL_MASK)
763 __irq_set_handler_locked(d->irq, handle_level_irq);
765 spin_unlock_irqrestore(&pctrl->lock, flags);
767 return 0;
770 static int intel_gpio_irq_wake(struct irq_data *d, unsigned int on)
772 struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
773 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(gc);
774 const struct intel_community *community;
775 unsigned pin = irqd_to_hwirq(d);
776 unsigned padno, gpp, gpp_offset;
777 u32 gpe_en;
779 community = intel_get_community(pctrl, pin);
780 if (!community)
781 return -EINVAL;
783 padno = pin_to_padno(community, pin);
784 gpp = padno / NPADS_IN_GPP;
785 gpp_offset = padno % NPADS_IN_GPP;
787 /* Clear the existing wake status */
788 writel(BIT(gpp_offset), community->regs + GPI_GPE_STS + gpp * 4);
791 * The controller will generate wake when GPE of the corresponding
792 * pad is enabled and it is not routed to SCI (GPIROUTSCI is not
793 * set).
795 gpe_en = readl(community->regs + GPI_GPE_EN + gpp * 4);
796 if (on)
797 gpe_en |= BIT(gpp_offset);
798 else
799 gpe_en &= ~BIT(gpp_offset);
800 writel(gpe_en, community->regs + GPI_GPE_EN + gpp * 4);
802 dev_dbg(pctrl->dev, "%sable wake for pin %u\n", on ? "en" : "dis", pin);
803 return 0;
806 static void intel_gpio_community_irq_handler(struct gpio_chip *gc,
807 const struct intel_community *community)
809 int gpp;
811 for (gpp = 0; gpp < community->ngpps; gpp++) {
812 unsigned long pending, enabled, gpp_offset;
814 pending = readl(community->regs + GPI_IS + gpp * 4);
815 enabled = readl(community->regs + community->ie_offset +
816 gpp * 4);
818 /* Only interrupts that are enabled */
819 pending &= enabled;
821 for_each_set_bit(gpp_offset, &pending, NPADS_IN_GPP) {
822 unsigned padno, irq;
825 * The last group in community can have less pins
826 * than NPADS_IN_GPP.
828 padno = gpp_offset + gpp * NPADS_IN_GPP;
829 if (padno >= community->npins)
830 break;
832 irq = irq_find_mapping(gc->irqdomain,
833 community->pin_base + padno);
834 generic_handle_irq(irq);
839 static void intel_gpio_irq_handler(unsigned irq, struct irq_desc *desc)
841 struct gpio_chip *gc = irq_desc_get_handler_data(desc);
842 struct intel_pinctrl *pctrl = gpiochip_to_pinctrl(gc);
843 struct irq_chip *chip = irq_get_chip(irq);
844 int i;
846 chained_irq_enter(chip, desc);
848 /* Need to check all communities for pending interrupts */
849 for (i = 0; i < pctrl->ncommunities; i++)
850 intel_gpio_community_irq_handler(gc, &pctrl->communities[i]);
852 chained_irq_exit(chip, desc);
855 static struct irq_chip intel_gpio_irqchip = {
856 .name = "intel-gpio",
857 .irq_ack = intel_gpio_irq_ack,
858 .irq_mask = intel_gpio_irq_mask,
859 .irq_unmask = intel_gpio_irq_unmask,
860 .irq_set_type = intel_gpio_irq_type,
861 .irq_set_wake = intel_gpio_irq_wake,
864 static void intel_gpio_irq_init(struct intel_pinctrl *pctrl)
866 size_t i;
868 for (i = 0; i < pctrl->ncommunities; i++) {
869 const struct intel_community *community;
870 void __iomem *base;
871 unsigned gpp;
873 community = &pctrl->communities[i];
874 base = community->regs;
876 for (gpp = 0; gpp < community->ngpps; gpp++) {
877 /* Mask and clear all interrupts */
878 writel(0, base + community->ie_offset + gpp * 4);
879 writel(0xffff, base + GPI_IS + gpp * 4);
884 static int intel_gpio_probe(struct intel_pinctrl *pctrl, int irq)
886 int ret;
888 pctrl->chip = intel_gpio_chip;
890 pctrl->chip.ngpio = pctrl->soc->npins;
891 pctrl->chip.label = dev_name(pctrl->dev);
892 pctrl->chip.dev = pctrl->dev;
893 pctrl->chip.base = -1;
895 ret = gpiochip_add(&pctrl->chip);
896 if (ret) {
897 dev_err(pctrl->dev, "failed to register gpiochip\n");
898 return ret;
901 ret = gpiochip_add_pin_range(&pctrl->chip, dev_name(pctrl->dev),
902 0, 0, pctrl->soc->npins);
903 if (ret) {
904 dev_err(pctrl->dev, "failed to add GPIO pin range\n");
905 gpiochip_remove(&pctrl->chip);
906 return ret;
909 ret = gpiochip_irqchip_add(&pctrl->chip, &intel_gpio_irqchip, 0,
910 handle_simple_irq, IRQ_TYPE_NONE);
911 if (ret) {
912 dev_err(pctrl->dev, "failed to add irqchip\n");
913 gpiochip_remove(&pctrl->chip);
914 return ret;
917 gpiochip_set_chained_irqchip(&pctrl->chip, &intel_gpio_irqchip, irq,
918 intel_gpio_irq_handler);
919 return 0;
922 static int intel_pinctrl_pm_init(struct intel_pinctrl *pctrl)
924 #ifdef CONFIG_PM_SLEEP
925 const struct intel_pinctrl_soc_data *soc = pctrl->soc;
926 struct intel_community_context *communities;
927 struct intel_pad_context *pads;
928 int i;
930 pads = devm_kcalloc(pctrl->dev, soc->npins, sizeof(*pads), GFP_KERNEL);
931 if (!pads)
932 return -ENOMEM;
934 communities = devm_kcalloc(pctrl->dev, pctrl->ncommunities,
935 sizeof(*communities), GFP_KERNEL);
936 if (!communities)
937 return -ENOMEM;
940 for (i = 0; i < pctrl->ncommunities; i++) {
941 struct intel_community *community = &pctrl->communities[i];
942 u32 *intmask;
944 intmask = devm_kcalloc(pctrl->dev, community->ngpps,
945 sizeof(*intmask), GFP_KERNEL);
946 if (!intmask)
947 return -ENOMEM;
949 communities[i].intmask = intmask;
952 pctrl->context.pads = pads;
953 pctrl->context.communities = communities;
954 #endif
956 return 0;
959 int intel_pinctrl_probe(struct platform_device *pdev,
960 const struct intel_pinctrl_soc_data *soc_data)
962 struct intel_pinctrl *pctrl;
963 int i, ret, irq;
965 if (!soc_data)
966 return -EINVAL;
968 pctrl = devm_kzalloc(&pdev->dev, sizeof(*pctrl), GFP_KERNEL);
969 if (!pctrl)
970 return -ENOMEM;
972 pctrl->dev = &pdev->dev;
973 pctrl->soc = soc_data;
974 spin_lock_init(&pctrl->lock);
977 * Make a copy of the communities which we can use to hold pointers
978 * to the registers.
980 pctrl->ncommunities = pctrl->soc->ncommunities;
981 pctrl->communities = devm_kcalloc(&pdev->dev, pctrl->ncommunities,
982 sizeof(*pctrl->communities), GFP_KERNEL);
983 if (!pctrl->communities)
984 return -ENOMEM;
986 for (i = 0; i < pctrl->ncommunities; i++) {
987 struct intel_community *community = &pctrl->communities[i];
988 struct resource *res;
989 void __iomem *regs;
990 u32 padbar;
992 *community = pctrl->soc->communities[i];
994 res = platform_get_resource(pdev, IORESOURCE_MEM,
995 community->barno);
996 regs = devm_ioremap_resource(&pdev->dev, res);
997 if (IS_ERR(regs))
998 return PTR_ERR(regs);
1000 /* Read offset of the pad configuration registers */
1001 padbar = readl(regs + PADBAR);
1003 community->regs = regs;
1004 community->pad_regs = regs + padbar;
1005 community->ngpps = DIV_ROUND_UP(community->npins, NPADS_IN_GPP);
1008 irq = platform_get_irq(pdev, 0);
1009 if (irq < 0) {
1010 dev_err(&pdev->dev, "failed to get interrupt number\n");
1011 return irq;
1014 ret = intel_pinctrl_pm_init(pctrl);
1015 if (ret)
1016 return ret;
1018 pctrl->pctldesc = intel_pinctrl_desc;
1019 pctrl->pctldesc.name = dev_name(&pdev->dev);
1020 pctrl->pctldesc.pins = pctrl->soc->pins;
1021 pctrl->pctldesc.npins = pctrl->soc->npins;
1023 pctrl->pctldev = pinctrl_register(&pctrl->pctldesc, &pdev->dev, pctrl);
1024 if (!pctrl->pctldev) {
1025 dev_err(&pdev->dev, "failed to register pinctrl driver\n");
1026 return -ENODEV;
1029 ret = intel_gpio_probe(pctrl, irq);
1030 if (ret) {
1031 pinctrl_unregister(pctrl->pctldev);
1032 return ret;
1035 platform_set_drvdata(pdev, pctrl);
1037 return 0;
1039 EXPORT_SYMBOL_GPL(intel_pinctrl_probe);
1041 int intel_pinctrl_remove(struct platform_device *pdev)
1043 struct intel_pinctrl *pctrl = platform_get_drvdata(pdev);
1045 gpiochip_remove(&pctrl->chip);
1046 pinctrl_unregister(pctrl->pctldev);
1048 return 0;
1050 EXPORT_SYMBOL_GPL(intel_pinctrl_remove);
1052 #ifdef CONFIG_PM_SLEEP
1053 int intel_pinctrl_suspend(struct device *dev)
1055 struct platform_device *pdev = to_platform_device(dev);
1056 struct intel_pinctrl *pctrl = platform_get_drvdata(pdev);
1057 struct intel_community_context *communities;
1058 struct intel_pad_context *pads;
1059 int i;
1061 pads = pctrl->context.pads;
1062 for (i = 0; i < pctrl->soc->npins; i++) {
1063 const struct pinctrl_pin_desc *desc = &pctrl->soc->pins[i];
1064 u32 val;
1066 if (!intel_pad_usable(pctrl, desc->number))
1067 continue;
1069 val = readl(intel_get_padcfg(pctrl, desc->number, PADCFG0));
1070 pads[i].padcfg0 = val & ~PADCFG0_GPIORXSTATE;
1071 val = readl(intel_get_padcfg(pctrl, desc->number, PADCFG1));
1072 pads[i].padcfg1 = val;
1075 communities = pctrl->context.communities;
1076 for (i = 0; i < pctrl->ncommunities; i++) {
1077 struct intel_community *community = &pctrl->communities[i];
1078 void __iomem *base;
1079 unsigned gpp;
1081 base = community->regs + community->ie_offset;
1082 for (gpp = 0; gpp < community->ngpps; gpp++)
1083 communities[i].intmask[gpp] = readl(base + gpp * 4);
1086 return 0;
1088 EXPORT_SYMBOL_GPL(intel_pinctrl_suspend);
1090 int intel_pinctrl_resume(struct device *dev)
1092 struct platform_device *pdev = to_platform_device(dev);
1093 struct intel_pinctrl *pctrl = platform_get_drvdata(pdev);
1094 const struct intel_community_context *communities;
1095 const struct intel_pad_context *pads;
1096 int i;
1098 /* Mask all interrupts */
1099 intel_gpio_irq_init(pctrl);
1101 pads = pctrl->context.pads;
1102 for (i = 0; i < pctrl->soc->npins; i++) {
1103 const struct pinctrl_pin_desc *desc = &pctrl->soc->pins[i];
1104 void __iomem *padcfg;
1105 u32 val;
1107 if (!intel_pad_usable(pctrl, desc->number))
1108 continue;
1110 padcfg = intel_get_padcfg(pctrl, desc->number, PADCFG0);
1111 val = readl(padcfg) & ~PADCFG0_GPIORXSTATE;
1112 if (val != pads[i].padcfg0) {
1113 writel(pads[i].padcfg0, padcfg);
1114 dev_dbg(dev, "restored pin %u padcfg0 %#08x\n",
1115 desc->number, readl(padcfg));
1118 padcfg = intel_get_padcfg(pctrl, desc->number, PADCFG1);
1119 val = readl(padcfg);
1120 if (val != pads[i].padcfg1) {
1121 writel(pads[i].padcfg1, padcfg);
1122 dev_dbg(dev, "restored pin %u padcfg1 %#08x\n",
1123 desc->number, readl(padcfg));
1127 communities = pctrl->context.communities;
1128 for (i = 0; i < pctrl->ncommunities; i++) {
1129 struct intel_community *community = &pctrl->communities[i];
1130 void __iomem *base;
1131 unsigned gpp;
1133 base = community->regs + community->ie_offset;
1134 for (gpp = 0; gpp < community->ngpps; gpp++) {
1135 writel(communities[i].intmask[gpp], base + gpp * 4);
1136 dev_dbg(dev, "restored mask %d/%u %#08x\n", i, gpp,
1137 readl(base + gpp * 4));
1141 return 0;
1143 EXPORT_SYMBOL_GPL(intel_pinctrl_resume);
1144 #endif
1146 MODULE_AUTHOR("Mathias Nyman <mathias.nyman@linux.intel.com>");
1147 MODULE_AUTHOR("Mika Westerberg <mika.westerberg@linux.intel.com>");
1148 MODULE_DESCRIPTION("Intel pinctrl/GPIO core driver");
1149 MODULE_LICENSE("GPL v2");