* [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working
@ 2016-03-16 18:15 Qipeng Zha
2016-03-16 18:15 ` [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable Qipeng Zha
2016-03-17 13:34 ` [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Linus Walleij
0 siblings, 2 replies; 7+ messages in thread
From: Qipeng Zha @ 2016-03-16 18:15 UTC (permalink / raw)
To: linux-gpio; +Cc: linus.walleij, mika.westerberg, Qi Zheng
High level trigger mode of GPIO interrupt is not set correctly
in intel_gpio_irq_type(), and will make this kind of interrupt
not respond.
Signed-off-by: Qi Zheng <qi.zheng@intel.com>
Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
---
drivers/pinctrl/intel/pinctrl-intel.c | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/drivers/pinctrl/intel/pinctrl-intel.c b/drivers/pinctrl/intel/pinctrl-intel.c
index 85536b4..c216cb3 100644
--- a/drivers/pinctrl/intel/pinctrl-intel.c
+++ b/drivers/pinctrl/intel/pinctrl-intel.c
@@ -741,8 +741,9 @@ static int intel_gpio_irq_type(struct irq_data *d, unsigned type)
value |= PADCFG0_RXINV;
} else if (type & IRQ_TYPE_EDGE_RISING) {
value |= PADCFG0_RXEVCFG_EDGE << PADCFG0_RXEVCFG_SHIFT;
- } else if (type & IRQ_TYPE_LEVEL_LOW) {
- value |= PADCFG0_RXINV;
+ } else if (type & IRQ_TYPE_LEVEL_MASK) {
+ if (type & IRQ_TYPE_LEVEL_LOW)
+ value |= PADCFG0_RXINV;
} else {
value |= PADCFG0_RXEVCFG_DISABLED << PADCFG0_RXEVCFG_SHIFT;
}
--
1.8.3.2
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable
2016-03-16 18:15 [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Qipeng Zha
@ 2016-03-16 18:15 ` Qipeng Zha
2016-03-17 14:07 ` Linus Walleij
2016-03-17 13:34 ` [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Linus Walleij
1 sibling, 1 reply; 7+ messages in thread
From: Qipeng Zha @ 2016-03-16 18:15 UTC (permalink / raw)
To: linux-gpio; +Cc: linus.walleij, mika.westerberg, Qi Zheng, Mika Westerberg
From: Qi Zheng <qi.zheng@intel.com>
There is unexpected gpio interrupt after irq_enable. If not
implemeted gpio_irq_enable callback, irq_enable calls irq_unmask
instead. But if there was interrupt set before the irq_enable,
unmask it may trigger the unexpected interrupt. By implementing
the gpio_irq_enable callback, do interrupt status ack, the issue
has gone.
Signed-off-by: Qi Zheng <qi.zheng@intel.com>
Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
---
change in v2:
remove one blank line.
---
drivers/pinctrl/intel/pinctrl-intel.c | 30 ++++++++++++++++++++++++++++++
1 file changed, 30 insertions(+)
diff --git a/drivers/pinctrl/intel/pinctrl-intel.c b/drivers/pinctrl/intel/pinctrl-intel.c
index c216cb3..6c2c816f 100644
--- a/drivers/pinctrl/intel/pinctrl-intel.c
+++ b/drivers/pinctrl/intel/pinctrl-intel.c
@@ -665,6 +665,35 @@ static void intel_gpio_irq_ack(struct irq_data *d)
spin_unlock(&pctrl->lock);
}
+static void intel_gpio_irq_enable(struct irq_data *d)
+{
+ struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+ struct intel_pinctrl *pctrl = gpiochip_get_data(gc);
+ const struct intel_community *community;
+ unsigned pin = irqd_to_hwirq(d);
+ unsigned long flags;
+
+ spin_lock_irqsave(&pctrl->lock, flags);
+
+ community = intel_get_community(pctrl, pin);
+ if (community) {
+ unsigned padno = pin_to_padno(community, pin);
+ unsigned gpp_size = community->gpp_size;
+ unsigned gpp_offset = padno % gpp_size;
+ unsigned gpp = padno / gpp_size;
+ u32 value;
+
+ /* Clear interrupt status first to avoid unexpected interrupt */
+ writel(BIT(gpp_offset), community->regs + GPI_IS + gpp * 4);
+
+ value = readl(community->regs + community->ie_offset + gpp * 4);
+ value |= BIT(gpp_offset);
+ writel(value, community->regs + community->ie_offset + gpp * 4);
+ }
+
+ spin_unlock_irqrestore(&pctrl->lock, flags);
+}
+
static void intel_gpio_irq_mask_unmask(struct irq_data *d, bool mask)
{
struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
@@ -853,6 +882,7 @@ static irqreturn_t intel_gpio_irq(int irq, void *data)
static struct irq_chip intel_gpio_irqchip = {
.name = "intel-gpio",
+ .irq_enable = intel_gpio_irq_enable,
.irq_ack = intel_gpio_irq_ack,
.irq_mask = intel_gpio_irq_mask,
.irq_unmask = intel_gpio_irq_unmask,
--
1.8.3.2
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working
2016-03-16 18:15 [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Qipeng Zha
2016-03-16 18:15 ` [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable Qipeng Zha
@ 2016-03-17 13:34 ` Linus Walleij
1 sibling, 0 replies; 7+ messages in thread
From: Linus Walleij @ 2016-03-17 13:34 UTC (permalink / raw)
To: Qipeng Zha; +Cc: linux-gpio@vger.kernel.org, Westerberg, Mika, Qi Zheng
On Wed, Mar 16, 2016 at 7:15 PM, Qipeng Zha <qipeng.zha@intel.com> wrote:
> High level trigger mode of GPIO interrupt is not set correctly
> in intel_gpio_irq_type(), and will make this kind of interrupt
> not respond.
>
> Signed-off-by: Qi Zheng <qi.zheng@intel.com>
> Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
Patch applied with Mika's ACK, from v1.
Yours,
Linus Walleij
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable
2016-03-16 18:15 ` [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable Qipeng Zha
@ 2016-03-17 14:07 ` Linus Walleij
2016-04-01 11:54 ` Westerberg, Mika
0 siblings, 1 reply; 7+ messages in thread
From: Linus Walleij @ 2016-03-17 14:07 UTC (permalink / raw)
To: Qipeng Zha
Cc: linux-gpio@vger.kernel.org, Westerberg, Mika, Qi Zheng,
Mika Westerberg
On Wed, Mar 16, 2016 at 7:15 PM, Qipeng Zha <qipeng.zha@intel.com> wrote:
> From: Qi Zheng <qi.zheng@intel.com>
>
> There is unexpected gpio interrupt after irq_enable. If not
> implemeted gpio_irq_enable callback, irq_enable calls irq_unmask
> instead. But if there was interrupt set before the irq_enable,
> unmask it may trigger the unexpected interrupt. By implementing
> the gpio_irq_enable callback, do interrupt status ack, the issue
> has gone.
>
> Signed-off-by: Qi Zheng <qi.zheng@intel.com>
> Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
> Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
Patch applied for fixes.
Yours,
Linus Walleij
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable
2016-03-17 14:07 ` Linus Walleij
@ 2016-04-01 11:54 ` Westerberg, Mika
2016-04-13 13:29 ` Linus Walleij
0 siblings, 1 reply; 7+ messages in thread
From: Westerberg, Mika @ 2016-04-01 11:54 UTC (permalink / raw)
To: Linus Walleij; +Cc: Qipeng Zha, linux-gpio@vger.kernel.org, Qi Zheng
On Thu, Mar 17, 2016 at 03:07:33PM +0100, Linus Walleij wrote:
> On Wed, Mar 16, 2016 at 7:15 PM, Qipeng Zha <qipeng.zha@intel.com> wrote:
>
> > From: Qi Zheng <qi.zheng@intel.com>
> >
> > There is unexpected gpio interrupt after irq_enable. If not
> > implemeted gpio_irq_enable callback, irq_enable calls irq_unmask
> > instead. But if there was interrupt set before the irq_enable,
> > unmask it may trigger the unexpected interrupt. By implementing
> > the gpio_irq_enable callback, do interrupt status ack, the issue
> > has gone.
> >
> > Signed-off-by: Qi Zheng <qi.zheng@intel.com>
> > Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
> > Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
>
> Patch applied for fixes.
Linus, what happend to these two patches? I do not find them in the
mainline for some reason.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable
2016-04-01 11:54 ` Westerberg, Mika
@ 2016-04-13 13:29 ` Linus Walleij
2016-04-13 13:54 ` Westerberg, Mika
0 siblings, 1 reply; 7+ messages in thread
From: Linus Walleij @ 2016-04-13 13:29 UTC (permalink / raw)
To: Westerberg, Mika; +Cc: Qipeng Zha, linux-gpio@vger.kernel.org, Qi Zheng
On Fri, Apr 1, 2016 at 1:54 PM, Westerberg, Mika
<mika.westerberg@intel.com> wrote:
> On Thu, Mar 17, 2016 at 03:07:33PM +0100, Linus Walleij wrote:
>> On Wed, Mar 16, 2016 at 7:15 PM, Qipeng Zha <qipeng.zha@intel.com> wrote:
>>
>> > From: Qi Zheng <qi.zheng@intel.com>
>> >
>> > There is unexpected gpio interrupt after irq_enable. If not
>> > implemeted gpio_irq_enable callback, irq_enable calls irq_unmask
>> > instead. But if there was interrupt set before the irq_enable,
>> > unmask it may trigger the unexpected interrupt. By implementing
>> > the gpio_irq_enable callback, do interrupt status ack, the issue
>> > has gone.
>> >
>> > Signed-off-by: Qi Zheng <qi.zheng@intel.com>
>> > Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
>> > Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
>>
>> Patch applied for fixes.
>
> Linus, what happend to these two patches? I do not find them in the
> mainline for some reason.
I guess lack of patience or me being slow :)
It's there now AFAICT.
Yours,
Linus Walleij
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable
2016-04-13 13:29 ` Linus Walleij
@ 2016-04-13 13:54 ` Westerberg, Mika
0 siblings, 0 replies; 7+ messages in thread
From: Westerberg, Mika @ 2016-04-13 13:54 UTC (permalink / raw)
To: Linus Walleij; +Cc: Qipeng Zha, linux-gpio@vger.kernel.org, Qi Zheng
On Wed, Apr 13, 2016 at 03:29:00PM +0200, Linus Walleij wrote:
> On Fri, Apr 1, 2016 at 1:54 PM, Westerberg, Mika
> <mika.westerberg@intel.com> wrote:
> > On Thu, Mar 17, 2016 at 03:07:33PM +0100, Linus Walleij wrote:
> >> On Wed, Mar 16, 2016 at 7:15 PM, Qipeng Zha <qipeng.zha@intel.com> wrote:
> >>
> >> > From: Qi Zheng <qi.zheng@intel.com>
> >> >
> >> > There is unexpected gpio interrupt after irq_enable. If not
> >> > implemeted gpio_irq_enable callback, irq_enable calls irq_unmask
> >> > instead. But if there was interrupt set before the irq_enable,
> >> > unmask it may trigger the unexpected interrupt. By implementing
> >> > the gpio_irq_enable callback, do interrupt status ack, the issue
> >> > has gone.
> >> >
> >> > Signed-off-by: Qi Zheng <qi.zheng@intel.com>
> >> > Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
> >> > Signed-off-by: Qipeng Zha <qipeng.zha@intel.com>
> >>
> >> Patch applied for fixes.
> >
> > Linus, what happend to these two patches? I do not find them in the
> > mainline for some reason.
>
> I guess lack of patience or me being slow :)
>
> It's there now AFAICT.
Thank you :)
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2016-04-13 13:54 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-03-16 18:15 [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Qipeng Zha
2016-03-16 18:15 ` [PATCH v2 2/2] pinctrl:Intel: implement gpio_irq_enable Qipeng Zha
2016-03-17 14:07 ` Linus Walleij
2016-04-01 11:54 ` Westerberg, Mika
2016-04-13 13:29 ` Linus Walleij
2016-04-13 13:54 ` Westerberg, Mika
2016-03-17 13:34 ` [PATCH v2 1/2] pinctrl:Intel: make the high level interrupt working Linus Walleij
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).