From: Mitchell Tasman <tasman@bbn.com>
To: Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org>
Cc: xenomai@xenomai.org
Subject: Re: [Xenomai] A possible mis-interaction between CONFIG_PREEMPT and GPIO IRQ handling for ARM, leading to extreme latency
Date: Tue, 29 May 2012 04:52:25 -0400 [thread overview]
Message-ID: <4FC48E49.3050105@bbn.com> (raw)
In-Reply-To: <4FC48383.6020201@xenomai.org>
On 05/29/2012 04:06 AM, Gilles Chanteperdrix wrote:
> On 05/29/2012 09:20 AM, Mitchell Tasman wrote:
>> One change that had been made along the way on the for-ipipe-2.6.38-arm
>> branch was to add a gpio_mask_ack_irq() function, and invoke it like so
>> from gpio_irq_handler(), instead of invoking gpio_ack_irq():
>>
>> #ifndef CONFIG_IPIPE
>> desc->irq_data.chip->irq_ack(&desc->irq_data);
>> #else /* CONFIG_IPIPE */
>> desc->irq_data.chip->irq_mask_ack(&desc->irq_data);
>> #endif /* CONFIG_IPIPE */
>>
>> With the latest commits, the gpio_mask_ack_irq() function remains, but
>> it is no longer invoked, with gpio_ack_irq() being called
>> unconditionally instead, as with the vanilla 2.6.38.8 source.
> desc->irq_data.chip->irq_mask_ack is the "mask_ack" method of the parent
> irq, not gpio_mask_ack_irq. gpio_mask_ack_irq is called normally when
> acknowledging the gpio irq.
Sorry about my confusion. Assuming that I'm looking at the correct
vector this time, in arch/arm/mach-omap2/irq.c for 2.6.38.8 as patched
for I-Pipe:
> static struct irq_chip omap_irq_chip = {
> .name = "INTC",
> .irq_ack = omap_mask_ack_irq,
> .irq_mask = omap_mask_irq,
> .irq_mask_ack = omap_mask_ack_irq,
> .irq_unmask = omap_unmask_irq,
> };
both halves of the former #ifndef block quoted above appear equivalent,
and the parent irq is indeed masked. Likewise, for 3.0.13 with
CONFIG_IPIPE defined, .irq_ack and .irq_mask_ack both appear to mask the
parent irq.
Regarding your recent commits to ipipe-gch.git, I'm imagining that once
the dust settles, the next step will be to cut new I-Pipe for ARM patch
sets and update xenomai-2.6.git accordingly. I'm planning an additional
round of testing soon thereafter.
Thanks much,
Mitch
next prev parent reply other threads:[~2012-05-29 8:52 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-05-22 0:31 [Xenomai] A possible mis-interaction between CONFIG_PREEMPT and GPIO IRQ handling for ARM, leading to extreme latency Mitchell Tasman
2012-05-22 7:40 ` Gilles Chanteperdrix
2012-05-22 8:07 ` Gilles Chanteperdrix
2012-05-22 8:34 ` [Xenomai] RE : " Jean-Pascal JULIEN
2012-05-22 8:51 ` Gilles Chanteperdrix
2012-05-22 11:52 ` [Xenomai] RE : " Jean-Pascal JULIEN
2012-05-22 12:38 ` Gilles Chanteperdrix
2012-05-22 13:23 ` [Xenomai] RE : " Jean-Pascal JULIEN
2012-05-22 13:33 ` Gilles Chanteperdrix
2012-05-22 21:22 ` [Xenomai] " Mitchell Tasman
2012-05-22 21:30 ` Gilles Chanteperdrix
2012-05-25 9:18 ` Mitchell Tasman
2012-05-25 12:20 ` Gilles Chanteperdrix
2012-05-29 7:20 ` Mitchell Tasman
2012-05-29 8:06 ` Gilles Chanteperdrix
2012-05-29 8:52 ` Mitchell Tasman [this message]
2012-06-07 7:44 ` Eric Eric
2012-06-07 8:21 ` Gilles Chanteperdrix
2012-06-07 8:34 ` Gilles Chanteperdrix
-- strict thread matches above, loose matches on Subject: below --
2012-05-22 15:50 Jean-Pascal JULIEN
2012-05-23 8:22 Jean-Pascal JULIEN
2012-05-23 17:05 ` Mitchell Tasman
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4FC48E49.3050105@bbn.com \
--to=tasman@bbn.com \
--cc=gilles.chanteperdrix@xenomai.org \
--cc=xenomai@xenomai.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.