From: Sergei Shtylyov <sshtylyov@ru.mvista.com>
To: Manuel Lauss <mano@roarinelk.homelinux.net>
Cc: Ralf Baechle <ralf@linux-mips.org>,
Kevin Hickey <khickey@rmicorp.com>,
linux-mips@linux-mips.org
Subject: Re: [PATCH] Alchemy: modernize Pb1200 IRQ cascade handling code.
Date: Wed, 13 Aug 2008 16:34:19 +0400 [thread overview]
Message-ID: <48A2D4CB.1030901@ru.mvista.com> (raw)
In-Reply-To: <1218568881-3544-2-git-send-email-mano@roarinelk.homelinux.net>
Hello.
Manuel Lauss wrote:
> Signed-off-by: Manuel Lauss <mano@roarinelk.homelinux.net>
>
[...]
> diff --git a/arch/mips/au1000/pb1200/irqmap.c b/arch/mips/au1000/pb1200/irqmap.c
> index 2a505ad..7229f30 100644
> --- a/arch/mips/au1000/pb1200/irqmap.c
> +++ b/arch/mips/au1000/pb1200/irqmap.c
> @@ -48,62 +48,26 @@ int __initdata au1xxx_nr_irqs = ARRAY_SIZE(au1xxx_irq_map);
> /*
> * Support for External interrupts on the Pb1200 Development platform.
> */
> -static volatile int pb1200_cascade_en;
>
> -irqreturn_t pb1200_cascade_handler(int irq, void *dev_id)
> +static void pb1200_cascade_handler(unsigned int irq, struct irq_desc *desc)
> {
> unsigned short bisr = bcsr->int_status;
> - int extirq_nr = 0;
> -
> - /* Clear all the edge interrupts. This has no effect on level. */
>
Note this comment...
> - bcsr->int_status = bisr;
> - for ( ; bisr; bisr &= bisr - 1) {
> - extirq_nr = PB1200_INT_BEGIN + __ffs(bisr);
> - /* Ack and dispatch IRQ */
> - do_IRQ(extirq_nr);
> - }
>
> - return IRQ_RETVAL(1);
> + for ( ; bisr; bisr &= bisr - 1)
> + generic_handle_irq(PB1200_INT_BEGIN + __ffs(bisr));
> }
>
> -inline void pb1200_enable_irq(unsigned int irq_nr)
> +static void pb1200_unmask_irq(unsigned int irq_nr)
> {
> bcsr->intset_mask = 1 << (irq_nr - PB1200_INT_BEGIN);
> bcsr->intset = 1 << (irq_nr - PB1200_INT_BEGIN);
> }
>
> -inline void pb1200_disable_irq(unsigned int irq_nr)
> +static void pb1200_maskack_irq(unsigned int irq_nr)
> {
> bcsr->intclr_mask = 1 << (irq_nr - PB1200_INT_BEGIN);
> bcsr->intclr = 1 << (irq_nr - PB1200_INT_BEGIN);
>
I wonder what's the difference between int{clr|set} and
int{clr|set}_mask registers...
[...]
> + bcsr->int_status = 1 << (irq_nr - PB1200_INT_BEGIN); /* ack */
>
The above comment said that writing to this register has no effect on
the level-triggered interrupts, so this statement doesn't seem to make
sense since you're treating all interrupts as level-triggered below.
> @@ -113,12 +77,9 @@ static struct irq_chip external_irq_type = {
> #ifdef CONFIG_MIPS_DB1200
> .name = "Db1200 Ext",
> #endif
> - .startup = pb1200_startup_irq,
> - .shutdown = pb1200_shutdown_irq,
> - .ack = pb1200_disable_irq,
> - .mask = pb1200_disable_irq,
> - .mask_ack = pb1200_disable_irq,
> - .unmask = pb1200_enable_irq,
> + .mask = pb1200_maskack_irq,
> + .mask_ack = pb1200_maskack_irq,
>
You can use the same function for the mask() and mask_ack() methods
but it only should be masking IRQ, as clearing it doesn't make sense...
> @@ -147,14 +108,14 @@ void _board_init_irq(void)
> }
> #endif
>
> - for (irq = PB1200_INT_BEGIN; irq <= PB1200_INT_END; irq++) {
> - set_irq_chip_and_handler(irq, &external_irq_type,
> - handle_level_irq);
> - pb1200_disable_irq(irq);
> - }
> + /* mask & disable & ack all */
> + bcsr->intclr_mask = 0xffff;
> + bcsr->intclr = 0xffff;
> + bcsr->int_status = 0xffff;
> +
> + for (irq = PB1200_INT_BEGIN; irq <= PB1200_INT_END; irq++)
> + set_irq_chip_and_handler_name(irq, &external_irq_type,
> + handle_level_irq, "level");
>
Are all those IRQs indeed level-triggered?
WBR, Sergei
next prev parent reply other threads:[~2008-08-13 12:34 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-08-12 19:21 [PATCH] Alchemy: modernize Pb1200 IRQ cascade handling code Manuel Lauss
2008-08-13 12:34 ` Sergei Shtylyov [this message]
2008-08-13 12:59 ` Manuel Lauss
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=48A2D4CB.1030901@ru.mvista.com \
--to=sshtylyov@ru.mvista.com \
--cc=khickey@rmicorp.com \
--cc=linux-mips@linux-mips.org \
--cc=mano@roarinelk.homelinux.net \
--cc=ralf@linux-mips.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox